From 7facfaa76616f798cd758c47f94cb527514c1abf Mon Sep 17 00:00:00 2001 From: Remington Breeze Date: Fri, 9 Apr 2021 13:11:17 -0700 Subject: [PATCH] feat: Argo Rollouts api-server and UI (#1015) Signed-off-by: Remington Breeze --- .codecov.yml | 12 +- .github/workflows/go.yml | 126 +- .gitignore | 3 + .golangci.yml | 2 + Dockerfile | 42 +- Makefile | 104 +- docs/dashboard.md | 14 + docs/dashboard/rollout-ui.png | Bin 0 -> 373035 bytes docs/dashboard/rollouts-list.png | Bin 0 -> 269980 bytes go.mod | 12 +- go.sum | 165 +- hack/install-codegen-go-tools.sh | 9 + hack/tools.go | 21 + manifests/crds/analysis-run-crd.yaml | 5 + manifests/crds/analysis-template-crd.yaml | 5 + .../crds/cluster-analysis-template-crd.yaml | 5 + manifests/install.yaml | 15 + manifests/namespace-install.yaml | 15 + metricproviders/kayenta/kayenta.go | 2 +- mkdocs.yml | 20 +- pkg/apiclient/rollout/forwarder_overwrite.go | 10 + pkg/apiclient/rollout/rollout.pb.go | 7474 ++++++ pkg/apiclient/rollout/rollout.pb.gw.go | 1475 ++ pkg/apiclient/rollout/rollout.proto | 223 + pkg/apiclient/rollout/rollout.swagger.json | 4340 +++ pkg/apis/rollouts/v1alpha1/analysis_types.go | 196 +- .../rollouts/v1alpha1/experiment_types.go | 90 +- pkg/apis/rollouts/v1alpha1/generated.pb.go | 21869 ++++++++++++++++ pkg/apis/rollouts/v1alpha1/generated.proto | 1224 + .../rollouts/v1alpha1/openapi_generated.go | 8 +- pkg/apis/rollouts/v1alpha1/types.go | 276 +- pkg/kubectl-argo-rollouts/cmd/cmd.go | 2 + .../cmd/dashboard/dashboard.go | 38 + pkg/kubectl-argo-rollouts/cmd/get/get.go | 5 +- .../cmd/get/get_experiment.go | 29 +- .../cmd/get/get_rollout.go | 83 +- pkg/kubectl-argo-rollouts/cmd/get/get_test.go | 14 + .../cmd/status/status.go | 10 +- .../info/analysisrun_info.go | 46 +- .../info/experiment_info.go | 32 +- pkg/kubectl-argo-rollouts/info/info.go | 10 +- pkg/kubectl-argo-rollouts/info/info_test.go | 47 +- pkg/kubectl-argo-rollouts/info/pod_info.go | 32 +- .../info/replicaset_info.go | 37 +- .../info/rollout_info.go | 82 +- .../viewcontroller/viewcontroller.go | 13 +- .../viewcontroller/viewcontroller_test.go | 14 +- server/server.go | 425 + server/static/.gitkeep | 0 sonar-project.properties | 15 + ui/.gitignore | 23 + ui/.prettierrc | 9 + ui/package.json | 70 + ui/src/app/App.scss | 38 + ui/src/app/App.tsx | 55 + .../action-button/action-button.scss | 74 + .../action-button/action-button.tsx | 89 + .../components/autocomplete/autocomplete.scss | 49 + .../components/autocomplete/autocomplete.tsx | 128 + .../app/components/effect-div/effect-div.scss | 19 + .../app/components/effect-div/effect-div.tsx | 26 + ui/src/app/components/header/header.scss | 66 + ui/src/app/components/header/header.tsx | 60 + .../app/components/info-item/info-item.scss | 54 + ui/src/app/components/info-item/info-item.tsx | 46 + ui/src/app/components/input/input.scss | 33 + ui/src/app/components/input/input.tsx | 54 + ui/src/app/components/menu/menu.scss | 31 + ui/src/app/components/menu/menu.tsx | 45 + ui/src/app/components/pods/pods.scss | 104 + ui/src/app/components/pods/pods.tsx | 145 + .../rollout-actions/rollout-actions.tsx | 87 + ui/src/app/components/rollout/rollout.scss | 283 + ui/src/app/components/rollout/rollout.tsx | 499 + .../rollouts-list/rollouts-list.scss | 139 + .../rollouts-list/rollouts-list.tsx | 190 + .../components/status-icon/status-icon.scss | 17 + .../components/status-icon/status-icon.tsx | 96 + ui/src/app/components/theme-div/theme-div.tsx | 28 + .../components/theme-toggle/theme-toggle.tsx | 12 + ui/src/app/components/tooltip/tooltip.scss | 15 + ui/src/app/components/tooltip/tooltip.tsx | 40 + .../app/components/wait-for/loading-bar.scss | 27 + ui/src/app/components/wait-for/spinner.scss | 10 + ui/src/app/components/wait-for/wait-for.tsx | 31 + ui/src/app/index.html | 13 + ui/src/app/index.tsx | 10 + ui/src/app/shared/context/api.tsx | 23 + ui/src/app/shared/context/theme.tsx | 31 + ui/src/app/shared/services/rollout.ts | 65 + ui/src/app/shared/styles/colors.scss | 77 + ui/src/app/shared/utils/utils.tsx | 98 + ui/src/app/shared/utils/watch.ts | 184 + ui/src/app/tsconfig.json | 16 + ui/src/app/webpack.common.js | 66 + ui/src/app/webpack.dev.js | 33 + ui/src/app/webpack.prod.js | 23 + .../assets/images/argo-icon-color-square.png | Bin 0 -> 102248 bytes .../assets/images/argo-icon-white-square.svg | 14 + ui/src/assets/images/argo-icon-white.svg | 1 + ui/src/models/rollout/generated/.gitignore | 3 + .../rollout/generated/.swagger-codegen-ignore | 23 + .../generated/.swagger-codegen/VERSION | 1 + ui/src/models/rollout/generated/api.ts | 6209 +++++ .../models/rollout/generated/api_test.spec.ts | 89 + .../models/rollout/generated/configuration.ts | 65 + ui/src/models/rollout/generated/custom.d.ts | 2 + ui/src/models/rollout/generated/git_push.sh | 51 + ui/src/models/rollout/generated/index.ts | 15 + ui/src/models/rollout/rollout.tsx | 4 + ui/tsconfig.json | 1 + ui/yarn.lock | 12136 +++++++++ utils/json/json.go | 35 +- 113 files changed, 59968 insertions(+), 708 deletions(-) create mode 100644 docs/dashboard.md create mode 100644 docs/dashboard/rollout-ui.png create mode 100644 docs/dashboard/rollouts-list.png create mode 100755 hack/install-codegen-go-tools.sh create mode 100644 hack/tools.go create mode 100644 pkg/apiclient/rollout/forwarder_overwrite.go create mode 100644 pkg/apiclient/rollout/rollout.pb.go create mode 100644 pkg/apiclient/rollout/rollout.pb.gw.go create mode 100644 pkg/apiclient/rollout/rollout.proto create mode 100644 pkg/apiclient/rollout/rollout.swagger.json create mode 100644 pkg/apis/rollouts/v1alpha1/generated.pb.go create mode 100644 pkg/apis/rollouts/v1alpha1/generated.proto create mode 100644 pkg/kubectl-argo-rollouts/cmd/dashboard/dashboard.go create mode 100644 server/server.go create mode 100644 server/static/.gitkeep create mode 100644 sonar-project.properties create mode 100644 ui/.gitignore create mode 100644 ui/.prettierrc create mode 100644 ui/package.json create mode 100644 ui/src/app/App.scss create mode 100644 ui/src/app/App.tsx create mode 100644 ui/src/app/components/action-button/action-button.scss create mode 100644 ui/src/app/components/action-button/action-button.tsx create mode 100644 ui/src/app/components/autocomplete/autocomplete.scss create mode 100644 ui/src/app/components/autocomplete/autocomplete.tsx create mode 100644 ui/src/app/components/effect-div/effect-div.scss create mode 100644 ui/src/app/components/effect-div/effect-div.tsx create mode 100644 ui/src/app/components/header/header.scss create mode 100644 ui/src/app/components/header/header.tsx create mode 100644 ui/src/app/components/info-item/info-item.scss create mode 100644 ui/src/app/components/info-item/info-item.tsx create mode 100644 ui/src/app/components/input/input.scss create mode 100644 ui/src/app/components/input/input.tsx create mode 100644 ui/src/app/components/menu/menu.scss create mode 100644 ui/src/app/components/menu/menu.tsx create mode 100644 ui/src/app/components/pods/pods.scss create mode 100644 ui/src/app/components/pods/pods.tsx create mode 100644 ui/src/app/components/rollout-actions/rollout-actions.tsx create mode 100644 ui/src/app/components/rollout/rollout.scss create mode 100644 ui/src/app/components/rollout/rollout.tsx create mode 100644 ui/src/app/components/rollouts-list/rollouts-list.scss create mode 100644 ui/src/app/components/rollouts-list/rollouts-list.tsx create mode 100644 ui/src/app/components/status-icon/status-icon.scss create mode 100644 ui/src/app/components/status-icon/status-icon.tsx create mode 100644 ui/src/app/components/theme-div/theme-div.tsx create mode 100644 ui/src/app/components/theme-toggle/theme-toggle.tsx create mode 100644 ui/src/app/components/tooltip/tooltip.scss create mode 100644 ui/src/app/components/tooltip/tooltip.tsx create mode 100644 ui/src/app/components/wait-for/loading-bar.scss create mode 100644 ui/src/app/components/wait-for/spinner.scss create mode 100644 ui/src/app/components/wait-for/wait-for.tsx create mode 100644 ui/src/app/index.html create mode 100644 ui/src/app/index.tsx create mode 100644 ui/src/app/shared/context/api.tsx create mode 100644 ui/src/app/shared/context/theme.tsx create mode 100644 ui/src/app/shared/services/rollout.ts create mode 100644 ui/src/app/shared/styles/colors.scss create mode 100644 ui/src/app/shared/utils/utils.tsx create mode 100644 ui/src/app/shared/utils/watch.ts create mode 100644 ui/src/app/tsconfig.json create mode 100644 ui/src/app/webpack.common.js create mode 100644 ui/src/app/webpack.dev.js create mode 100644 ui/src/app/webpack.prod.js create mode 100644 ui/src/assets/images/argo-icon-color-square.png create mode 100644 ui/src/assets/images/argo-icon-white-square.svg create mode 100644 ui/src/assets/images/argo-icon-white.svg create mode 100644 ui/src/models/rollout/generated/.gitignore create mode 100644 ui/src/models/rollout/generated/.swagger-codegen-ignore create mode 100644 ui/src/models/rollout/generated/.swagger-codegen/VERSION create mode 100644 ui/src/models/rollout/generated/api.ts create mode 100644 ui/src/models/rollout/generated/api_test.spec.ts create mode 100644 ui/src/models/rollout/generated/configuration.ts create mode 100644 ui/src/models/rollout/generated/custom.d.ts create mode 100644 ui/src/models/rollout/generated/git_push.sh create mode 100644 ui/src/models/rollout/generated/index.ts create mode 100644 ui/src/models/rollout/rollout.tsx create mode 100644 ui/tsconfig.json create mode 100644 ui/yarn.lock diff --git a/.codecov.yml b/.codecov.yml index 8865503bda..9b9f57ef04 100644 --- a/.codecov.yml +++ b/.codecov.yml @@ -8,5 +8,13 @@ coverage: default: threshold: 0.1 ignore: -- "pkg/apis/rollouts/v1alpha1" -- "test" + - "pkg/apis/rollouts/v1alpha1" + - "test" + - "**/*.pb.go" + - "**/*.pb.gw.go" + - "**/*generated.go" + - "**/*generated.deepcopy.go" + - "**/*_test.go" + - "pkg/apis/client/.*" + - "pkg/client/.*" + - "vendor/.*" diff --git a/.github/workflows/go.yml b/.github/workflows/go.yml index 7766ef6698..5f47443d1a 100644 --- a/.github/workflows/go.yml +++ b/.github/workflows/go.yml @@ -2,11 +2,11 @@ name: Go on: push: branches: - - 'master' - - 'release-*' + - "master" + - "release-*" pull_request: branches: - - 'master' + - "master" jobs: lint-go: name: Lint Go code @@ -23,58 +23,112 @@ jobs: name: Build runs-on: ubuntu-latest steps: + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: 1.16 + id: go - - name: Set up Go - uses: actions/setup-go@v2 - with: - go-version: 1.15 - id: go - - - name: Check out code into the Go module directory - uses: actions/checkout@v1 + - name: Check out code into the Go module directory + uses: actions/checkout@v1 - - name: Restore go build cache - uses: actions/cache@v2 - with: - path: ~/.cache/go-build - key: ${{ runner.os }}-go-build-v1-${{ github.run_id }} + - name: Restore go build cache + uses: actions/cache@v2 + with: + path: ~/.cache/go-build + key: ${{ runner.os }}-go-build-v1-${{ github.run_id }} - - name: Download all Go modules - run: | - go mod download + - name: Download all Go modules + run: | + go mod download - - name: Compile all packages - run: make controller plugin + - name: Compile all packages + run: make controller plugin - - name: Test - run: go test -failfast -covermode=count -coverprofile=coverage.out ./... + - name: Test + run: go test -failfast -covermode=count -coverprofile=coverage.out ./... - - name: Generate code coverage artifacts - uses: actions/upload-artifact@v2 - with: - name: code-coverage - path: coverage.out + - name: Generate code coverage artifacts + uses: actions/upload-artifact@v2 + with: + name: code-coverage + path: coverage.out - - name: Upload code coverage information to codecov.io - uses: codecov/codecov-action@v1 - with: - file: coverage.out + - name: Upload code coverage information to codecov.io + uses: codecov/codecov-action@v1 + with: + file: coverage.out codegen: name: Verify Codegen runs-on: ubuntu-latest + env: + GOPATH: /home/runner/go + PROTOC_ZIP: protoc-3.12.3-linux-x86_64.zip steps: - name: Checkout code uses: actions/checkout@v2 - name: Setup Golang uses: actions/setup-go@v1 with: - go-version: 1.15 - - name: Download & vendor dependencies + go-version: 1.16.2 + - uses: actions/cache@v2 + with: + path: /home/runner/.cache/go-build + key: GOCACHE-${{ hashFiles('**/go.mod') }} + - uses: actions/cache@v2 + with: + path: /home/runner/go/pkg/mod + key: GOMODCACHE-${{ hashFiles('**/go.mod') }} + - uses: actions/cache@v2 + with: + path: /home/runner/go/bin + key: go-bin-v1-${{ hashFiles('**/go.mod') }} + - uses: actions/cache@v2 + with: + path: protoc-3.12.3-linux-x86_64.zip + key: protoc-3.12.3-linux-x86_64.zip + - name: Install protoc + run: | + set -eux -o pipefail + curl -OL https://github.com/protocolbuffers/protobuf/releases/download/v3.12.3/$PROTOC_ZIP + sudo unzip -o $PROTOC_ZIP -d /usr/local bin/protoc + sudo unzip -o $PROTOC_ZIP -d /usr/local 'include/*' + sudo chmod +x /usr/local/bin/protoc + sudo find /usr/local/include -type f | xargs sudo chmod a+r + sudo find /usr/local/include -type d | xargs sudo chmod a+rx + ls /usr/local/include/google/protobuf/ + + - name: Add ~/go/bin to PATH + run: | + echo "/home/runner/go/bin" >> $GITHUB_PATH + - name: Add /usr/local/bin to PATH + run: | + echo "/usr/local/bin" >> $GITHUB_PATH + + - name: Create links + run: | + mkdir -p ~/go/src/github.com/argoproj + cp -a ../argo-rollouts ~/go/src/github.com/argoproj + + - name: Vendor and Download run: | - # We need to vendor go modules for codegen yet - go mod download go mod vendor -v + go mod download + + - name: Install UI code generator + run: | + wget https://repo1.maven.org/maven2/io/swagger/codegen/v3/swagger-codegen-cli/3.0.25/swagger-codegen-cli-3.0.25.jar -O swagger-codegen-cli.jar + echo "#!/usr/bin/java -jar" > swagger-codegen + cat swagger-codegen-cli.jar >> swagger-codegen + chmod +x swagger-codegen + sudo mv swagger-codegen /usr/local/bin/swagger-codegen + rm swagger-codegen-cli.jar + + - uses: actions/setup-java@v1 + with: + java-version: "9.0.4" + - name: Run codegen run: | make codegen diff --git a/.gitignore b/.gitignore index 89b7dfe79c..06bda989d7 100644 --- a/.gitignore +++ b/.gitignore @@ -12,3 +12,6 @@ site/ vendor/ # generated docs/generated +# static +server/static/* +!server/static/.gitkeep \ No newline at end of file diff --git a/.golangci.yml b/.golangci.yml index 5793fb1a21..1acbb8badd 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -1,5 +1,7 @@ run: deadline: 1m + skip-files: + - ".*\\.pb\\.go" skip-dirs: - pkg/client modules-download-mode: readonly diff --git a/Dockerfile b/Dockerfile index ec53d9fe23..6076824632 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,7 +3,7 @@ # Initial stage which pulls prepares build dependencies and CLI tooling we need for our final image # Also used as the image in CI jobs so needs all dependencies #################################################################################################### -FROM golang:1.15.8 as builder +FROM golang:1.16.1 as builder RUN apt-get update && apt-get install -y \ wget \ @@ -24,21 +24,57 @@ RUN cd ${GOPATH}/src/dummy && \ golangci-lint run #################################################################################################### -# Rollout Controller Build stage which performs the actual build of argo-rollouts binaries +# UI build stage #################################################################################################### -FROM golang:1.15.8 as argo-rollouts-build +FROM docker.io/library/node:12.18.4 as argo-rollouts-ui + +WORKDIR /src +ADD ["ui/package.json", "ui/yarn.lock", "./"] + +RUN yarn install + +ADD ["ui/", "."] + +ARG ARGO_VERSION=latest +ENV ARGO_VERSION=$ARGO_VERSION +RUN NODE_ENV='production' yarn build +#################################################################################################### +# Rollout Controller Build stage which performs the actual build of argo-rollouts binaries +#################################################################################################### +FROM golang:1.16.1 as argo-rollouts-build WORKDIR /go/src/github.com/argoproj/argo-rollouts + # Copy only go.mod and go.sum files. This way on subsequent docker builds if the # dependencies didn't change it won't re-download the dependencies for nothing. COPY go.mod go.sum ./ RUN go mod download + +# Copy UI files for plugin build +COPY --from=argo-rollouts-ui ./src/dist/app ./ui/dist + # Perform the build COPY . . + +# stop make from trying to re-build this without yarn installed +RUN touch ui/dist/node_modules.marker +RUN mkdir ui/dist/app +RUN touch ui/dist/app/index.html + ARG MAKE_TARGET="controller plugin-linux plugin-darwin" RUN make ${MAKE_TARGET} +#################################################################################################### +# Kubectl plugin image +#################################################################################################### +FROM scratch as kubectl-argo-rollouts + +COPY --from=argo-rollouts-build /go/src/github.com/argoproj/argo-rollouts/dist/kubectl-argo-rollouts-linux-amd64 /bin/kubectl-argo-rollouts + +WORKDIR /home/argo-rollouts + +ENTRYPOINT ["/bin/kubectl-argo-rollouts", "dashboard"] #################################################################################################### # Final image diff --git a/Makefile b/Makefile index f5769a2e0d..65e2deb4a6 100644 --- a/Makefile +++ b/Makefile @@ -18,6 +18,12 @@ E2E_INSTANCE_ID ?= argo-rollouts-e2e E2E_TEST_OPTIONS ?= E2E_PARALLEL ?= 1 +# go_install,path +define go_install + [ -e ./vendor ] || go mod vendor + go install -mod=vendor ./vendor/$(1) +endef + override LDFLAGS += \ -X ${PACKAGE}/utils/version.version=${VERSION} \ -X ${PACKAGE}/utils/version.buildDate=${BUILD_DATE} \ @@ -48,29 +54,117 @@ ifdef IMAGE_NAMESPACE IMAGE_PREFIX=${IMAGE_NAMESPACE}/ endif +# protoc,my.proto +define protoc + # protoc $(1) + [ -e vendor ] || go mod vendor + protoc \ + -I /usr/local/include \ + -I . \ + -I ./vendor \ + -I ${GOPATH}/src \ + -I ${GOPATH}/pkg/mod/github.com/gogo/protobuf@v1.3.1/gogoproto \ + -I ${GOPATH}/pkg/mod/github.com/grpc-ecosystem/grpc-gateway@v1.16.0/third_party/googleapis \ + --gogofast_out=plugins=grpc:${GOPATH}/src \ + --grpc-gateway_out=logtostderr=true:${GOPATH}/src \ + --swagger_out=logtostderr=true,fqn_for_swagger_name=true:. \ + $(1) +endef + +PROTO_BINARIES := $(GOPATH)/bin/protoc-gen-gogo $(GOPATH)/bin/protoc-gen-gogofast $(GOPATH)/bin/goimports $(GOPATH)/bin/protoc-gen-grpc-gateway $(GOPATH)/bin/protoc-gen-swagger +TYPES := $(shell find pkg/apis/rollouts/v1alpha1 -type f -name '*.go' -not -name openapi_generated.go -not -name '*generated*' -not -name '*test.go') + .PHONY: all all: controller image .PHONY: codegen -codegen: mocks +codegen: protogen mocks ./hack/update-codegen.sh ./hack/update-openapigen.sh PATH=${DIST_DIR}:$$PATH go run ./hack/gen-crd-spec/main.go +LEGACY_PATH=$(GOPATH)/src/github.com/argoproj/argo-rollouts + +install-codegen-tools: + sudo ./hack/install-codegen-go-tools.sh + +.PHONY: ensure-gopath +ensure-gopath: +ifneq ("$(PWD)","$(LEGACY_PATH)") + @echo "Due to legacy requirements for codegen, repository needs to be checked out within \$$GOPATH" + @echo "Location of this repo should be '$(LEGACY_PATH)' but is '$(PWD)'" + @exit 1 +endif + +UI_PROTOGEN_CMD=yarn --cwd ui run protogen +.PHONY: protogen +protogen: pkg/apis/rollouts/v1alpha1/generated.proto pkg/apiclient/rollout/rollout.swagger.json + rm -Rf vendor + go mod tidy + ${UI_PROTOGEN_CMD} + +$(GOPATH)/bin/controller-gen: + $(call go_install,sigs.k8s.io/controller-tools/cmd/controller-gen) + +$(GOPATH)/bin/go-to-protobuf: + $(call go_install,k8s.io/code-generator/cmd/go-to-protobuf) + +$(GOPATH)/bin/protoc-gen-gogo: + $(call go_install,github.com/gogo/protobuf/protoc-gen-gogo) + +$(GOPATH)/bin/protoc-gen-gogofast: + $(call go_install,github.com/gogo/protobuf/protoc-gen-gogofast) + +$(GOPATH)/bin/protoc-gen-grpc-gateway: + $(call go_install,github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway) + +$(GOPATH)/bin/protoc-gen-swagger: + $(call go_install,github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger) + +$(GOPATH)/bin/openapi-gen: + $(call go_install,k8s.io/kube-openapi/cmd/openapi-gen) + +$(GOPATH)/bin/swagger: + $(call go_install,github.com/go-swagger/go-swagger/cmd/swagger) + +$(GOPATH)/bin/goimports: + $(call go_install,golang.org/x/tools/cmd/goimports) + +APIMACHINERY_PKGS=k8s.io/apimachinery/pkg/util/intstr,+k8s.io/apimachinery/pkg/api/resource,+k8s.io/apimachinery/pkg/runtime/schema,+k8s.io/apimachinery/pkg/runtime,k8s.io/apimachinery/pkg/apis/meta/v1,k8s.io/api/core/v1,k8s.io/api/batch/v1 + +pkg/apis/rollouts/v1alpha1/generated.proto: $(GOPATH)/bin/go-to-protobuf $(PROTO_BINARIES) $(TYPES) + [ -e vendor ] || go mod vendor + ${GOPATH}/bin/go-to-protobuf \ + --go-header-file=./hack/custom-boilerplate.go.txt \ + --packages=github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1 \ + --apimachinery-packages=${APIMACHINERY_PKGS} \ + --proto-import $(CURDIR)/vendor + touch pkg/apis/rollouts/v1alpha1/generated.proto + +pkg/apiclient/rollout/rollout.swagger.json: $(PROTO_BINARIES) $(TYPES) pkg/apiclient/rollout/rollout.proto + $(call protoc,pkg/apiclient/rollout/rollout.proto) + .PHONY: controller controller: clean-debug CGO_ENABLED=0 go build -v -i -ldflags '${LDFLAGS}' -o ${DIST_DIR}/rollouts-controller ./cmd/rollouts-controller .PHONY: plugin -plugin: +plugin: ui/dist + cp -r ui/dist/app/* server/static CGO_ENABLED=0 go build -v -i -ldflags '${LDFLAGS}' -o ${DIST_DIR}/${PLUGIN_CLI_NAME} ./cmd/kubectl-argo-rollouts +ui/dist: + yarn --cwd ui install + yarn --cwd ui build + .PHONY: plugin-linux -plugin-linux: +plugin-linux: ui/dist + cp -r ui/dist/app server/static CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -v -i -ldflags '${LDFLAGS}' -o ${DIST_DIR}/${PLUGIN_CLI_NAME}-linux-amd64 ./cmd/kubectl-argo-rollouts .PHONY: plugin-darwin -plugin-darwin: +plugin-darwin: ui/dist + cp -r ui/dist/app server/static CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build -v -i -ldflags '${LDFLAGS}' -o ${DIST_DIR}/${PLUGIN_CLI_NAME}-darwin-amd64 ./cmd/kubectl-argo-rollouts .PHONY: plugin-docs @@ -161,4 +255,4 @@ release-plugins: ./hack/build-release-plugins.sh .PHONY: release -release: release-precheck precheckin image release-plugins +release: release-precheck precheckin image release-plugins \ No newline at end of file diff --git a/docs/dashboard.md b/docs/dashboard.md new file mode 100644 index 0000000000..f9ab5f4ff3 --- /dev/null +++ b/docs/dashboard.md @@ -0,0 +1,14 @@ +# UI Dashboard + +The Argo Rollouts Kubectl plugin can serve a local UI Dashboard to visualize your Rollouts. + +To start it, run `kubectl argo rollouts dashboard` in the namespace that contains your Rollouts. +Then visit `localhost:3200` to view the user interface. + +## List view + +![Rollouts List](dashboard/rollouts-list.png) + +## Individual Rollout view + +![Rollouts List](dashboard/rollouts-list.png) diff --git a/docs/dashboard/rollout-ui.png b/docs/dashboard/rollout-ui.png new file mode 100644 index 0000000000000000000000000000000000000000..8d26fde9e1ff1bc3796cd01bbbc2a11e03e7e8b4 GIT binary patch literal 373035 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

  • 51*G|obUU|P> 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≈ZA6C`J^`sgQq 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

    u<F|mrljb=XC6CUTBT1T&q`n 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 literal 0 HcmV?d00001 diff --git a/docs/dashboard/rollouts-list.png b/docs/dashboard/rollouts-list.png new file mode 100644 index 0000000000000000000000000000000000000000..ff64ae5d04f4acad2a65c423f2e1bc0d5b034957 GIT binary patch literal 269980 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

  • w9*~zTti856 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

    IO#Y-3E9RP)TvINov@NM*zBae+r*PU&qx@h zh7?WjEZs`_`>j&Rf#_Xrt!g50YG3(jxW}Mce-^ayb5YnXyMBFwj#!aebLd-+4! zbb(d@Te47PR4iwL{JacaHmHDf@J~2@xy;WeaVA;>o~=R;`A9cHNU(1{U+DYPmWg^p zg({+|pYm9~#`6ZyM05dEyuE<*akh5R@9VdKTWVr27*k5Q9-m%3aH1`IKRQo8p0k+< z70UTNb<-#_QljA=kPE8=qW0Hc6+YwLj{qG!jSvdO`u{UHK4~aYTJB7k7M0hQFMVUf)B#~;P@L{!T)nZs2bi7H zmXaV5)+X>cL0_r8AN#%AwCl$^sCKY4^?AT2h3Q}&rXH@v6QfhsC~$eTvPT;;n8(+J`tl5Gz?uhs;3wbP_H|U^<0S4gX$&vGiAkA zg#nj*P_0M6eP?{XZ#5u(4-PrjO`lSaH=-wgTf@_75sxsdqJd$lV&5zoc$ z1NSxPXc~8ehl?~O-;tyq6sjrISbzuKX|7JLJSF#R1z}ft0{27~x%eV&UaH%y$XE$% zaSMPNpXQruLbm=p-Ut9k>1!ZX3gQ0j=>ef@jp)5qQ4Y4T3UdfFx3ttd8O{OScHcL- zia*eTNb$*R*%Ub?G)BVVY=1PFRegZ0G`X;GsCbMCqJRignC*)b2fV1|b`|y2DKQzw zEp!b6p;I?xtamH>I1#%F$Yhrklzo1PD+*QN1}g|A%9<7Hjay&0vpp=6b&IlM%47Jf zPBIttmp;ozeJ)7dPFT z%F^h9^W+G_XFN-=4gVyLheH_Rx*6koETWG0-DwT1tb8h7&rAzc&`krmvpM>$gRfPt zAz?`%i;u~qq#84Os)P0X6hoHKQQILnHFI@gIMwG+*~M;E2=sbXCIy}@ z!*cg69T33Z`WyMm4Ski%?>=GR!T}4P>s3u>+T9;y`BcY1QkXIIPPf!EHizRF2EpBuMF0+yD( zpQOgx>Q_ICi$BMsKqJ2rpc=_dJgUW;X|n9T7P`KvvmsM=apr$?#5i;?Cqj8`!bwsY zXiP-)T|VS3KQUp<-ZOZn&zPO!E*8>#mnz?geR^$n)lCAd^8U@fB0leTBq?7xJPNPA zHu`>wUc>B*()nvTqct=OeW|KVhjT`$vjQS!nU3@U9XFN*q9V+gy0K}zU%7gnHK}$W zN2{L1iCE2eS>=35eKu`K1^+bsVwgMkX}?`k`>*!Yp2%19%-?LWMMk?19D1BTer_mg zsD{NXIoVqUGFMZ$0Qcdd!)85u%o$Q1v3~mpxFO@{k52wI!VSKG6pq@muD^u&~^_!kc9Y!dhT@r*__@3_)j2#%2}uwV}RN{hs0d zT5Y#)i7kARUeUttzR=|WxUhxF@_v;F38;MMFm{vBmq^`LD>FSO|GOGOv%nGryikvP zytPr{zI*m4Wp>qy-ea(@8{u3rrG$=|>gw#Do-2IP*59BL5!KI$qOs@h@p83Y3-)r+?bZT}K?+Rpy?~Q%jHS7nO+N(O+r;mhrS$jF8 zdR7KLQ^WTvIgIP43^(G#;fH_K!#49}sdxAw&paZ%4z}Z#xT4w`8J78N?Ks4QUw->_ z_{Yk5@-JCR3~8K+9hYbC9e3+WugA7u>x9NWX%AX) z`WN1aP0a!PocN13ZT*=MYbJHY2GCBt%-v+Fg#qk_+M;gj=V##zC1+>ldmWam#|AVN zHXE8wE5zdr0jKqz5ziW=!lD!6qbJHHK!Zi6R6fj^aAHVCja&N95t=ATu}dWa#vO*v`UI*&W&%)XCXXrS?Vti48a-CJz!+I)aU z7;>HY_8F>u%DY!*OL5y&y2qj~-d+_EC3gC2N^BSxoStW*;+STYnA{yOOvzSk>zR8v z62#8c&><%W%RE|e-(YKelbDQXSIv^Q*2>6=QP4Qz<9e| zd+V6K!$C$zA<;#1Qxw%e`hRNR2uS~H&ayfSK}$B$^P*z#k;6)}5ASeeBn#FeHX20*HVw+b)ptDSgiXSh|ksosqtZolPXwVJC zWp~%C@iHg_?+0>!bkZgFDulZt=iWrH!1J_L&Z<4VNIb6gz88N9B$RG0F#_w4`r8KA zT8V1M+ZFne;UhO;1i_j<{9Ef@;cPzljcmFXzIOBd%m8TkA>_Chv8|r#sw}d`ubjXm znFB@oO$zmW8W!=~lRpxs4v&r|F@t7hNzKQU-(!z<6Yi}`i=q>nL53feRw%8iv)%XA zfM^eGQ+_I0K4v+=wrbMX7`26eB5adlTtcrS;>JC}G9%l_7h0IWI(&&tSqTY6GY3s41aR)-O$@ctD!>PVTv=G!Co=H7} z69rUNCw&D~k0P`ATC3f%3oItCGvp)cDcRx0v#I8HZynDvA;b8edZiYulumQ0y`JqZ zWG=1jjH^*Seb;e+(U>`U+P9C&$#=Ao3NLpwBW_WE4=X=~XpYDn?td-Yc!0vV;HY~O zx={DijB&%Ieo7ls14+F~uzc;^5#P?56K9 z6k1dgyNp60s#$-7T8U?9@`zNgd$Bs6zttB1g1gdMEcZ3cd`UL~q(}uJrQvp}QLtn; z;d}zA)i^2LRz|w=S#jto;$3&N-S1CgZw53Qu&xVNG(cx}C6UQIxw}Ub)WJe}hhB=r zodv^G*ZY%t=>*>{XV0Xn;96((W!lWdoaVMkwiW7 z+fCl&XSFdx5p0Xnz+L#y*508Jz3+>$-?}{3R%xUg-f!}@u3d6 zm~}mH2WM)O_n}sa?;22XX)0?pxj}AKol!c>F5g6YPN?V1JN=G_W2K-_!OY&@6Sr;= zw^_^0oXNxY3QfA@cK&t6+C4Trf5(m4tgAoghjqaD*33`0e7lBMw`xV6j9_0+4A1W_ zEf+~=;ZDK@*Ng0fP4>A&cGrv{g*5A7S|u{D(Fo^>nzQ$ab(qPi0c51E>j0r72V*bV zyW0vFyyo=X6V;ztz`}4$<`>u&7vseb5O^y+d7ffWOrkaacxLwxQE1!bh@hN8x}ryaW>lZ_`re? zQBGSQmd)n}-n6L%u^l2qLjn{+f5cRXvEbK?0m%m{Vs+3y!pq}5stMY^&Uyl|`PKa~ z+q`pbNk{~>+Dv8~A>z3ozm@{uE_HeBmRWW@LAlixZS9aai7xuVeP^9BTOsz*=;~IX z17tU%@#s(PlF+hJNlI8pQB5rrmo|JWzW%{zK$-4cC68rYWG?}C6tK6QwPG;8K4kaSa?3>Oj$4PSK`v)wF z^Cw1*@GK9b)|V09!c?*=3!}yG#_Wx4ZKgSTU*SP-sCd(Iz#N*3^jSB+K;@{zSRY~K z++O^|733OB+kx?c+1-o`0f15&p{Z3}-(s9GOW)pRghkp{ja-#Z_W7I+=F}ekeMpTW zv-{tfhF^=~R)ML3saO!pv2)!HTK?;Ff}%oMKVnDYa=OD3c@~D_7u2S0mAig+Z&>|Q z+#qtSQ&CXXGHdjLa7ms{d+LA9PKl-XIhO@0dI#1W^9ce2-eNj$LR9pH0eCojZM_J{ z11JBC=G4$fuw)oizlm!JprR)etTB4)!%Ln^bX6ob$^OcUnl_T1RfIX2BQF;?p7FHj ziGwg^&+v8hMPW>uMXAn7zSJ-ury(1`!*?hG; zrrfj7SRh85)1V{#RJEbV?B7dg&a|i-$gqf|q-fo@~W}QQHuOUz6OZKeDbv z%e=D$%lnY^y)vhh0$b5&fl*(3((#O`L!N`AO`;NZ+walo-mza|Qe7>WxMqxYncPcN zux~5Wowxf#6N1optEc=C5Yj~bmPxT)>gz+GgwV{xQ4f4#z@ONvU*YtyZ*!@!qkEyAH zQHvzlmZRDbE{;fD;|2 zAE?9+9Xe0ggOUqKk-YvljiLhIhPB8uX^mOAzVE-r?#dl7nda8uzx#62b z0W0V_P~*PeSv|9Nb`l1)SovF4Zd)^7#Wb@wu(nydL8{l_lX+bBHlj>1^E00LL{@}- z!_oX7*Z2CR^&;A_R*N6s_PHK49QOdFIb2$GOXPElEl4 znL|pxyWa6n_|{ljQWjSOLQz#;OnOgMPEVJA6=?RY4{t;iJL%-^wMD{aTZ)QJ?B}R; zLLPF5#&TQsI2y$)hLYM-e$=H+$zw?Y@*gU5L9|?KchBW10&)ESBEn!KLg;gp<#x#Xg64S)DvCCo6}D>vNe(B(u)0pt!#+=5oAvN%#h^5BLc@|?TdJ9|LH!yP$vKX-o0zltHv z_WiglWdA{QDT~d@q{~{bPIXcIB#}#2C50bIbxNm2z2MHj&#h|ojdldD?q$!S#s0GF zNM)otLFsvn$O-zf7`h>pC<_rb%XmD|_ibBavH82?lE?BFA6<{5Hv$FNACoJ92sF$X z?8^tvWwId|WStKX#&tpq* z6c~|0z5H$Lf<`8K874+YU8Prh*~n8*J!+}4NDJ-5v=*nQ$_gm%b!|^%7w8+Zao^os z(*xBk0$+|1J2SQ`EKnc!{JrV=KJ~VTW^V2g-s817_ixliuJ08RMxeJwN(Kg^N_GQU zWTC;bVa?gOOrd?Tti&?+cV|xPA-nW4I~6n95dC|H0KtW9SiXA(#JA|o%$h5tT-*_02VTjCud$ zG-+Kd<`A-1Xj+wRl8K$=k*-jeKhS12x!`Z1p_#F!zk3kb`E#Kv$fr> z`fLz=3)-7bfgCLyKBqSyn6t3Y>=&+C6JVJF$$GB3*cz0S`G2JmMIj38%&1S^|IN6a zpx9@RANZB~)VNYJWkuwLy1IH&F2N`eg+l`jjG$9(BE4PFnG%x_ZYxqi7eEqkYrz+A_BGbY}1BvEUoG>WMC)Rh}ZRrtGb% z6)UQgeM3Xw{*GYWX@mOb&?H)+*loV#$;vW9tC6D2Q*VPOgkpqZdM>PLch0Fe$t@{6 zuPl`5=F*+`Y6i)@JVFhKa-8M708qn(C^}m0di8BAs)}6o5yj7x6OeY z32g-uE?9;w6>$0F2|j6P0xVx%?9)i5#%Ya5kz+BiL4$R^XvW?|!sVL0;LzW7-(2W6 zd~GzfjFwP%iCJk1P3#6am6~96HJ2ZG#&=y51RW*#?WgGEJLT0CAh)EUcYg|2t+}Kg z*7r~vm~i$XS68RZJ9E$TdWsbB-4ZTDtN8#sABUcSMNQ}#VFk*R$wnp!xvFf%#m&!F zPYzZVJ^&{b6#OVq`6LWaT*OHS=;#;U7FdCnrRK1qvGW78K2>Y^`_r?{bqC+*n%SeL z-I7GAWGCL6DGfpj1+hAErWv4FDv`eVzH;h^RqZC+U1gQO7{o+^trNR+6qXa-WNSA4 z+5$CoO}g!*{n9;)_bLMwuMFrUYoxbg@zlH14A5syyg}zi8km7>tOiuZ2bK>iH-*_C z&FV?OhTuk2x&|ZIsG^>PO|!qwpgPqf8U{TzHf?3{+}{u|4GLcD?zD(A3}+lycNoPd z4|^cU#;Elx-S@Xn*4uQu?rPJIM(|t{F?S?hO}z5Xo|%|)rZg`QH$DtvZfy8ZMoGs{ ze2(7R0n(jJWk*QU`4x|D3rw?>DiksPKqPooFfPc@=_AFDT-_xP6X*8fu+t@9#&YwN z`B5?RMq8qHBy^wQoghk9Kw~8<5*%{n-$9?W}$y%%F1ePEBmK z|7@dQY}h#&;Ulza);&UH^EQ~O?XjaxUa`WxZc1MpSe|8TL~*+=pX%{~(I9-S>qt-c zqVUgq$PGF^QK1yJ^6h?WcVCP8@LAz$ULR7nrj{`S{(+5@g`Jy!gS9F|6U08sb=wu1PQZ!_c3tgzUDEDJFtNs!L9Ef8_fC#EDz+p?v>+r} zbk{NnGWk=^a=NZ_yUr@nlP;eNtZNX*y3n7plrLOn+)^$fP195FD3rILFX=vM*i7Ik7Vjur$4ym$#&7 zb_8mWX|U42<6ceR!tLV?b1tjfs~p>Ea_+2{a$td^V_v$D>BG|d@?ek3 z;S**R%FOh9zZbwO5nR6KC#*>inDG>TcJlGfXR8D~Wwn^??|2?FPsX3MwD3=A{m`*ukmPSr2^NyK!! zN*xBHp2h<1Y6aJ@?<&lm za?2Mbz$~_Aymz{f#TYny2n|+gP~O`EcREwWOpG=Co&P6e_S)}6SbBs*O;sP3T4W2$ z1JBIUt8GVU7IUf_Ko|?ZqBP3AS`P?mq?L5k)c$YDu3rDa_Ev#0i7Bri%`eBn>H&kW z`yh|&ungcX+br&588NNHJoR$%q-ahCb*a#=30uFq8Gq<+Us16K(iHD=O4+g8>3~^F zc_h0pPs(v@kn+wl?NEF;b;S6su?G3>4gsG~J_>r5_#*fM5+CAHxLKB2UB$#luvADn zyG5$nzS9i_d4LqbQX?ZtQc2V{9JNP)BqmTUbx(8M+kUc1!+vuNX4{gwa+)^fx~6Pg zQ}#cpGFtrWgD`ymyIW$r?SQikr~_0*=#+tB={aMe*p2N7WKJ}ut}F*m67X!(k?kIf z7GpjWxK$%LErH+<_&GXN@uxl`G=dQrj5#vyjjizh@*$7uFvEC*>h!zrS8yP-d$#vN zM_wWL7p0@%ldztPBo2B72-#i&5e-9@%!6ncgCAJn1p*|QWDgWX?Hs{B{<2R*?rvCe(X=H&^wvL}t8hfX{x|)`JIj_ssZ$ax4e`tBMC;EF~bbI-bXycS%wAlUDQQwwkWvQ$Z|abn(3p zKQKkf2m(c}0+|S)j@@3dy#AN}_9CDMwSfNL55_)s%rQ3GV*!)Az9j7p)bEM0y`->8 z@ZzG&Y;mmrXD2{&3o(GWva!4~_5aNtaBsY{;XQy^4M%FwF+fR^Zx5A3dLb2ZAprTF z?4nOF#oWs}rV@03@*k1*Eli<8KOB-$;H1JYOH;555Izdsxtrtuzh%Xt{hj)L8ZC+n zHxVoUukQA_%UuVQG)WpCGXBs1fKj{Pi~*96cP;b@l>so7(Qv?=-|GY&RTqsVtQ9Yc zV~z;t#rp#m@kg$h(B_wS58bn>zfU+!(LEb0&YZ*S*~{#U#%wGcG%iU49{>V`JJ~Im z+TR3$j8_4KD;p-O1PTO}+r=HKpq)pHQ;FZLD1MGtwz)5{|4$`5YCS=(3kjtW~(RSS{25^ zT=DyR8}Nc#Py#;jW+T8p-0)*B^-Sj9IPXIqS@UCz^A!QD=&fr)x&NsRo_EmT7SL8X zBSlQGH5wM{kF1|z{0Yv}i?%eaRJZ@P?E)s6P71VD^=J{(l*O~oy^};1PA&}0SeuH; z(EpW!L!0kkz;@6Wj#_!fk6{|`-)94>8SA8eAM?Xfr2qzH;^bt*)zEep?aI+}$p@PM zO@A{g>XP(5?LN?0UClgZ)dPY+F7)&dWGmZdpyiKWuSic^K-oV)eSRA_$^aCjpSwN2 zfr&ToQ-Q{OB+4)~K5?WV=$_?mU7@(|hz23UIJH-pYmMW7;Q|!F#<`b7(f=|51p<`) zL73i05P~){(=yf96%e#8oZHz8Va&!l=>OqH7}s@`OCa(8l|O!p-r)vRamJJZqi8_l zATO?JTp)*EDbB?hU)6Cu#oPiOqZOW`rd2XAt-m=0y#sJ-S>D5X1!&yz6&@#H(BP}r z*Xb^na$->-of>02QcwVa5c`iW7c@IVckFQV)}93I7T}mY!nVEtscxPBEkEf6p1twf ze!+(^`V1uiwY!9(moV2vy!Zyt+G72y2Z7>&Kx=q}96vEU=DoN%?!`bOKq6}Y6*)$` z51k&+TBK)KJ*LgRk3r9Wp&h%$!o%V#J%J0rMcc zV~M%mw66a!V+_J?Er>BBcR=SndUP%cAM?xW02w>zD7GJFcSUcU(@nXH7?VKz`=4>t zyO363{(k~>Kz}`aNBt>A`#4hJ=YF1%mH!w`a=*Ad>A8eYvlp}_f9urjl03aGGq7(a zGcsP9F>~~c1=|_f(1fBr)2w9hQdI^VV0qA_7q3=P5Mw{Rdff@|foR32cP|N#=b^U~ z6437_EOY2l9&lw{#T?Dce{OCg&8>0CWDWrRLN4gi7lReSE{qKIQis&FrQVTV1l7aCio1;u(o#DT8Smk#CeU@n|4_XU3G&n{zzd{?k$ z0R8s=B^EEfZ>ow0!*wJMXLSRBtgc%R;g@Q1y8nZTrA~`xdCVCS2WH!m9CJ>tVBJMe z8iE+h6)o*=FCyWM`3HchU4&!0T(?y)*G&nnxNcrE^cr(U{sP}U=unK&^B30z92<{a z4AZQy0A6shf4J7E=V4=vegGYioOml;st?*MhVIyD)dvVchcJ3IdlPsuA?bbSKLSN* z@=Oz>B#j>nF;JnX{BE`&hF{Qz+oD^mv%il`M?eR(CV5@44D;s%djAG$ZlpSlA%^cK z2P|gr!c68S=5M0|n0b2kNd-L|-G@M8=w5L2B^V+6x0*7?j560S<}>g)@~(>Cx9Hh_t`>*xTd&nI0Qvuok|Xwca) z{=`f78z>Z@IV);+3H9z1ULcs+f<#t4#vhJ}zdz`>nJj(}qr2kGr0B-%{G=EO-U6@Q zVK+YNVXk+e(LVrlEm79T5b75<2DJSbtDY`n;>*>Bb3R-^i3~OZ7Qn1#>(X|JQ~S?2 zxRQTf!o5$L0J+F&B*ADONLnzUary%b*yam>tQ7QA%DkA~)?9PJE#M7jm}qkaYXoor zJu7*6jDgbgW&wrkSpPWGwN3TAm>a*JA>adxL|4h37mvIDb&udSx@V^8_^-{( z(c(3FC(>^)hY4gGFT68QD8=;B4?=+Lh?Gbh)6>Pjpyxk$z&?GPA6??MEm;zFspnh& zczC^vZysluCp|N&N=gJ1g7Io!nF4_aEL=L5zxd3pS$Y#Fe(KzVj%Q+!fTm0UM z(X~KUzyrR)?I|u!A^y#c=sAte6G|k&L0@Qp^=df_bA?_C{0pS*b?#tNZ(0uk95ZSh ztS?n4yUv8Rjna`)0jzW~U{gV~C0&XL>BRrByZ0f1Y#4w~zz7fmwZVud*Dx8`hjZt2 zxyE|sY6v=vxF0=tY1VlD(Yubu;ylc1F%c}ltOY@2k}(D^PD_Gb(ErEYdqy?Ae(RzN zqM}O?P?6q2x`2RmM1cST5}I_ScO*0kO%z3t-XdM3hu#Sgg3`N`5Fr$$6M6}~oL?5Y z_WIwu@3`ZPaX#EJ?*1TtA>?hdJ#)@y%J*A!K4!WDJdd~i)6f1xplE&zlpVha&71#v zIImZLjXF#!X#dA(;Y}ch-_T?bd`WWwFgeUn|9@;d}PBn z+I4_N7|&N`heWa5F#Vj#7MIJ@F`J|uV1Q9J@&RXRkLPl3Xg+qQiu=bCctZf05+jLx z2v(=@1tpOtVXVzf4{o*JP*6ZU`488hAGYbFwR9av4XpT)=QD~+|EyS|*e0HFZ!YO02qN<5{w65ng9hjrkTDO1yX z`p=+yrWru#GIP#d;0ONazthcfBa7f`+qMnx{#G)V3*`);@5gq(8J77Rdnl``#A@Z) zrb{ztvEFz{v>#15JCk=`yv|C&t8mgd`qK?Y^2+%D`^RpSasTMTH&pGQm}6Nf=Db5a zRU`SbWOdnFJ_)g}_RG*l{yh&W&^^ zUsrvC;fDwdO$#yR!vY8QKY-%}z7pr&jA)PN#@}b3o+AplvY@9GZzsb1z3E$-ERa0; zA^s1b6*&*wke7NdX&>-rT)3ESAPE=cJUQ?OrM{fr$i90Gre(XxEJduqdV`**BbZd^ zv@(bFi=foYun$gOqW>5nx$i`E))RMggu!q5gNSZi)@I_DQSO{Lu>2hK&e9*)Z;9(a z_$E^yaO#`M$&{(T_X{QLccLN7^3Q(d1GZ}G?|d8Jq6t`_*xL$|A@64bp5|jQP33RSF&&Z^L?!sUj3vor*|r! z+iXN9UT2mmYmEZ``6A%Y7X`c|q|&s~Tv=~O5aJPQ)s8>=X(1e}%lyFoE`r1HKK4@4 z@B{EasjWt0J;I0A8__hrQ>^xMTqJ+o72rA0Tn6wi%?EgK!1o~}nB1yj|D?7w39#8s zPkyy>BOolW2YLOp3uDdt$3v8QIZOC3nNeXsAfo@X*#9q_tXEW|L53NZt(PCMtqCeI zmP_-o3Y7pG7pImber~+Xs*8Wx6+dTOW;^evtkL(u%rWuy;@>axt<=lPe_dffJ@hB^ z$fDMbVLz?H0W8npU`+n%!e8eZY7AVNfq-Zl^qV>ucnurm7`X?4#C^-_Ly%ui0le|_ z@+^zr@A`vTz*F{24vyw7oq06uI$vL0YbDPidyQk?!-S&_0U_(JS2`Z}juxB$APuMo zbR?R_5%`XO{rT5%WJbGmDseN-54d#i3SMiXZh*m<|2a7EPDUH$|49WvLx1_u|?IslTv4i?KO^$hRAoubFts*jE{o4 z+o|O9@W%oDKyRh42K@%oUyolXPzO1lqO3N%$1xVz?$FS|P3(Ys>&{17O!VF>7-tH< zQp$rkZeLD6{;k`^F8Z`T9QMHqv%%P65ARR7!ocI8@Q%?!Z;SCN=`xERUErCtmnAuA zEl#})b9`iy=7^o?RgGOlQ{9h*qB~W?Lb9~6(`+Z*gEP~d>K#YyOBOrMr!>BecPsR3 z#oKNH$vV&s=6ck6W87YQaghb*?{{&z{Iw355z3%OqgD;lY!bte&x1)d9B|ODql)kP zQmNEE%julQ5;6X)!^op|0cKP%9>sE1hbW)H5$(!taPMJl75pb+bZs^!k9rf^*;M8; zC-I3#vKPm)Hxo$kSF6ZXcxTl6l)S=flYnugl$4b3W#e$$2{T|0-yV5 zuTd4n&gb~#G5pLvESEe?CO|QXs$Z!+=^o609Bd{&XN!;+KE1LLMe^b19~{by<2jlb zqr_PhHR8W2j4Py+LNSaz3%Lo3w4{wtP73H68`aWuJoS1;sr;n<$mLfU6)@NJK1y6V{19HP9CgzQVaeP$q2o)x_Vcv+Q~8=rYCI7 zxW+2!u@e7=_~@hx2u7Q5k~ zqDv8UR3di^WAB3Rb%9F#3&+@MWy7-{_&uAs6&2?M=-OJB8R*v{GNa%K$aogrpJJUC z6eUvu`3xf!`_uj%C#<$sJO-kC%*7u0oY>uzSlWxcF^}4Wsuxqy0}45eSnPy>;wj!yS^_miki8o3685yVzA1Zv}t2Sa~Q){CJzdC}0 zT-r70Ss7h!ue)7YSGuAR_h5fv-4kuID!z)VdTT9@lYVR6-l3I1#_f*0N~K-wQDC6H zTE9xfrBe{;bwpe42O|~s7lHvdC9%^H4$;i$Cg*UcSj*k@i+tB5)}H!SDNOVxf24*} zO+{3HFNFPL;>y87n}X1Ck8_Wul@EZg;;?O#g&w{?ReWZg$;udi)m=}G zzUs~2Igl9+gT+S{?tjA>4Zv zEijWb2}_z^w{8_?#z!B%@5*y9(JYR+pCdb|-+5EO;U>~;MHk`OZa8PVoEQn!kCE6^ ziP*7{rYfEQY>qF7_t4$qiEJVEkoJ7!S|sZeTy_F^}Z;OF~mDb!m=)9o-4{KB1 zu+Z?eQ=4*^di4wRqloOI%DE3dQvMP8bKZT)>{P>jM=z2QU)w_c2Ai%O!#X?p+QN{% zMYTF!H^ zGqbz-gy~1%P-gRm{i9i>?#JrJF2^)`X}1eSN56m3H>U1KrkJj5xR1pfU&{1N(?few zodzjiV`J9QD>?NQyOZ$&w@-g~T{(%96Q^(9$>T+ut zb;k3W6&RMj2*TbiERw`&K3UQe5WwfhQAtCWCLXoTr0FDCVj0?qbuhkopR%&k=L^SR zL;)*eyM2RlpbBFl?!)Uk!_sHI4aqQwo59boii+VA_7Z$h_gsh4C3HIBQRZ76!7+Jd zkZESwUaC%2dcO&ah$4%!-p&TZ@5paWsOwBb&R>+;nu!@#4cWjwszWw=t zs=8;th`{Aw+l&vDhC3ges&^c7557DMyAqwa>Jna|c-YI)0uOTPV>!pXFBA_42Q<3IvMyQ9)sII*xF1bG;Q^s14*8+`KKUc- zMTOk$@WM9BlaNPqwE*9X-vQRd%M53b5gNGnAYn`1JWs#jwSIPW!lSlBTLJh$(4c5Ixh zYzoM*Ez_qjKYR+mDG+;iwl~?ddT`PH_~5(oI;-DvE9}0FfrK+a%Hx<>prabBR?iI9jhPm7(Mz zV-)8;e&6uLB+lDFCH^k|+f*;3IRPWKrZzQA(mS@TP~%VPy+g{W_@$xP7k#pPr@V&D z#P1_SdIz`Cy+h4S6Siwr7RKxgk~TYUJsZ05S(t_WLUAD24~0yqdtyp%D?V zt;GA$;f}?yi|+Q+hf64iCF$=VUUZv8&J0`IQsPCpgeYKZ5Tkp^_;I6sw_(pRUyM_E z@4G9vBg>c2QP;&PTMAlMQ2;|Kv;M+4?FYiy+~-545dum+UZfBE0wLkj_~40 zURIO^4&hR#0$LH<-{K`LPVHzgm)+BxI5;5dYeMp)B==1EgL9zJ`J{J32gi)v$3|G_ z>Gx`j1y->n(l&|yEhj1}>9XbTN>0&09G283Y3*jVU=2Wvu*v=2y{}QO$R%s1QQt{5 zSm#?YQ>&Z8bH|JTboUK%C^BDn+rHa6cdd{($B(_-e@kXmE1vl1*+Y3aBgk)g>WJU> zXQVmXVVx$V`oMiy1K?hj>0D?^vlOL%i)ta^TxBIWy{#G=J_9-3P)CFk6`5~LW{+SUE6vKRBDw%W+Z z`pH9Huf?XG&BZlu%gJBekcys1ow;4;S!pt{_)`<_$F2T|o;xi%?|7WF-bHr|Y;2Zo zuH$h^5y2ZySV9!XYvQjBkL%$~lbr-zL{%$K9D2cOmH1lQ%Map`q1<{>%6>G%+T$6X zl4C|TBc8!gf%$q1GPVX?8}Dzp2A#785FVyyqIHyv8%H1Jl}3)HpZ`t(od=*DOA=P# z#5U`>PYe(f&vckfqoac2K0`{Uh8R;~vN$i!2;bSedLBTSv}3-ZsC{FmhYxGJO3mBC zh@G^8Q&XJlT2OEMmhpo}vKF6IKzLDfzVRbPGB4eeBkMdVS%=WlF0`Hzi|p}EP-b>^ zLQoAyW_a38)k2`AX$*rJ{+*0;RyvKoj>ay2nFkBZtb(@xoRH2$sFK*v8sc#>hWi1)d+H+3vU3f$+=bg z%;VEB)3>=wg6 zUfaXBTN$9S-|ZP0IiaZMoR}&GSr-*I$&?s-dAsrh9m~hnhM6|ZK?$ymeSNZe4zbp) z{ZsPDa6a3JFD5dPr;7K|$VLFqhGx7I#Z*QCN5NV3 zA5asnD+LT|@-aEtmh}_i;}TRaaxjwb%{P49tD~HB4ZV;-*)TdMDi5!ILj*Jovz89~ zKTlr(*#EZ2ug>3LjfC<@M!NSQ5nn-yc=u5ChLnxRzTzko&FXOjsq!CpNOdA^8WuYE z?Yr+YSFaRZC0@QvdI&>cAyvU^nhE! zw$g9*P3zstUSh*EJurH4DBUe;p;qFyvlz5SqWJ2-aPO-2&AQj3Zx~XlEd&zTlV#~$jS&Xuc+u5d)H8!^L($c2lD94 z*36OBJSf;qAxnR{d>o)wuv{d6Vy~UgGTRwTA)S~zp~q=~Yc$Y+HV=49RBExN564q- zs&{sZENQbWrj^;PTr{s^P}pv) zK{_nuAlv7-sjt;1;AnqlShP@qvu9QE<#w+=|&j6gr7=mFDKJbhxAF?0VG8--NEp}UwM6YQ9d^{fXo7sln ztQs;OPovi=(V%pU$*Zb_P$)N_vD1pM!ghORZ-_ZZHWP7sGhseio9&ztdnJ0@h7zBt$Y_WEj@X}h7Ytk`YZ z;bI=vi&Ey@X#hU9y3*eUGD7n(ERQLVnqUTgWST$p%6siCkHNsEgh?y&o;sO5t?izZ)dB7USY%%vi z{2Ckv+dxX>X@cmL^R#3Sb+Uct_L#p{Sg#QrCEB*$ee-t`!yCq}&s^q;2U@PGmP2)n z^(+%K#1psy7*!BcSEWf6<(n1p?k zz|1Ui2ia}DasZ&Hcgun67vlSLCL@i#f18vQZy==D->yb7+uMC6&6DL9XW9+-V2jWN z2g6VeWA_(o@vq#0p7qB5R$FOYe&*A*h^1r_M%e^r7~X*GFd|bq{fKmPEpsb5DO3X! zI5hQ+!V)))AB$Ebqf?7nN;TvLa1NmzPsgoRW6qh*iH~9UuzafMzC+0g+${7>M|pKu zNkUSX&armcf-kr2kT?PmgvUQ7=;^RJKP;bI)uWFO7bv_pSH1-)JcSX{P-kEzy82c) z0cE2rz#Uc&cojUC$v^pmCI?>laPR2+aa?7MI0JKtGyi!M-)$0vhzAWtxD z-bum8BGNq9xfAXTlN2X9NUDTiWZMR@QfLf`zoe7mj@Qvc5uv61)RywIRGS=#V;(Dg%RIhCs(pEU8PEy1HT$FE*9%{YnnE?q6>j)PMbcbI?Mep_ zGk8A8Cw4@$`MW&xrV*o&!Iv<1bORqgmMg-Z*&zGmbJCKD! zl!__d?nxDj4F)xR&**kv(j$Hyfm@F@)!ITcO_ASq=rJ3R-LDkePz>AHs+dlEsw2Iu z%n%kJaFDFL%kxOmx*<&7S&uowXmp8jq+u=7B(^Wj`EHoKMZ-JQwA1(J!!eq}MbG3K zyuWTtOPkL#ov<*AT$X}83XY&71$=BkWp~M5{awu84s`QHojNotH7kWi;!aUiJE4w* z0U!+7Cp~q6EkfIQ2Yz+i2Lvye_iLOiD_ApIq6f0>W4bi2QLj>@v~$NywK); z=TkwzX2EpN1qpMBc1b{66_sz_{J?k~t<^6Fz-F8CwEM=1OgNZD zo(mOU`mrC7U;eFG$?WJ}#9q6X!unYm#A|7i0_ab;q37ZHt<6J~T}G%r8V3M)^Sq-1 zWZ|yO%v8XXja@##%`M`yUCgmOJkb(zop73t+gYUMuG3O$pa7pTco)U;M&s3(0gsD__Psg{x+6ne?NUTmu=*YP%@dA&=a18uLV({!F$@7^J}yW1`YV^o86Bg7%juj8 zUjd=>qObj2l8{lgw3q5FujN*iqM$iwYT%I3Ac7v`GgH&ow8fgrh&XO~epb&IU<6cR z%o6oX-h3$D3=NI-8hif6HHA*uPK$1b&sBw=9oT zkHapgA_%gbi!vl##j*ZSqP)kAH!24LtQH$oL;NY6@z$?|n=x<`OCoIrd zJ!yjNm`%^%?5HORCpSogZp$EWWgoZg5+qN_sAZf&1dC%#-6?o~SDbqB-FO0cnfVNW zYRblSh;V^XW+oBgwzJ#6cKy3PRL}1jX97ur--RY75dxZ-pX=Ax)gTl4=$@5n>)tr( z^4oX1(m^140ROD8(Zxump@hYx1i#)PcT-7|%(9hk^Grf;+iu&&N#VrNxz7v?j6b>G zPk%4M)A{b2{inJ*lS@U8E8jgs9Dc0c`PGJSP2skj9se5O@4Rm|K|w9$SakvG1Q^v3 z)G^O-j?ZF2;=X>3oJ@k`BB^Uaptd&>(z1Vi(wNSw$SC6cQ|4RDh>K_<0X-?}p9Sfh zWf1R?6!`qCwOevAzo~Y7ZUDyxIKY)ytr?u3YN(yX?v;bFVV4P1&|}W}qEQc{s#R&O zy6eecXRUSv0}s+X(hZlggUYKzWHjXrTXSTR0Oc5M*fjySBIfGqyYp2s>N37-Ipbxo zjx|Rr4g+0I%sIntZeC5pFzCiJXADX-d0w%V)V^99?~d{yIl zO&8tk7#?az+{Gmy0U`421SX?+>mEur#of1HS5Cj$rQBt#+jbhDUMWDyU})!0YUSQX zq}eUc1FGoI^tAmmtc@1S|6rGn`g?wzpsdZzt9@hkNt~?>Kxt*0QP9ECs(5l%(Z&== zR22LHA>KpV=NVtF1Ib9e4dgI($$Yy$VS-aA(F>n+)$)ffCzFwRV_sDvQI;2@0piI} zJ&l{P^gEH-yjo)qS~NcDsuq`qvuR-1dgPQqDWkjm{qFr*X{2eLyZ$HE-6-jj{Gt50 zlh*@3BAZObWTo}1R%Muc>x?+Xs%^}ckycwyh~s@*ak>P={(Dtg)ziZwF})g-OB17Z ztGQPE&IU?~G7}T-ai&|Q`7{0VI-52nD*)Bl@y|ol%xpEP3*tus#?W$j_|B@Z0o+T- zc0%l6RD5aftj73q4xzllU6P|`l)p(9a)g@b^ypdkuDV~W)x5@{HK?xo_7YVHL!mb3 z>!L(x!^Wbn99p!m(8WY_g1+r0VI(1sApJJ^aj-&(a_3 zOHCXaR`{@Isvlbgg&vya(bWf^JudrC(2&j@0>1PIuwYxl@vj3kD~hy zqS57H<3Z=<7p9ro6%6`*KKup`25OJkf+Je*MD|(>O=x=&UY0Y4Wa&&W)^7r>GdIZz z;_^3iX1g~3uLkSqWT6QXkA@4dHgxE^!?$3B**={rA-qtz&a~bum?7-j*Zc{2f;B|hJ|z!;$-eDm7B0??GcyW-3h2PG0*Rd3VUtO zV&>HQ^WebU_sBoVqjQwcdj`IR%Zt*AIp&9){+iyzbcU7Lw)s_?gNJqlTkNYkL#|1( zNskLoA+XnFZWHh%g+)!Uq4CeXsP+R#?<{lKHZt{kcH7(CX}q!;egg$xPZ_9ZMPBT@ zrCNn0#;MRA5)^Tu@%)DZ>@Hobh9BhUX$$Z7t|xW|@9V{^(`g{n#4Lc>O>^(Yeli?~3qZh2A0eW;;HPZC3mJ*n{T@1=wG&u6|O7 zID*SdjC^!8^E8WI4*`B0PLKaCy{Q5JX@R6&GD{s0_5c~{v~!eT>yuig)YPip0%(Gn zGDN>=YM=(noM#}4O4h0Tyg+Uz8R0hO-RCF|SBKIceC3#ysvWOAW|bXbnMRFS70^OF zuOX&88~tzE>W-NMQ9W6t5kCdvzB*`jpS&*uvaj*+tOLZ1z=U9*LkSe1c$omDGSHBc z(BJK)79((_t)UDkZm~g95>!W9)KL~OAHwDA$CTFV5gHAJsVvtcQ_L#{0q2M62>I+{ z_#NwHbxxn_-VHEq?lgSsGfdlId$@63*fBv(N=`!hGFlhl!NI|s`$;iF3)UNo)F($G zIP{{B^=ffzQSo0mo@=<_P3VuGQIs>)vQ*SqDS+0jb7OEKT7UA`!oj~5OUzBLWAUSg ztF^2OS`b~d%~E-T^!`cPT3^kk2C!Y**G2%vE%d0W``5w#vp^jzBj=8G zvG$Ry_wIQ{h0;qek2JW`cPG5pa9ZTIVuOCjJ-o3*{E$3uLNerL-oRry?WZ>$E8HOA zxx)QrK+|9W$#w&D`GSw6>x2u;D7wxP5?fFpxllmPhC~6W;(~)ntud#APsL)fgjf)547!&2HCs7q+*pb3o z$LobGzu5`v(rn)M{kdvFPZAbKE4T&>A96oM*qN1cdD2T z1YJu47y<^04hv2K-rTxGc=MBwIvmLv**Tm1&ffeH>+_x0`L$Q$>i4^wQ5MsyceI?~ z&_%j3J8k;nCEU>*|Gt%0tW5F4tg$kOmpEZ>1_^orPyA#isxe3X$iap$&z>z64%POx z3o;!yh6Q)>%6697Z_I_j^w>Cb$+J`I+ni<8-*g5m*NabZ;_ z5JhMMQg7`E5FT_a@IVZUWfj@c$O6Q zq@T@E+Y7fSt}x!?%aE##om!T<0x;}0)A)N zpWi2b@gnLON=>o5^f-KqUs;�mu(pSDdR?S^vN<%3;h)t{CfIQCpt+*U6;sj+zTl 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 E16`bds{jB1 literal 0 HcmV?d00001 diff --git a/go.mod b/go.mod index bb6d5389b3..ce5d5b61e0 100644 --- a/go.mod +++ b/go.mod @@ -1,16 +1,20 @@ module github.com/argoproj/argo-rollouts -go 1.15 +go 1.16 require ( github.com/antonmedv/expr v1.8.9 + github.com/argoproj/pkg v0.7.0 github.com/aws/aws-sdk-go-v2/config v1.0.0 github.com/aws/aws-sdk-go-v2/service/elasticloadbalancingv2 v1.0.0 github.com/docker/spdystream v0.0.0-20181023171402-6480d4af844c // indirect github.com/evanphx/json-patch/v5 v5.2.0 github.com/ghodss/yaml v1.0.1-0.20190212211648-25d852aebe32 github.com/go-openapi/spec v0.19.3 + github.com/gogo/protobuf v1.3.1 + github.com/golang/protobuf v1.4.3 github.com/gregjones/httpcache v0.0.0-20190611155906-901d90724c79 // indirect + github.com/grpc-ecosystem/grpc-gateway v1.16.0 github.com/hashicorp/golang-lru v0.5.4 // indirect github.com/jstemmer/go-junit-report v0.9.1 github.com/juju/ansiterm v0.0.0-20180109212912-720a0952cc2a @@ -21,6 +25,7 @@ require ( github.com/prometheus/common v0.18.0 github.com/servicemeshinterface/smi-sdk-go v0.4.1 github.com/sirupsen/logrus v1.7.0 + github.com/soheilhy/cmux v0.1.4 github.com/spaceapegames/go-wavefront v1.8.1 github.com/spf13/cobra v1.1.1 github.com/stretchr/testify v1.7.0 @@ -28,6 +33,10 @@ require ( github.com/undefinedlabs/go-mpatch v1.0.6 github.com/valyala/fasttemplate v1.2.1 github.com/vektra/mockery/v2 v2.6.0 + golang.org/x/tools v0.1.0 + google.golang.org/genproto v0.0.0-20201110150050-8816d57aaa9a + google.golang.org/grpc v1.33.1 + google.golang.org/grpc/examples v0.0.0-20210331235824-f6bb3972ed15 // indirect gopkg.in/yaml.v2 v2.3.0 gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 // indirect k8s.io/api v0.20.4 @@ -47,6 +56,7 @@ require ( ) replace ( + github.com/grpc-ecosystem/grpc-gateway => github.com/grpc-ecosystem/grpc-gateway v1.16.0 k8s.io/api => k8s.io/api v0.20.4 k8s.io/apiextensions-apiserver => k8s.io/apiextensions-apiserver v0.20.4 k8s.io/apimachinery => k8s.io/apimachinery v0.21.0-alpha.0 diff --git a/go.sum b/go.sum index bbb7a5203e..bab8aa3022 100644 --- a/go.sum +++ b/go.sum @@ -3,7 +3,6 @@ bazil.org/fuse v0.0.0-20180421153158-65cc252bf669/go.mod h1:Xbm+BRKSBEpa4q4hTSxo bitbucket.org/bertimus9/systemstat v0.0.0-20180207000608-0eeff89b0690/go.mod h1:Ulb78X89vxKYgdL24HMTiXYHlyHEvruOj1ZPlqeNEZM= cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= -cloud.google.com/go v0.38.0 h1:ROfEUZz+Gh5pa62DJWXSaonyu3StP6EA6lPEXPI6mCo= cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU= cloud.google.com/go v0.39.0/go.mod h1:rVLT6fkc8chs9sfPtFc1SBH6em7n+ZoXaG+87tDISts= cloud.google.com/go v0.44.1/go.mod h1:iSa0KzasP4Uvy3f1mN/7PiObzGgflwredwwASm/v6AU= @@ -60,33 +59,25 @@ github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78 h1:w+iIsaOQNcT7O github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78/go.mod h1:LmzpDX56iTiv29bbRTIsUNlaFfuhWRQBWjQdVyAevI8= github.com/Azure/go-autorest v14.2.0+incompatible h1:V5VMDjClD3GiElqLWO7mz2MxNAK/vTfRHdAubSIPRgs= github.com/Azure/go-autorest v14.2.0+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24= -github.com/Azure/go-autorest/autorest v0.9.0 h1:MRvx8gncNaXJqOoLmhNjUAKh33JJF8LyxPhomEtOsjs= github.com/Azure/go-autorest/autorest v0.9.0/go.mod h1:xyHB1BMZT0cuDHU7I0+g046+BFDTQ8rEZB0s4Yfa6bI= -github.com/Azure/go-autorest/autorest v0.9.3 h1:OZEIaBbMdUE/Js+BQKlpO81XlISgipr6yDJ+PSwsgi4= github.com/Azure/go-autorest/autorest v0.9.3/go.mod h1:GsRuLYvwzLjjjRoWEIyMUaYq8GNUx2nRB378IPt/1p0= 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/adal v0.5.0 h1:q2gDruN08/guU9vAjuPWff0+QIrpH6ediguzdAzXAUU= github.com/Azure/go-autorest/autorest/adal v0.5.0/go.mod h1:8Z9fGy2MpX0PvDjB1pEgQTmVqjGhiHBW7RJJEciWzS0= github.com/Azure/go-autorest/autorest/adal v0.8.0/go.mod h1:Z6vX6WXXuyieHAXwMj0S6HY6e6wcHn37qQMBQlvY3lc= github.com/Azure/go-autorest/autorest/adal v0.8.1/go.mod h1:ZjhuQClTqx435SRJ2iMlOxPYt3d2C/T/7TiQCVZSn3Q= -github.com/Azure/go-autorest/autorest/adal v0.8.3 h1:O1AGG9Xig71FxdX9HO5pGNyZ7TbSyHaVg+5eJO/jSGw= github.com/Azure/go-autorest/autorest/adal v0.8.3/go.mod h1:ZjhuQClTqx435SRJ2iMlOxPYt3d2C/T/7TiQCVZSn3Q= 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.2/go.mod h1:90gmfKdlmKgfjUpnCEpOJzsUEjrWDSLwHIG73tSXddM= github.com/Azure/go-autorest/autorest/azure/cli v0.3.1/go.mod h1:ZG5p860J94/0kI9mNJVoIoLgXcirM2gF5i2kWloofxw= -github.com/Azure/go-autorest/autorest/date v0.1.0 h1:YGrhWfrgtFs84+h0o46rJrlmsZtyZRg470CqAXTZaGM= github.com/Azure/go-autorest/autorest/date v0.1.0/go.mod h1:plvfp3oPSKwf2DNjlBjWF/7vwR+cUD/ELuzDCXwHUVA= -github.com/Azure/go-autorest/autorest/date v0.2.0 h1:yW+Zlqf26583pE43KhfnhFcdmSWlm5Ew6bxipnr/tbM= github.com/Azure/go-autorest/autorest/date v0.2.0/go.mod h1:vcORJHLJEh643/Ioh9+vPmf1Ij9AEBM5FuBIXLmIy0g= github.com/Azure/go-autorest/autorest/date v0.3.0 h1:7gUk1U5M/CQbp9WoqinNzJar+8KY+LPI6wiWrP/myHw= github.com/Azure/go-autorest/autorest/date v0.3.0/go.mod h1:BI0uouVdmngYNUzGWeSYnokU+TrmwEsOqdt8Y6sso74= github.com/Azure/go-autorest/autorest/mocks v0.1.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= -github.com/Azure/go-autorest/autorest/mocks v0.2.0 h1:Ww5g4zThfD/6cLb4z6xxgeyDa7QDkizMkJKe0ysZXp0= github.com/Azure/go-autorest/autorest/mocks v0.2.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= -github.com/Azure/go-autorest/autorest/mocks v0.3.0 h1:qJumjCaCudz+OcqE9/XtEPfvtOjOmKaui4EOpFI6zZc= 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= @@ -95,15 +86,12 @@ github.com/Azure/go-autorest/autorest/to v0.2.0/go.mod h1:GunWKJp1AEqgMaGLV+iocm github.com/Azure/go-autorest/autorest/to v0.3.0/go.mod h1:MgwOyqaIuKdG4TL/2ywSsIWKAfJfgHDo8ObuUk3t5sA= github.com/Azure/go-autorest/autorest/validation v0.1.0/go.mod h1:Ha3z/SqBeaalWQvokg3NZAlQTalVMtOIAs1aGK7G6u8= github.com/Azure/go-autorest/autorest/validation v0.2.0/go.mod h1:3EEqHnBxQGHXRYq3HT1WyXAvT7LLY3tl70hw6tQIbjI= -github.com/Azure/go-autorest/logger v0.1.0 h1:ruG4BSDXONFRrZZJ2GUXDiUyVpayPmb1GnWeHDdaNKY= github.com/Azure/go-autorest/logger v0.1.0/go.mod h1:oExouG+K6PryycPJfVSxi/koC6LSNgds39diKLz7Vrc= github.com/Azure/go-autorest/logger v0.2.0 h1:e4RVHVZKC5p6UANLJHkM4OfR1UKZPj8Wt8Pcx+3oqrE= github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8= -github.com/Azure/go-autorest/tracing v0.5.0 h1:TRn4WjSnkcSy5AEG3pnbtFSwNtwzjr4VYyQflFE619k= 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/DATA-DOG/go-sqlmock v1.3.3/go.mod h1:f/Ixk793poVmq4qj/V1dPUg2JEAKC73Q5eFN3EC/SaM= @@ -142,15 +130,14 @@ github.com/ajstarks/svgo v0.0.0-20180226025133-644b8db467af/go.mod h1:K08gAheRH3 github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7/go.mod h1:6zEj6s6u/ghQa61ZWa/C2Aw3RkjiTBOix7dkqa1VLIs= github.com/alecthomas/kingpin v2.2.6+incompatible/go.mod h1:59OFYbFVLKQKq+mqrL6Rw5bR0c3ACQaawgXx0QYndlE= 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= github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= -github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4 h1:Hs82Z41s6SdL1CELW+XaDYmOH4hkBN4/N9og/AsOv7E= github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= 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/andybalholm/brotli v1.0.0/go.mod h1:loMXtMfwqflxFJPmdbJO0a3KNoPuLBgiu3qAvBg8x/Y= github.com/anmitsu/go-shlex v0.0.0-20161002113705-648efa622239/go.mod h1:2FmKhYUyUczH0OGQWaF5ceTx0UBShxjsH6f8oGKYe2c= +github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= github.com/antonmedv/expr v1.8.9 h1:O9stiHmHHww9b4ozhPx7T6BK7fXfOCHJ8ybxf0833zw= github.com/antonmedv/expr v1.8.9/go.mod h1:5qsM3oLGDND7sDmQGDXHkYfkjYMUX14qsgqmHhwGEk8= github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ= @@ -159,6 +146,8 @@ github.com/apex/log v1.9.0/go.mod h1:m82fZlWIuiWzWP04XCTXmnX0xRkYYbCdYn8jbJeLBEA github.com/apex/logs v1.0.0/go.mod h1:XzxuLZ5myVHDy9SAmYpamKKRNApGj54PfYLcFrXqDwo= github.com/aphistic/golf v0.0.0-20180712155816-02c07f170c5a/go.mod h1:3NqKYiepwy8kCu4PNA+aP7WUV72eXWJeP9/r3/K9aLE= github.com/aphistic/sweet v0.2.0/go.mod h1:fWDlIh/isSE9n6EPsRmC0det+whmX6dJid3stzu0Xys= +github.com/argoproj/pkg v0.7.0 h1:fhCONBGjX5FuB+AlpXHc1Lo3FGuNDB7Zr+Q7S0my5ck= +github.com/argoproj/pkg v0.7.0/go.mod h1:ra+bQPmbVAoEL+gYSKesuigt4m49i3Qa3mE/xQcjCiA= 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= @@ -173,10 +162,9 @@ github.com/aws/aws-sdk-go v1.15.27/go.mod h1:mFuSZ37Z9YOHbQEwBWztmVzqXrEkub65tZo github.com/aws/aws-sdk-go v1.19.18/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= github.com/aws/aws-sdk-go v1.20.6/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= github.com/aws/aws-sdk-go v1.27.0/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= -github.com/aws/aws-sdk-go v1.31.13 h1:UeWMTRTL0XAKLR7vxDL4/u7KOtz/LtfJr+lXtxN4YEQ= github.com/aws/aws-sdk-go v1.31.13/go.mod h1:5zCpMtNQVjRREroY7sYe8lOMRSxkhG6MZveU8YkpAk0= +github.com/aws/aws-sdk-go v1.33.16/go.mod h1:5zCpMtNQVjRREroY7sYe8lOMRSxkhG6MZveU8YkpAk0= github.com/aws/aws-sdk-go v1.35.24/go.mod h1:tlPOdRjfxPBpNIwqDj61rmsnA85v9jc0Ps9+muhnW+k= -github.com/aws/aws-sdk-go-v2 v0.18.0 h1:qZ+woO4SamnH/eEbjM2IDLhRNwIwND/RQyVlBLp3Jqg= github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= github.com/aws/aws-sdk-go-v2 v1.0.0 h1:ncEVPoHArsG+HjoDe/3ex/TG1CbLwMQ4eaWj0UGdyTo= github.com/aws/aws-sdk-go-v2 v1.0.0/go.mod h1:smfAbmpW+tcRVuNUjo3MOArSZmW72t62rkCzc2i0TWM= @@ -203,7 +191,6 @@ github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kB github.com/bifurcation/mint v0.0.0-20180715133206-93c51c6ce115/go.mod h1:zVt7zX3K/aDCk9Tj+VM7YymsX66ERvzCJzw8rFCX2JU= github.com/bketelsen/crypt v0.0.3-0.20200106085610-5cbc8cc4026c/go.mod h1:MKsuJmJgSg28kpZDP6UIiPt0e0Oz0kqKNGyRaWEPv84= github.com/blakesmith/ar v0.0.0-20190502131153-809d4375e1fb/go.mod h1:PkYb9DJNAwrSvRx5DYA+gUcOIgTGVMNkfSCbZM8cWpI= -github.com/blang/semver v3.5.0+incompatible h1:CGxCgetQ64DKk7rdZ++Vfnb1+ogGNnB17OJKJXD2Cfs= github.com/blang/semver v3.5.0+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk= github.com/blang/semver v3.5.1+incompatible h1:cQNTCjp13qL8KC3Nbxr/y2Bqb63oX6wdnnjpJbkM4JQ= github.com/blang/semver v3.5.1+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk= @@ -234,7 +221,6 @@ github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4 github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= github.com/clusterhq/flocker-go v0.0.0-20160920122132-2b8b7259d313/go.mod h1:P1wt9Z3DP8O6W3rvwCt0REIlshg1InHImaLW0t3ObY0= github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= -github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa h1:OaNxuTZr7kxeODyLWsRMC+OD03aFUH+mW6r2d+MWa5Y= github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8= github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI= github.com/codegangsta/negroni v1.0.0/go.mod h1:v0y3T5G7Y1UlFfyxFn/QLRU4a2EuNau2iZY63YTKWo0= @@ -258,15 +244,12 @@ github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc github.com/coreos/etcd v3.3.13+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= 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 h1:wkHLiw0WNATZnSG7epLsujiMCgPAc9xhjJ4tgnAxmfM= 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 h1:Wf6HqHfScWJN9/ZjdUKyjop4mf3Qdd+1TvvltAvM3m8= github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= github.com/coreos/go-systemd/v22 v22.0.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk= github.com/coreos/go-systemd/v22 v22.1.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk= github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= -github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f h1:lBNOc5arjvs8E5mO2tbpBpLoyyu8B6e44T7hJy6potg= github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= @@ -282,7 +265,6 @@ github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs github.com/daviddengcn/go-colortext v0.0.0-20160507010035-511bcaf42ccd/go.mod h1:dv4zxwHi5C/8AeI+4gX4dCWOIvNi7I6JCSX0HvlKPgE= github.com/denis-tingajkin/go-header v0.3.1/go.mod h1:sq/2IxMhaZX+RRcgHfCRx/m0M5na0fBt4/CRe7Lrji0= github.com/devigned/tab v0.1.1/go.mod h1:XG9mPq0dFghrYvoBF3xdRrJzSTX1b7IQrvaL9mzjeJY= -github.com/dgrijalva/jwt-go v3.2.0+incompatible h1:7qlOGliEKZXTDg6OTjfoBKDXWrumCAMpl/TFQ4/5kLM= github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ= github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no= github.com/dimchansky/utfbom v1.1.0/go.mod h1:rO41eb7gLfo8SF1jd9F8HplJm1Fewwi4mQvIirEdv+8= @@ -299,7 +281,6 @@ github.com/docker/spdystream v0.0.0-20181023171402-6480d4af844c h1:ZfSZ3P3BedhKG github.com/docker/spdystream v0.0.0-20181023171402-6480d4af844c/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 h1:VSnTsYCnlFHaM2/igO1h6X3HA71jcobQuxemgkq4zYo= github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5mFgVsvEsIPBvNs= github.com/eapache/go-xerial-snappy v0.0.0-20180814174437-776d5712da21/go.mod h1:+020luEh2TKB4/GOp8oxxtq0Daoen/Cii55CzbTV6DU= @@ -325,12 +306,12 @@ github.com/evanphx/json-patch/v5 v5.2.0/go.mod h1:G79N1coSVB93tBe7j6PhzjmR3/2Vvl github.com/exponent-io/jsonpath v0.0.0-20151013193312-d6023ce2651d h1:105gxyaGwCFad8crR9dcMQWvV9Hvulu6hwUh4tWPJnM= github.com/exponent-io/jsonpath v0.0.0-20151013193312-d6023ce2651d/go.mod h1:ZZMPRZwes7CROmyNKgQzC3XPs6L/G2EJLHddWejkmf4= github.com/fatih/camelcase v1.0.0/go.mod h1:yN2Sb0lFhZJUdVvtELVWefmrXpuZESvPmqwoZc+/fpc= -github.com/fatih/color v1.7.0 h1:DkWD4oS2D8LGGgTQ6IvwJJXSL5Vp2ffcQg58nFV38Ys= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= -github.com/fatih/color v1.9.0 h1:8xPHl4/q1VyqGIPif1F+1V3Y3lSmrq01EabUW3CoW5s= github.com/fatih/color v1.9.0/go.mod h1:eQcE1qtQxscV5RaZvpXrrb8Drkc3/DdQ+uUYCNjL+zU= github.com/fatih/color v1.10.0 h1:s36xzo75JdqLaaWoiEHk767eHiwo0598uUxyfiPkDsg= github.com/fatih/color v1.10.0/go.mod h1:ELkj/draVOlAH/xkhN6mQ50Qd0MPOk5AAr3maGEBuJM= +github.com/felixge/httpsnoop v1.0.1 h1:lvB5Jl89CsZtGIWuTcDM1E/vkVs49/Ml7JJe07l8SPQ= +github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= github.com/flynn/go-shlex v0.0.0-20150515145356-3f9db97f8568/go.mod h1:xEzjJPgXI435gkrCt3MPfRiAkVrwSbHsst4LCFVfpJc= github.com/fogleman/gg v1.2.1-0.20190220221249-0403632d5b90/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= github.com/form3tech-oss/jwt-go v3.2.2+incompatible h1:TcekIExNqud5crz4xD2pavyTgWiPvpYe4Xau31I0PRk= @@ -338,7 +319,6 @@ github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoD github.com/fortytw2/leaktest v1.3.0/go.mod h1:jDsjWgpAGjm2CA7WthBh/CdZYEPF31XHquHwclZch5g= github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4= github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20= -github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I= 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= @@ -354,7 +334,6 @@ github.com/gliderlabs/ssh v0.1.1/go.mod h1:U7qILu1NlMHj9FlMhZLlkCdDnU1DBEAqr0aev github.com/gliderlabs/ssh v0.2.2/go.mod h1:U7qILu1NlMHj9FlMhZLlkCdDnU1DBEAqr0aevW3Awn0= 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-acme/lego v2.5.0+incompatible h1:5fNN9yRQfv8ymH3DSsxla+4aYeQt2IgfZqHKVnK8f0s= github.com/go-acme/lego v2.5.0+incompatible/go.mod h1:yzMNe9CasVUhkquNvti5nAtPmG94USbYxYrZfTkIn0M= github.com/go-bindata/go-bindata v3.1.1+incompatible/go.mod h1:xK8Dsgwmeed+BBsSy2XTopBn/8uK2HWuGSnA11C3Joo= github.com/go-critic/go-critic v0.5.0/go.mod h1:4jeRh3ZAVnRYhuWdOEvwzVqLUpxMSoAT0xZ74JsTPlo= @@ -377,8 +356,9 @@ github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9 github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= github.com/go-logfmt/logfmt v0.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 h1:QvGt2nLcHH0WK9orKa+ppBPAxREcH364nPUedEpK0TY= github.com/go-logr/logr v0.2.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= +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-ole/go-ole v1.2.1/go.mod h1:7FAglXiTm7HKlQRDeOQ6ZNUHidzCWXuZWq/1dTyBNF8= 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= @@ -459,7 +439,6 @@ github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b h1:VKtxabqXZkF25pY9ekf 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= -github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6 h1:ZgQEtGgCBiWRM39fZuwSd1LwSqqSW0hOdXCYYDX0R3I= github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e h1:1r7pUrabqp18hOBcwBwiTsbnFeTZHV9eER/QT5JVZxY= @@ -472,7 +451,6 @@ github.com/golang/mock v1.4.1/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt github.com/golang/mock v1.4.3/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= 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 h1:6nsPYzhq5kReh6QImI3k5qWzO4PEbvbIW2cwSfR/6xs= 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= @@ -483,7 +461,6 @@ github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrU github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w= 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 h1:+Z5KGCizgyZCbGh1KZqA0fcLLkwbsjIzS4aV2v7wJX0= 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= @@ -515,12 +492,10 @@ github.com/google/cadvisor v0.38.7/go.mod h1:1OFB9sOOMkBdUBGCO/1SArawTnDscgMzTod 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 h1:xsAVV57WRhGj6kEIi8ReJzQlHHqcBYCElAvkovg3B/4= github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.4.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.1/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.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.4 h1:L8R9j+yAqZuZjsqh/z+F1NCffTKKLShY6zXTItVIZ8M= github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= @@ -529,7 +504,6 @@ github.com/google/go-querystring v1.0.0 h1:Xkwi/a1rcvNg1PPYe5vI8GbeBY/jrVuDX5ASu github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck= github.com/google/go-replayers/grpcreplay v0.1.0/go.mod h1:8Ig2Idjpr6gifRd6pNVggX6TC1Zw6Jx74AKp7QNH2QE= github.com/google/go-replayers/httpreplay v0.1.0/go.mod h1:YKZViNhiGgqdBlUbI2MwGpq4pXxNmhJLPHQ7cv2b5no= -github.com/google/gofuzz v1.0.0 h1:A8PeW59pxE9IoFRqBp37U+mSNaQoZ46F1f0f863XSXw= 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= @@ -549,7 +523,6 @@ github.com/google/shlex v0.0.0-20191202100458-e7afc7fbc510/go.mod h1:pupxD2MaaD3 github.com/google/subcommands v1.0.1/go.mod h1:ZjhPrFU+Olkh9WazFPsl27BQ4UPiG37m3yTrtFlrHVk= github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.1.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/google/uuid v1.1.1 h1:Gkbcsh/GbpXz7lPftLA3P6TYMwjCLYm83jiFQZF/3gY= github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= 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= @@ -557,7 +530,6 @@ github.com/google/wire v0.4.0/go.mod h1:ngWDr9Qvq3yZA10YrxfyGELY/AFWGVpy9c1LTRi1 github.com/googleapis/gax-go v2.0.2+incompatible/go.mod h1:SFVmujtThgffbyetf+mdk2eWhX2bMyUtNHzFKcPA9HY= 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.2.0 h1:l6N3VoaVzTncYYW+9yOz2LJJammFZGBO13sqgEhpy9g= github.com/googleapis/gnostic v0.2.0/go.mod h1:sJBsCZ4ayReDTBIg8b9dl28c5xFWyhBTVRp3pOg5EKY= github.com/googleapis/gnostic v0.4.1 h1:DLJCy1n/vrD4HPjOvYcT8aYQXpPIzoRZONaYwyycI+I= github.com/googleapis/gnostic v0.4.1/go.mod h1:LRhVm6pbyptWbWbuZ38d1eyptfvIytN3ir6b65WBswg= @@ -578,9 +550,7 @@ github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2z github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= github.com/gorilla/mux v1.8.0/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So= github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= -github.com/gorilla/websocket v1.4.0 h1:WDFjx/TMzVgy9VdMMQi2K2Emtwi2QcUQsztZ/zLaH/Q= github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= -github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc= github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= github.com/gostaticanalysis/analysisutil v0.0.0-20190318220348-4088753ea4d3/go.mod h1:eEOZF4jCKGi+aprrirO9e7WKB3beBRtWgqGunKl6pKE= github.com/gostaticanalysis/analysisutil v0.0.3/go.mod h1:eEOZF4jCKGi+aprrirO9e7WKB3beBRtWgqGunKl6pKE= @@ -590,13 +560,10 @@ github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:Fecb github.com/gregjones/httpcache v0.0.0-20190611155906-901d90724c79 h1:+ngKgrYPPJrOjhax5N+uePQ0Fh1Z7PheYoUI/0nzkPA= github.com/gregjones/httpcache v0.0.0-20190611155906-901d90724c79/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= 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 h1:z53tR0945TRRQO/fLEVPI6SMv7ZflF0TEaTAoU7tOzg= 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 h1:Ovs26xHkKqVztRpIrF/92BcuyuQ/YW4NSIpoGtfXNho= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= -github.com/grpc-ecosystem/grpc-gateway v1.9.0/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= -github.com/grpc-ecosystem/grpc-gateway v1.9.5 h1:UImYN5qQ8tuGpGE16ZmjvcTtTw24zw1QAp/SlnNrZhI= -github.com/grpc-ecosystem/grpc-gateway v1.9.5/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= +github.com/grpc-ecosystem/grpc-gateway v1.16.0 h1:gmcG1KaJ57LophUzW0Hy8NmPhnMZb4M0+kPpLofRdBo= +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/api v1.3.0/go.mod h1:MmDNSzIMUjNpY/mQ398R4bk2FnqQLoPndWW5VkKPlCE= github.com/hashicorp/consul/sdk v0.1.1/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8= @@ -616,16 +583,13 @@ github.com/hashicorp/go-retryablehttp v0.6.8/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER github.com/hashicorp/go-rootcerts v1.0.0/go.mod h1:K6zTfqpRlCUIjkwsN4Z+hiSfzSTQa6eBIzfwKfwNnHU= github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU= github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4= -github.com/hashicorp/go-uuid v1.0.0 h1:RS8zrF7PhGwyNPOtxSClXXj9HA8feRnJzgnI1RJCSnM= github.com/hashicorp/go-uuid v1.0.0/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= -github.com/hashicorp/go-uuid v1.0.1 h1:fv1ep09latC32wFoVwnqcnKJGnMSdBanPczbHAYm1BE= github.com/hashicorp/go-uuid v1.0.1/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= github.com/hashicorp/go-version v1.2.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= github.com/hashicorp/go-version v1.2.1/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= github.com/hashicorp/go.net v0.0.1/go.mod h1:hjKkEWcCURg++eb33jQU7oqQcI9XDCnUzHA0oac0k90= github.com/hashicorp/golang-lru v0.0.0-20180201235237-0fb14efe8c47/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= -github.com/hashicorp/golang-lru v0.5.1 h1:0hERBMJE1eitiLkihrMvRVBYAkpHzc/J3QdDN+dAcgU= github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= github.com/hashicorp/golang-lru v0.5.4 h1:YDjusn29QI/Das2iO9M0BHnIbxPeyuCHsjMW+lJfyTc= github.com/hashicorp/golang-lru v0.5.4/go.mod h1:iADmTwqILo4mZ8BN3D2Q6+9jd8WM5uGBxy+E8yxSoD4= @@ -638,7 +602,6 @@ github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/J github.com/heketi/heketi v9.0.1-0.20190917153846-c2e2a4ab7ab9+incompatible/go.mod h1:bB9ly3RchcQqsQ9CpyaQwvva7RS5ytVoSoholZQON6o= github.com/heketi/tests v0.0.0-20151005000721-f3775cbcefd6/go.mod h1:xGMAM8JLi7UkZt1i4FQeQy0R2T8GLUwQhOP5M1gBhy4= github.com/hinshun/vt10x v0.0.0-20180616224451-1954e6464174/go.mod h1:DqJ97dSdRW1W22yXSB90986pcOyQ7r45iio1KN2ez1A= -github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/huandu/xstrings v1.3.1/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE= github.com/huandu/xstrings v1.3.2/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE= @@ -661,15 +624,12 @@ github.com/jingyugao/rowserrcheck v0.0.0-20191204022205-72ab7603b68a/go.mod h1:x github.com/jirfag/go-printf-func-name v0.0.0-20191110105641-45db9963cdd3/go.mod h1:HEWGJkRDzjJY2sqdDwxccsGicWEf9BQOZsq2tV+xzM0= github.com/jmespath/go-jmespath v0.0.0-20160202185014-0b12d6b521d8/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= -github.com/jmespath/go-jmespath v0.3.0 h1:OS12ieG61fsCg5+qLJ+SsW9NicxNkg3b25OyT2yCeUc= github.com/jmespath/go-jmespath v0.3.0/go.mod h1:9QtRXoHjLGCJ5IBSaohpXITPlowMeeYCZ7fLUTSywik= -github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg= github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= github.com/jmoiron/sqlx v1.2.0/go.mod h1:1FEQNm3xlJgrMD+FBdI9+xvCksHtbpVBBw5dYhBSsks= github.com/jmoiron/sqlx v1.2.1-0.20190826204134-d7d95172beb5/go.mod h1:1FEQNm3xlJgrMD+FBdI9+xvCksHtbpVBBw5dYhBSsks= github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg= -github.com/jonboulle/clockwork v0.1.0 h1:VKV+ZcuP6l3yW9doeqz6ziZGgcynBVQO+obU0+0hcPo= github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo= github.com/jpillora/backoff v0.0.0-20180909062703-3050d21c67d7/go.mod h1:2iMrUgbbvHEiQClaW2NsSzMyGHqN+rDFqY705q49KG0= github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4= @@ -702,19 +662,16 @@ github.com/klauspost/compress v1.10.7/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYs github.com/klauspost/compress v1.10.10/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/compress v1.11.0/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/cpuid v1.2.0/go.mod h1:Pj4uuM528wm8OyEC2QMXAi2YiTZ96dNQPGgoMS4s3ek= -github.com/konsorten/go-windows-terminal-sequences v1.0.1 h1:mweAR1A6xJ3oS2pRaGiHgQ4OO8tzTaLawm8vnODuwDk= +github.com/klauspost/cpuid v1.2.3/go.mod h1:Pj4uuM528wm8OyEC2QMXAi2YiTZ96dNQPGgoMS4s3ek= 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.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= -github.com/konsorten/go-windows-terminal-sequences v1.0.3 h1:CE8S1cTafDpPvMhIxNJKvHsGVBgn1xWYf1NbHQhywc8= 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 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI= github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/pty v1.1.5/go.mod h1:9r2w37qlBe7rQ6e1fg1S/9xpWHSnaqNdHD3WcMdbPDA= -github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= 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= @@ -757,10 +714,8 @@ github.com/matoous/godox v0.0.0-20190911065817-5d6d842e92eb/go.mod h1:1BELzlh859 github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= github.com/mattn/go-colorable v0.1.1/go.mod h1:FuOcm+DKB9mbwrcAfNl7/TZVBZ6rcnceauSikq3lYCQ= github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= -github.com/mattn/go-colorable v0.1.4 h1:snbPLB8fVfU9iwbbo30TPtbLRzwWu6aJS6Xh4eaaviA= github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= github.com/mattn/go-colorable v0.1.6/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= -github.com/mattn/go-colorable v0.1.7 h1:bQGKb3vps/j0E9GfJQ03JyhRuxsvdAanXlT9BTw3mdw= github.com/mattn/go-colorable v0.1.7/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= 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= @@ -784,7 +739,6 @@ github.com/mattn/go-shellwords v1.0.10/go.mod h1:EZzvwXDESEeg03EKmM+RmDnNOPKG4lL github.com/mattn/go-sqlite3 v1.9.0/go.mod h1:FPy6KqzDD04eiIsT53CuJW3U88zkxoIYsOqkbpncsNc= github.com/mattn/go-zglob v0.0.3/go.mod h1:9fxibJccNxU2cnpIKLRRFA7zX7qhkJIQWBb449FYHOo= github.com/mattn/goveralls v0.0.2/go.mod h1:8d1ZMHsd7fW6IRPKQh46F2WRpyib5/X4FOpevwGNQEw= -github.com/matttproud/golang_protobuf_extensions v1.0.1 h1:4hp9jkHxhMHkqkrB3Ix0jegS5sx/RkqARlsWZ6pIwiU= github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= github.com/matttproud/golang_protobuf_extensions v1.0.2-0.20181231171920-c182affec369 h1:I0XW9+e1XWDxdcEniV4rQAIOPUGDq67JSCiRCgGCZLI= github.com/matttproud/golang_protobuf_extensions v1.0.2-0.20181231171920-c182affec369/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= @@ -795,6 +749,9 @@ github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3N github.com/miekg/dns v1.1.3/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= github.com/miekg/dns v1.1.4/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= github.com/mindprince/gonvml v0.0.0-20190828220739-9ebdce4bb989/go.mod h1:2eu9pRWp8mo84xCg6KswZ+USQHjwgRhNp06sozOdsTY= +github.com/minio/md5-simd v1.1.0/go.mod h1:XpBqgZULrMYD3R+M28PcmP0CkI7PEMzB3U77ZrKZ0Gw= +github.com/minio/minio-go/v7 v7.0.2/go.mod h1:dJ80Mv2HeGkYLH1sqS/ksz07ON6csH3S6JUMSQ2zAns= +github.com/minio/sha256-simd v0.1.1/go.mod h1:B5e1o+1/KgNmWrSQK08Y6Z1Vb5pwIktudl0J58iy0KM= github.com/mistifyio/go-zfs v2.1.2-0.20190413222219-f784269be439+incompatible/go.mod h1:8AuVvqP/mXw1px98n46wfvcGfQ4ci2FwoAjKYxuo3Z4= github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc= github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= @@ -861,24 +818,22 @@ github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQ 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/olekukonko/tablewriter v0.0.4/go.mod h1:zq6QwlOf5SlnkVbMSr5EoBv3636FWnp+qbPhuoO21uA= +github.com/oliveagle/jsonpath v0.0.0-20180606110733-2e52cf6e6852/go.mod h1:eqOVx5Vwu4gd2mmMZvVZsgIqNSaW3xxRThUJ0k/TPk4= 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.7.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.13.0 h1:M76yO2HkZASFjXL0HSoZJ1AYEmQxNJmY41Jx1zNUq1Y= github.com/onsi/ginkgo v1.13.0/go.mod h1:+REjRxOmWfHCjfv9TTWB1jD1Frx4XydAD3zm1lskyM0= 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/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= -github.com/onsi/gomega v1.7.0 h1:XPnZz8VVBHjVsy1vzJmRwIcSwiUO+JFfrv/xGiigmME= 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 h1:o0+MgICZLuZ7xjH7Vx6zS/zcu93/BEp1VwkIW1mEXCE= 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= @@ -915,7 +870,6 @@ github.com/phayes/checkstyle v0.0.0-20170904204023-bfd46e6a821d/go.mod h1:3OzsM7 github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc= github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= -github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I= 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= @@ -932,7 +886,6 @@ github.com/prometheus/client_golang v0.9.3-0.20190127221311-3c4408c8b829/go.mod 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.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og= -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.8.0 h1:zvJNkoCFAnYFNC24FV8nW4JdRJ3GIFcLbg65lL/JDcw= github.com/prometheus/client_golang v1.8.0/go.mod h1:O9VU6huf47PktckDQfMTX0Y8tY0/7TSWwj+ITvv0TnM= @@ -948,7 +901,6 @@ github.com/prometheus/common v0.2.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y8 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.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA= -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.14.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s= github.com/prometheus/common v0.18.0 h1:WCVKW7aL6LEe1uryfI9dnEc2ZqNB1Fn0ok930v0iL1Y= @@ -960,7 +912,6 @@ github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084/go.mod h1:TjEm7z github.com/prometheus/procfs v0.0.0-20190522114515-bc1a522cf7b1/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A= -github.com/prometheus/procfs v0.1.3 h1:F0+tqvhOksq22sc6iCHF5WGlWjdwj92p0udFh1VFBS8= 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= @@ -976,8 +927,8 @@ github.com/remyoudompheng/bigfft v0.0.0-20170806203942-52369c62f446/go.mod h1:uY github.com/rivo/tview v0.0.0-20200219210816-cd38d7432498/go.mod h1:6lkG1x+13OShEf0EaOCaTQYyB7d5nSbb181KtjlS+84= github.com/rivo/uniseg v0.1.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc= github.com/robfig/cron v1.1.0/go.mod h1:JGuDeoQd7Z6yL4zQhZ3OPEVHB7fL6Ka6skscFHfmt2k= -github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= github.com/rogpeppe/fastuuid v1.1.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= +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/rogpeppe/go-internal v1.5.2/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= github.com/rogpeppe/go-internal v1.6.0/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= @@ -1014,9 +965,7 @@ github.com/shurcooL/go-goon v0.0.0-20170922171312-37c2f522c041/go.mod h1:N5mDOms 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.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q= -github.com/sirupsen/logrus v1.4.2 h1:SPIRibHv4MatM3XXNO2BJeFLZwZ2LvZgfQ5+UNI2im4= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= -github.com/sirupsen/logrus v1.6.0 h1:UBcNElsrwanuuMsnGSlYmtmgbb23qDR5dG+6X6Oo89I= github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88= github.com/sirupsen/logrus v1.7.0 h1:ShrD1U9pZB12TX0cVy0DtePoCH97K8EtX+mg7ZARUtM= github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= @@ -1024,6 +973,7 @@ github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1 github.com/smartystreets/assertions v1.0.0 h1:UVQPSSmc3qtTi+zPPkCXvZX9VvW/xT/NsRvKfwY81a8= github.com/smartystreets/assertions v1.0.0/go.mod h1:kHHU4qYBaI3q23Pp3VPrmWhuIUrLW/7eUrw0BU5VaoM= github.com/smartystreets/go-aws-auth v0.0.0-20180515143844-0c1422d1fdb9/go.mod h1:SnhjPscd9TpLiy1LpzGSKh3bXCfxxXuqd9xmQJy3slM= +github.com/smartystreets/goconvey v0.0.0-20190330032615-68dc04aab96a/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA= github.com/smartystreets/goconvey v1.6.4 h1:fv0U8FUIMPNf1L9lnHLvLhgicrIVChEkdzIKYqbNC9s= github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA= github.com/smartystreets/gunit v1.0.0/go.mod h1:qwPWnhz6pn0NnRBP++URONOVyNkPyr4SauJk4cUOwJs= @@ -1038,9 +988,7 @@ github.com/spaceapegames/go-wavefront v1.8.1 h1:Xuby0uBfw1WVxD9d+l8Gh+zINqnBfd0R github.com/spaceapegames/go-wavefront v1.8.1/go.mod h1:GtdIjtJ0URkfPmaKx0+7vMSDvT/MON9v+4pbdagA8As= 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.3.2 h1:GDarE4TJQI52kYSbSAmLiId1Elfj+xgSDqrUZxFhxlU= github.com/spf13/afero v1.3.2/go.mod h1:5KUK8ByomD5Ti5Artl0RtHeI5pTF7MIDuXL3yY520V4= github.com/spf13/afero v1.4.1 h1:asw9sl74539yqavKaglDM5hFpdJVK0Y5Dr/JOgQ89nQ= github.com/spf13/afero v1.4.1/go.mod h1:Ai8FlHk4v/PARR026UzYexafAt9roJ7LcLMAmO6Z93I= @@ -1048,7 +996,6 @@ github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkU github.com/spf13/cast v1.3.1 h1:nFm6S0SMdyzrzcmThSipiEubIDy8WEXKNZ0UOgiRpng= 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 v1.0.0 h1:6m/oheQuQ13N9ks4hubMG6BnvwOeaJrqSPLahSnczz8= 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= @@ -1079,10 +1026,8 @@ github.com/stretchr/testify v0.0.0-20161117074351-18a02ba4a312/go.mod h1:a8OnRci github.com/stretchr/testify v1.2.1/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 h1:2E4SXV/wtOkTonXsotYi4li6zVWxYlZuYNCXe9XRJyk= 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= @@ -1102,9 +1047,7 @@ github.com/tj/go-buffer v1.1.0/go.mod h1:iyiJpfFcR2B9sXu7KvjbT9fpM4mOelRSDTbntVj github.com/tj/go-elastic v0.0.0-20171221160941-36157cbbebc2/go.mod h1:WjeM0Oo1eNAjXGDx2yma7uG2XoyRZTq1uv3M/o7imD0= github.com/tj/go-kinesis v0.0.0-20171128231115-08b17f58cb1b/go.mod h1:/yhzCV0xPfx6jb1bBgRFjl5lytqVqZXEaeqWP8lTEao= github.com/tj/go-spin v1.1.0/go.mod h1:Mg1mzmePZm4dva8Qz60H2lHwmJ2loum4VIrLgVnKwh4= -github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8 h1:ndzgwNDnKIqyCvHTXaCqh9KlOWKvBry6nuXMJmonVsE= 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 h1:LnC5Kc/wtumK+WB441p7ynQJzVuNRJiqddSIE3IlSEQ= github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= github.com/tomarrell/wrapcheck v0.0.0-20200807122107-df9e8bcb914d/go.mod h1:yiFB6fFoV7saXirUGfuK+cPtUh4NX/Hf5y2WC2lehu0= github.com/tommy-muehle/go-mnd v1.3.1-0.20200224220436-e6f9a994e8fa/go.mod h1:dSUh0FtTP8VhvkL1S+gUR1OKd9ZnSaozuI6r3m6wOig= @@ -1149,7 +1092,6 @@ github.com/xanzy/ssh-agent v0.2.0/go.mod h1:0NyE30eGUDliuLEHJgYte/zncp2zdTStcOnW github.com/xanzy/ssh-agent v0.2.1/go.mod h1:mLlQY/MoOhWBj+gOGMQkOeiEvkx+8pJSI+0Bx9h2kr4= github.com/xanzy/ssh-agent v0.3.0/go.mod h1:3s9xbODqPuuhK9JV1R321M/FlMZSBvE5aY6eAcqrDh0= github.com/xi2/xz v0.0.0-20171230120015-48954b6210f8/go.mod h1:HUYIGzjTL3rfEspMxjDjgmT5uz5wzYJKVo23qUhYTos= -github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 h1:eY9dn8+vbi4tKz5Qo6v2eYzo7kUS51QINcR5jNpbZS8= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= @@ -1158,9 +1100,7 @@ github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9de github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/zenazn/goji v0.9.0/go.mod h1:7S9M489iMyHBNxwZnk9/EHS098H4/F6TATF2mIxtB1Q= go.etcd.io/bbolt v1.3.2/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= -go.etcd.io/bbolt v1.3.3 h1:MUGmc65QhB3pIlaQ5bB4LwqSj6GIonVJXpZiaKNyaKk= go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= -go.etcd.io/bbolt v1.3.5 h1:XAzx9gjCb0Rxj7EoqcClPD1d5ZBxZJk0jbuoPHenBt0= 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= @@ -1174,21 +1114,13 @@ 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 v1.3.2 h1:2Oa65PReHzfn29GpvgsYwloV9AVFHPDk8tYxt2c2tr4= go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= -go.uber.org/atomic v1.4.0 h1:cxzIVoETapQEqDhQu3QfnvXAV4AlzcvUCxkVUFw3+EU= go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= -go.uber.org/atomic v1.5.0 h1:OI5t8sDa1Or+q8AeE+yKeB/SDYioSHAgcVljj9JIETY= go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= -go.uber.org/multierr v1.1.0 h1:HoEmRHQPVSqub6w2z2d2EOVs2fjyFRGyofhKuyDq0QI= go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= -go.uber.org/multierr v1.3.0 h1:sFPn2GLc3poCkfrpIXGhBD2X0CMIo4Q/zSULXrj/+uc= go.uber.org/multierr v1.3.0/go.mod h1:VgVr7evmIr6uPjLBxg28wmKNXyqE9akIJ5XnfpiKl+4= -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 v1.10.0 h1:ORx85nbTijNz8ljznvCMR1ZBIPKFn3jQrag10X2AsuM= go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= -go.uber.org/zap v1.13.0 h1:nR6NoDBgAf67s68NhaXbsojM+2gxp3S1hWkHDl27pVU= go.uber.org/zap v1.13.0/go.mod h1:zwrFLgMcdUuIBviXEYEH1YKNaOBnKXsx2IPda5bBwHM= gocloud.dev v0.20.0/go.mod h1:+Y/RpSXrJthIOM8uFNzWp6MRu9pFPNFEEZrQMxpkfIc= golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= @@ -1201,19 +1133,17 @@ golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACk golang.org/x/crypto v0.0.0-20190320223903-b7391e95e576/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20190426145343-a29dc8fdc734/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20190513172903-22d7a77e9e5f/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-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= -golang.org/x/crypto v0.0.0-20190820162420-60c769a6c586 h1:7KByu05hhLed2MO29w7p1XfZvZ13m8mub3shuVftRs0= golang.org/x/crypto v0.0.0-20190820162420-60c769a6c586/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= -golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550 h1:ObdrDkeb4kJdCP557AjRjq69pTHfNouLtWZG7j9rPN8= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200302210943-78000ba7a073/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200414173820-0848c9571904/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= -golang.org/x/crypto v0.0.0-20200709230013-948cd5f35899 h1:DZhuSZLsGlFL4CmhA8BcRA0mnthyA/nZ00AqCUo7vHg= golang.org/x/crypto v0.0.0-20200709230013-948cd5f35899/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20201016220609-9e8e0b390897 h1:pLI5jrR7OSLijeIDcmRxNmw2api+jEfxLoykJVice/E= @@ -1244,7 +1174,6 @@ 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/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= @@ -1252,7 +1181,6 @@ golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKG 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 h1:KU7oHjnv3XNWfa5COkzUifxZmxp1TyI7ImMXqFxLwvQ= 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= @@ -1264,7 +1192,6 @@ golang.org/x/net v0.0.0-20181023162649-9b4f9f5ad519/go.mod h1:mL1N/T3taQHkDXs73r golang.org/x/net v0.0.0-20181108082009-03003ca0c849/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= -golang.org/x/net v0.0.0-20181220203305-927f97764cc3/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190125091013-d26f9f9a57f3/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -1282,14 +1209,12 @@ golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLL golang.org/x/net v0.0.0-20190724013045-ca1201d0de80/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20191004110552-13f9640d40b9 h1:rjwSpXsdiK0dV8/Naq3kAw9ymfAeJIyd0upUIElB+lI= golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20191112182307-2180aed22343/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= golang.org/x/net v0.0.0-20200222125558-5a598a2470a0/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20200226121028-0de0cce0169b h1:0mm1VjtFUOIlE1SbDlwjYaDxZVDP2S5ou6y0gSgXHu8= 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= @@ -1300,11 +1225,9 @@ golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/ golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= golang.org/x/net v0.0.0-20200602114024-627f9648deb9/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 h1:VXak5I6aEWmAXeQjA+QSZzlgNrpq9mjcfDemuexIKsU= golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= -golang.org/x/net v0.0.0-20200822124328-c89045814202 h1:VvcQYSHwXgi7W+TpUR6A9g6Up98WAHf3f/ulnJ62IyA= golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= -golang.org/x/net v0.0.0-20201031054903-ff519b6c9102 h1:42cLlJJdEh+ySyeUUbEQ5bsTiq8voBeTuweGVkY6Puw= +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 h1:uwuIcX0g4Yl1NC5XAz37xsr2lTtcqevgzYNVt49waME= golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= @@ -1312,7 +1235,6 @@ golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAG golang.org/x/oauth2 v0.0.0-20181106182150-f42d05182288/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-20190402181905-9f3314589c9a/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= -golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45 h1:SVwTIAaPC2U/AvvLNZ2a7OVsmBpC8L5BlwK1whH3hm0= 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= @@ -1325,6 +1247,7 @@ golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJ 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/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180606202747-9527bec2660b/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= 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= @@ -1370,7 +1293,6 @@ golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7w 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-20200120151820-655fe14d7479/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200122134326-e047566fdf82 h1:ywK/j/KkyTHcdyYSZNXGjMwgmDSfjglYZ3vStQ/gSCU= golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200124204421-9fbb57f87de9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -1388,32 +1310,26 @@ golang.org/x/sys v0.0.0-20200519105757-fe76b779f299/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200602225109-6fdc65e7d980/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 h1:Ih9Yo4hSPImZOpfGuA4bR/ORKTAbhZo2AbWNRCnevdo= golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200728102440-3e129f6d46b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201009025420-dfb3f7c4e634 h1:bNEHhJCnrwMKNMmOx3yAynp5vs5/gRy+XWFtZFu7NBM= golang.org/x/sys v0.0.0-20201009025420-dfb3f7c4e634/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201015000850-e3ed0017c211/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201109165425-215b40eba54c h1:+B+zPA6081G5cEb2triOIJpcvSW4AYzmIyWAqMn2JAc= golang.org/x/sys v0.0.0-20201109165425-215b40eba54c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201110211018-35f3e6cf4a65/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/sys v0.0.0-20210119212857-b64e53b001e4 h1:myAQVi0cGEoqQVR5POX+8RR2mrocKqNN1hmeMqhX27k= +golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= 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 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= -golang.org/x/text v0.3.3 h1:cokOdA+Jmi5PJGXLlLllQSgYigAEfHXJAERHVMaCc2k= 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/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 h1:SvFZT6jyqRaOeXpc5h/JSfZenJ2O330aBsf7JfSUXmQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= -golang.org/x/time v0.0.0-20191024005414-555d28b269f0 h1:/5xXl8Y5W96D+TtHSlonuFqGHIWVuyCkGJLwGh9JJFs= 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= @@ -1478,7 +1394,6 @@ golang.org/x/tools v0.0.0-20200304193943-95d2e580d8eb/go.mod h1:o4KQGtdN14AW+yjs golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= golang.org/x/tools v0.0.0-20200317043434-63da46f3035e/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= golang.org/x/tools v0.0.0-20200321224714-0d839f3cf2ed/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= -golang.org/x/tools v0.0.0-20200323144430-8dcfad9e016e h1:ssd5ulOvVWlh4kDSUF2SqzmMeWfjmwDXM+uGw/aQjRE= golang.org/x/tools v0.0.0-20200323144430-8dcfad9e016e/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= golang.org/x/tools v0.0.0-20200324003944-a576cf524670/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= golang.org/x/tools v0.0.0-20200325010219-a49f79bcc224/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= @@ -1503,18 +1418,17 @@ golang.org/x/tools v0.0.0-20200626171337-aa94e735be7f/go.mod h1:EkVYQZoAsY45+roY golang.org/x/tools v0.0.0-20200701041122-1837592efa10/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= golang.org/x/tools v0.0.0-20200724022722-7017fd6b1305/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= golang.org/x/tools v0.0.0-20200731060945-b5fad4ed8dd6/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= -golang.org/x/tools v0.0.0-20200812195022-5ae4c3c160a0 h1:SQvH+DjrwqD1hyyQU+K7JegHz1KEZgEwt17p9d6R2eg= golang.org/x/tools v0.0.0-20200812195022-5ae4c3c160a0/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= golang.org/x/tools v0.0.0-20200831203904-5a2aa26beb65/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE= golang.org/x/tools v0.0.0-20201001104356-43ebab892c4c/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= golang.org/x/tools v0.0.0-20201002184944-ecd9fd270d5d/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= golang.org/x/tools v0.0.0-20201007032633-0806396f153e/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= golang.org/x/tools v0.0.0-20201011145850-ed2f50202694/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= -golang.org/x/tools v0.0.0-20201013201025-64a9e34f3752 h1:2ntEwh02rqo2jSsrYmp4yKHHjh0CbXP3ZtSUetSB+q8= golang.org/x/tools v0.0.0-20201013201025-64a9e34f3752/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= +golang.org/x/tools v0.1.0 h1:po9/4sTYwZU9lPhi1tOrb4hCv3qrhiQ77LZfGa2OjwY= +golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0= 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 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4= 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= @@ -1545,7 +1459,6 @@ google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9Ywl google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= google.golang.org/appengine v1.3.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= -google.golang.org/appengine v1.5.0 h1:KxkO13IPW4Lslp2bz+KHP2E3gtFlrIGNThxkZQ3g+4c= 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= @@ -1555,7 +1468,6 @@ google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoA 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= google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= -google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873 h1:nfPFGzJkUDX6uBmpN/pSw7MbOAWegH5QDQuoXFHedLg= google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190508193815-b515fa19cec8/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190530194941-fb225487d101/go.mod h1:z3L6/3dTEVtUr6QSP8miRzeRqwQOioJ9I66odjN4I7s= @@ -1580,11 +1492,13 @@ google.golang.org/genproto v0.0.0-20200325114520-5b2d0af7952b/go.mod h1:55QSHmfG 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-20200603110839-e855014d5736/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= -google.golang.org/genproto v0.0.0-20200608115520-7c474a2e3482 h1:i+Aiej6cta/Frzp13/swvwz5O00kYcSe0A/C5Wd7zX8= google.golang.org/genproto v0.0.0-20200608115520-7c474a2e3482/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= +google.golang.org/genproto v0.0.0-20200806141610-86f49bd18e98/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201110150050-8816d57aaa9a h1:pOwg4OoaRYScjmR4LlLgdtnyoHYTSAVhhqe5uPdpII8= google.golang.org/genproto v0.0.0-20201110150050-8816d57aaa9a/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= google.golang.org/grpc v1.17.0/go.mod h1:6QZJwpn2B+Zp71q/5VxRsJ6NXXVCE5NRUHRo+f3cWCs= google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= @@ -1594,15 +1508,18 @@ google.golang.org/grpc v1.21.0/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ij google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= google.golang.org/grpc v1.22.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= -google.golang.org/grpc v1.23.1 h1:q4XQuHFC6I28BKZpo6IYyb3mNO+l7lSOxRuYTCiDfXk= 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 h1:EC2SB8S04d2r73uptxphDSUG+kTKVgjRPF+N3xpxRB4= google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk= +google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.33.1 h1:DGeFlSan2f+WEtCERJ4J9GJWk15TxUi8QGagfI87Xyc= +google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= +google.golang.org/grpc/examples v0.0.0-20210331235824-f6bb3972ed15 h1:5zzARWGVJhfHEHNuN5Irypt6oKD506IgclKOta6InM0= +google.golang.org/grpc/examples v0.0.0-20210331235824-f6bb3972ed15/go.mod h1:Ly7ZA/ARzg8fnPU9TyZIxoz33sEUuWX7txiqs8lPTgE= 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= @@ -1611,22 +1528,18 @@ google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzi google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= google.golang.org/protobuf v1.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 h1:UhZDfRO8JRQru4/+LlLE0BRKGF8L+PICnvYZmx/fEGA= 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= gopkg.in/AlecAivazis/survey.v1 v1.8.7/go.mod h1:iBNOmqKz/NUbZx3bA+4hAGLRC7fSK7tgtVDT4tB22XA= -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= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= -gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU= gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/cheggaaa/pb.v1 v1.0.25/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 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4= gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys= gopkg.in/gcfg.v1 v1.2.0/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o= gopkg.in/gcfg.v1 v1.2.3/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o= @@ -1639,8 +1552,6 @@ gopkg.in/ini.v1 v1.62.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= gopkg.in/kyokomi/emoji.v1 v1.5.1/go.mod h1:N9AZ6hi1jHOPn34PsbpufQZUcKftSD7WgS2pgpmH4Lg= gopkg.in/mcuadros/go-syslog.v2 v2.2.1/go.mod h1:l5LPIyOOyIdQquNg+oU6Z3524YwrcqEm0aKH+5zpt2U= 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 h1:orlkJ3myw8CN1nVQHBFfloD+L3egixIa4FvUP6RosSA= gopkg.in/square/go-jose.v2 v2.2.2/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI= gopkg.in/src-d/go-billy.v4 v4.2.1/go.mod h1:tm33zBoOwxjYHZIE+OV8bxTWFMJLrconzFMd38aARFk= gopkg.in/src-d/go-git-fixtures.v3 v3.1.1/go.mod h1:dLBcvytrw/TYZsNTWCnkNF2DSIlzWYqTe3rJR56Ac7g= @@ -1649,18 +1560,15 @@ gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkep gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= gopkg.in/warnings.v0 v0.1.1/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI= gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI= -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 h1:obN1ZagJSUGI0Ek/LBmuj4SNLPfIny3KsKFopxRdj10= 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 h1:B0J02caTR6tpSJozBJyiAzT6CtBzjclw4pgm9gg8Ys0= gopkg.in/yaml.v3 v3.0.0-20190905181640-827449938966/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.0-20200605160147-a5ece683394c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ= @@ -1679,7 +1587,6 @@ honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= honnef.co/go/tools v0.0.1-2020.1.5/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= -honnef.co/go/tools v0.0.1-2020.1.6 h1:W18jzjh8mfPez+AwGLxmOImucz/IFjpNlrKVnaj2YVc= honnef.co/go/tools v0.0.1-2020.1.6/go.mod h1:pyyisuGw24ruLjrr1ddx39WE0y9OooInRzEYLhQB2YY= k8s.io/api v0.20.4 h1:xZjKidCirayzX6tHONRQyTNDVIR55TYVqgATqo6ZULY= k8s.io/api v0.20.4/go.mod h1:++lNL1AJMkDymriNniQsWRkMDzRaX2Y/POTUi8yvqYQ= @@ -1713,13 +1620,12 @@ k8s.io/heapster v1.2.0-beta.1/go.mod h1:h1uhptVXMwC8xtZBYsPXKVi8fpdlYkTs6k949Koz 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/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE= -k8s.io/klog/v2 v2.2.0 h1:XRvcwJozkgZ1UQJmfMGpvRthQHOvihEhYtDfAaxMz/A= 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/klog/v2 v2.5.0 h1:8mOnjf1RmUPW6KRqQCfYSZq/K20Unmp3IhuZUhxl8KI= +k8s.io/klog/v2 v2.5.0/go.mod h1:hy9LJ/NvuK+iVyP4Ehqva4HxZG/oXyIS3n3Jmire4Ec= k8s.io/kube-aggregator v0.20.4/go.mod h1:0ixQ9De7KXyHteXizS6nVtrnKqGa4kiuxl9rEBsNccw= k8s.io/kube-controller-manager v0.20.4/go.mod h1:HCVTzFZhw/dtTgfeF2mEUSZZM++poC6qUhNmZ5yRELk= -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/kube-openapi v0.0.0-20210216185858-15cd8face8d6 h1:37dOBBPjjBJGIfD+BlzVcjICVLX6fDDIwt5H1UnhXXM= k8s.io/kube-openapi v0.0.0-20210216185858-15cd8face8d6/go.mod h1:wXW5VT87nVfh/iLV8FpR2uDvrFyomxbtb1KivDbvPTE= @@ -1759,7 +1665,6 @@ sigs.k8s.io/kustomize v2.0.3+incompatible h1:JUufWFNlI44MdtnjUqVnvh29rR37PQFzPbL sigs.k8s.io/kustomize v2.0.3+incompatible/go.mod h1:MkjgH3RdOWrievjo6c9T245dYlB5QeXV4WCbnt/PEpU= sigs.k8s.io/structured-merge-diff/v4 v4.0.2 h1:YHQV7Dajm86OuqnIR6zAelnDWBRjo+YhYV9PmGrh1s8= sigs.k8s.io/structured-merge-diff/v4 v4.0.2/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= -sigs.k8s.io/yaml v1.1.0 h1:4A07+ZFc2wgJwo8YNlQpr1rVlgUDlxXHhPJciaPY5gs= 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/hack/install-codegen-go-tools.sh b/hack/install-codegen-go-tools.sh new file mode 100755 index 0000000000..ddec370479 --- /dev/null +++ b/hack/install-codegen-go-tools.sh @@ -0,0 +1,9 @@ +#!/bin/bash +set -eux -o pipefail + +GO111MODULE=on go get github.com/gogo/protobuf/gogoproto@v1.3.1 +GO111MODULE=on go get sigs.k8s.io/controller-tools/cmd/controller-gen@v0.4.1 +GO111MODULE=on go get github.com/golang/protobuf/protoc-gen-go@v1.4.2 +GO111MODULE=on go get github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway@v1.12.2 +GO111MODULE=on go get github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger@v1.12.2 +GO111MODULE=on go get golang.org/x/tools/cmd/goimports@v0.0.0-20190627203933-19ff4fff8850 \ No newline at end of file diff --git a/hack/tools.go b/hack/tools.go new file mode 100644 index 0000000000..74f2010e40 --- /dev/null +++ b/hack/tools.go @@ -0,0 +1,21 @@ +// +build tools + +package tools + +import ( + _ "github.com/gogo/protobuf/protoc-gen-gogo" + _ "github.com/gogo/protobuf/protoc-gen-gogofast" + _ "github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway" + _ "github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger" + _ "golang.org/x/tools/cmd/goimports" + _ "k8s.io/code-generator/cmd/client-gen" + _ "k8s.io/code-generator/cmd/deepcopy-gen" + _ "k8s.io/code-generator/cmd/defaulter-gen" + _ "k8s.io/code-generator/cmd/go-to-protobuf" + _ "k8s.io/code-generator/cmd/go-to-protobuf/protoc-gen-gogo" + _ "k8s.io/code-generator/cmd/informer-gen" + _ "k8s.io/code-generator/cmd/lister-gen" + _ "k8s.io/code-generator/pkg/util" + _ "k8s.io/code-generator/third_party/forked/golang/reflect" + _ "k8s.io/kube-openapi/cmd/openapi-gen" +) \ No newline at end of file diff --git a/manifests/crds/analysis-run-crd.yaml b/manifests/crds/analysis-run-crd.yaml index e120620f13..fd77bd910b 100644 --- a/manifests/crds/analysis-run-crd.yaml +++ b/manifests/crds/analysis-run-crd.yaml @@ -2300,6 +2300,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2319,6 +2320,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2340,8 +2342,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -2399,6 +2403,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string diff --git a/manifests/crds/analysis-template-crd.yaml b/manifests/crds/analysis-template-crd.yaml index c4758d5bc5..617be0f408 100644 --- a/manifests/crds/analysis-template-crd.yaml +++ b/manifests/crds/analysis-template-crd.yaml @@ -2295,6 +2295,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2314,6 +2315,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2335,8 +2337,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -2394,6 +2398,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string diff --git a/manifests/crds/cluster-analysis-template-crd.yaml b/manifests/crds/cluster-analysis-template-crd.yaml index 8c52a8fa26..5957b9fd57 100644 --- a/manifests/crds/cluster-analysis-template-crd.yaml +++ b/manifests/crds/cluster-analysis-template-crd.yaml @@ -2295,6 +2295,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2314,6 +2315,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2335,8 +2337,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -2394,6 +2398,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string diff --git a/manifests/install.yaml b/manifests/install.yaml index 33be3d7311..13e5dffc93 100644 --- a/manifests/install.yaml +++ b/manifests/install.yaml @@ -2301,6 +2301,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2320,6 +2321,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2341,8 +2343,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -2400,6 +2404,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string @@ -4793,6 +4798,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -4812,6 +4818,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -4833,8 +4840,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -4892,6 +4901,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string @@ -7212,6 +7222,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -7231,6 +7242,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -7252,8 +7264,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -7311,6 +7325,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string diff --git a/manifests/namespace-install.yaml b/manifests/namespace-install.yaml index d559428755..45ac042e1a 100644 --- a/manifests/namespace-install.yaml +++ b/manifests/namespace-install.yaml @@ -2301,6 +2301,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2320,6 +2321,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -2341,8 +2343,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -2400,6 +2404,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string @@ -4793,6 +4798,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -4812,6 +4818,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -4833,8 +4840,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -4892,6 +4901,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string @@ -7212,6 +7222,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -7231,6 +7242,7 @@ spec: start: type: string step: + format: int64 type: integer required: - end @@ -7252,8 +7264,10 @@ spec: threshold: properties: marginal: + format: int64 type: integer pass: + format: int64 type: integer required: - marginal @@ -7311,6 +7325,7 @@ spec: jsonPath: type: string timeoutSeconds: + format: int64 type: integer url: type: string diff --git a/metricproviders/kayenta/kayenta.go b/metricproviders/kayenta/kayenta.go index 4926d66924..e15da1ed3d 100644 --- a/metricproviders/kayenta/kayenta.go +++ b/metricproviders/kayenta/kayenta.go @@ -209,7 +209,7 @@ func (p *Provider) Resume(run *v1alpha1.AnalysisRun, metric v1alpha1.Metric, mea if ok { score := int(result) measurement.Value = fmt.Sprintf("%v", score) - measurement.Phase = evaluateResult(score, metric.Provider.Kayenta.Threshold.Pass, metric.Provider.Kayenta.Threshold.Marginal) + measurement.Phase = evaluateResult(score, int(metric.Provider.Kayenta.Threshold.Pass), int(metric.Provider.Kayenta.Threshold.Marginal)) } else { if err == nil { err = errors.New("Missing Score") diff --git a/mkdocs.yml b/mkdocs.yml index b5263fe5e7..13d41f6f09 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -8,16 +8,16 @@ theme: palette: primary: teal google_analytics: -- UA-105170809-3 -- auto + - UA-105170809-3 + - auto markdown_extensions: -- codehilite -- admonition -- pymdownx.superfences -- pymdownx.tabbed -- footnotes -- toc: - permalink: true + - codehilite + - admonition + - pymdownx.superfences + - pymdownx.tabbed + - footnotes + - toc: + permalink: true nav: - Overview: index.md - Installation: installation.md @@ -28,6 +28,7 @@ nav: - NGINX: getting-started/nginx/index.md - Istio: getting-started/istio/index.md - SMI: getting-started/smi/index.md +- Dashboard: dashboard.md - Rollout: - Deployment Strategies: - BlueGreen: features/bluegreen.md @@ -62,6 +63,7 @@ nav: - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_abort.md - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_create.md - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_create_analysisrun.md + - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_dashboard.md - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_get.md - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_get_experiment.md - generated/kubectl-argo-rollouts/kubectl-argo-rollouts_get_rollout.md diff --git a/pkg/apiclient/rollout/forwarder_overwrite.go b/pkg/apiclient/rollout/forwarder_overwrite.go new file mode 100644 index 0000000000..b79eb6c79d --- /dev/null +++ b/pkg/apiclient/rollout/forwarder_overwrite.go @@ -0,0 +1,10 @@ +package rollout + +import ( + "github.com/argoproj/pkg/grpc/http" +) + +func init() { + forward_RolloutService_WatchRolloutInfos_0 = http.StreamForwarder + forward_RolloutService_WatchRolloutInfo_0 = http.StreamForwarder +} diff --git a/pkg/apiclient/rollout/rollout.pb.go b/pkg/apiclient/rollout/rollout.pb.go new file mode 100644 index 0000000000..d505843bf9 --- /dev/null +++ b/pkg/apiclient/rollout/rollout.pb.go @@ -0,0 +1,7474 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: pkg/apiclient/rollout/rollout.proto + +package rollout + +import ( + context "context" + fmt "fmt" + v1alpha1 "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" + proto "github.com/gogo/protobuf/proto" + empty "github.com/golang/protobuf/ptypes/empty" + _ "google.golang.org/genproto/googleapis/api/annotations" + grpc "google.golang.org/grpc" + codes "google.golang.org/grpc/codes" + status "google.golang.org/grpc/status" + io "io" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +type RolloutInfoQuery struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Namespace string `protobuf:"bytes,2,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RolloutInfoQuery) Reset() { *m = RolloutInfoQuery{} } +func (m *RolloutInfoQuery) String() string { return proto.CompactTextString(m) } +func (*RolloutInfoQuery) ProtoMessage() {} +func (*RolloutInfoQuery) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{0} +} +func (m *RolloutInfoQuery) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutInfoQuery) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RolloutInfoQuery.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RolloutInfoQuery) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutInfoQuery.Merge(m, src) +} +func (m *RolloutInfoQuery) XXX_Size() int { + return m.Size() +} +func (m *RolloutInfoQuery) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutInfoQuery.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutInfoQuery proto.InternalMessageInfo + +func (m *RolloutInfoQuery) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *RolloutInfoQuery) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type RolloutInfoListQuery struct { + Namespace string `protobuf:"bytes,1,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RolloutInfoListQuery) Reset() { *m = RolloutInfoListQuery{} } +func (m *RolloutInfoListQuery) String() string { return proto.CompactTextString(m) } +func (*RolloutInfoListQuery) ProtoMessage() {} +func (*RolloutInfoListQuery) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{1} +} +func (m *RolloutInfoListQuery) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutInfoListQuery) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RolloutInfoListQuery.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RolloutInfoListQuery) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutInfoListQuery.Merge(m, src) +} +func (m *RolloutInfoListQuery) XXX_Size() int { + return m.Size() +} +func (m *RolloutInfoListQuery) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutInfoListQuery.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutInfoListQuery proto.InternalMessageInfo + +func (m *RolloutInfoListQuery) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type SetImageRequest struct { + Rollout string `protobuf:"bytes,1,opt,name=rollout,proto3" json:"rollout,omitempty"` + Container string `protobuf:"bytes,2,opt,name=container,proto3" json:"container,omitempty"` + Image string `protobuf:"bytes,3,opt,name=image,proto3" json:"image,omitempty"` + Tag string `protobuf:"bytes,4,opt,name=tag,proto3" json:"tag,omitempty"` + Namespace string `protobuf:"bytes,5,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *SetImageRequest) Reset() { *m = SetImageRequest{} } +func (m *SetImageRequest) String() string { return proto.CompactTextString(m) } +func (*SetImageRequest) ProtoMessage() {} +func (*SetImageRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{2} +} +func (m *SetImageRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *SetImageRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_SetImageRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *SetImageRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_SetImageRequest.Merge(m, src) +} +func (m *SetImageRequest) XXX_Size() int { + return m.Size() +} +func (m *SetImageRequest) XXX_DiscardUnknown() { + xxx_messageInfo_SetImageRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_SetImageRequest proto.InternalMessageInfo + +func (m *SetImageRequest) GetRollout() string { + if m != nil { + return m.Rollout + } + return "" +} + +func (m *SetImageRequest) GetContainer() string { + if m != nil { + return m.Container + } + return "" +} + +func (m *SetImageRequest) GetImage() string { + if m != nil { + return m.Image + } + return "" +} + +func (m *SetImageRequest) GetTag() string { + if m != nil { + return m.Tag + } + return "" +} + +func (m *SetImageRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type UndoRolloutRequest struct { + Rollout string `protobuf:"bytes,1,opt,name=rollout,proto3" json:"rollout,omitempty"` + Revision int64 `protobuf:"varint,2,opt,name=revision,proto3" json:"revision,omitempty"` + Namespace string `protobuf:"bytes,3,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *UndoRolloutRequest) Reset() { *m = UndoRolloutRequest{} } +func (m *UndoRolloutRequest) String() string { return proto.CompactTextString(m) } +func (*UndoRolloutRequest) ProtoMessage() {} +func (*UndoRolloutRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{3} +} +func (m *UndoRolloutRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *UndoRolloutRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_UndoRolloutRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *UndoRolloutRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_UndoRolloutRequest.Merge(m, src) +} +func (m *UndoRolloutRequest) XXX_Size() int { + return m.Size() +} +func (m *UndoRolloutRequest) XXX_DiscardUnknown() { + xxx_messageInfo_UndoRolloutRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_UndoRolloutRequest proto.InternalMessageInfo + +func (m *UndoRolloutRequest) GetRollout() string { + if m != nil { + return m.Rollout + } + return "" +} + +func (m *UndoRolloutRequest) GetRevision() int64 { + if m != nil { + return m.Revision + } + return 0 +} + +func (m *UndoRolloutRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type RestartRolloutRequest struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Namespace string `protobuf:"bytes,2,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RestartRolloutRequest) Reset() { *m = RestartRolloutRequest{} } +func (m *RestartRolloutRequest) String() string { return proto.CompactTextString(m) } +func (*RestartRolloutRequest) ProtoMessage() {} +func (*RestartRolloutRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{4} +} +func (m *RestartRolloutRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RestartRolloutRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RestartRolloutRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RestartRolloutRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_RestartRolloutRequest.Merge(m, src) +} +func (m *RestartRolloutRequest) XXX_Size() int { + return m.Size() +} +func (m *RestartRolloutRequest) XXX_DiscardUnknown() { + xxx_messageInfo_RestartRolloutRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_RestartRolloutRequest proto.InternalMessageInfo + +func (m *RestartRolloutRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *RestartRolloutRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type PromoteRolloutRequest struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Namespace string `protobuf:"bytes,2,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *PromoteRolloutRequest) Reset() { *m = PromoteRolloutRequest{} } +func (m *PromoteRolloutRequest) String() string { return proto.CompactTextString(m) } +func (*PromoteRolloutRequest) ProtoMessage() {} +func (*PromoteRolloutRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{5} +} +func (m *PromoteRolloutRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PromoteRolloutRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_PromoteRolloutRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *PromoteRolloutRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_PromoteRolloutRequest.Merge(m, src) +} +func (m *PromoteRolloutRequest) XXX_Size() int { + return m.Size() +} +func (m *PromoteRolloutRequest) XXX_DiscardUnknown() { + xxx_messageInfo_PromoteRolloutRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_PromoteRolloutRequest proto.InternalMessageInfo + +func (m *PromoteRolloutRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *PromoteRolloutRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type AbortRolloutRequest struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Namespace string `protobuf:"bytes,2,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *AbortRolloutRequest) Reset() { *m = AbortRolloutRequest{} } +func (m *AbortRolloutRequest) String() string { return proto.CompactTextString(m) } +func (*AbortRolloutRequest) ProtoMessage() {} +func (*AbortRolloutRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{6} +} +func (m *AbortRolloutRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AbortRolloutRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_AbortRolloutRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *AbortRolloutRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_AbortRolloutRequest.Merge(m, src) +} +func (m *AbortRolloutRequest) XXX_Size() int { + return m.Size() +} +func (m *AbortRolloutRequest) XXX_DiscardUnknown() { + xxx_messageInfo_AbortRolloutRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_AbortRolloutRequest proto.InternalMessageInfo + +func (m *AbortRolloutRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *AbortRolloutRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type RetryRolloutRequest struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Namespace string `protobuf:"bytes,2,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RetryRolloutRequest) Reset() { *m = RetryRolloutRequest{} } +func (m *RetryRolloutRequest) String() string { return proto.CompactTextString(m) } +func (*RetryRolloutRequest) ProtoMessage() {} +func (*RetryRolloutRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{7} +} +func (m *RetryRolloutRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RetryRolloutRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RetryRolloutRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RetryRolloutRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_RetryRolloutRequest.Merge(m, src) +} +func (m *RetryRolloutRequest) XXX_Size() int { + return m.Size() +} +func (m *RetryRolloutRequest) XXX_DiscardUnknown() { + xxx_messageInfo_RetryRolloutRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_RetryRolloutRequest proto.InternalMessageInfo + +func (m *RetryRolloutRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *RetryRolloutRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type RolloutWatchEvent struct { + Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` + RolloutInfo *RolloutInfo `protobuf:"bytes,2,opt,name=rolloutInfo,proto3" json:"rolloutInfo,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RolloutWatchEvent) Reset() { *m = RolloutWatchEvent{} } +func (m *RolloutWatchEvent) String() string { return proto.CompactTextString(m) } +func (*RolloutWatchEvent) ProtoMessage() {} +func (*RolloutWatchEvent) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{8} +} +func (m *RolloutWatchEvent) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutWatchEvent) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RolloutWatchEvent.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RolloutWatchEvent) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutWatchEvent.Merge(m, src) +} +func (m *RolloutWatchEvent) XXX_Size() int { + return m.Size() +} +func (m *RolloutWatchEvent) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutWatchEvent.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutWatchEvent proto.InternalMessageInfo + +func (m *RolloutWatchEvent) GetType() string { + if m != nil { + return m.Type + } + return "" +} + +func (m *RolloutWatchEvent) GetRolloutInfo() *RolloutInfo { + if m != nil { + return m.RolloutInfo + } + return nil +} + +type NamespaceInfo struct { + Namespace string `protobuf:"bytes,1,opt,name=namespace,proto3" json:"namespace,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *NamespaceInfo) Reset() { *m = NamespaceInfo{} } +func (m *NamespaceInfo) String() string { return proto.CompactTextString(m) } +func (*NamespaceInfo) ProtoMessage() {} +func (*NamespaceInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{9} +} +func (m *NamespaceInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *NamespaceInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_NamespaceInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *NamespaceInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_NamespaceInfo.Merge(m, src) +} +func (m *NamespaceInfo) XXX_Size() int { + return m.Size() +} +func (m *NamespaceInfo) XXX_DiscardUnknown() { + xxx_messageInfo_NamespaceInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_NamespaceInfo proto.InternalMessageInfo + +func (m *NamespaceInfo) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +type RolloutInfoList struct { + Rollouts []*RolloutInfo `protobuf:"bytes,1,rep,name=rollouts,proto3" json:"rollouts,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RolloutInfoList) Reset() { *m = RolloutInfoList{} } +func (m *RolloutInfoList) String() string { return proto.CompactTextString(m) } +func (*RolloutInfoList) ProtoMessage() {} +func (*RolloutInfoList) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{10} +} +func (m *RolloutInfoList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutInfoList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RolloutInfoList.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RolloutInfoList) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutInfoList.Merge(m, src) +} +func (m *RolloutInfoList) XXX_Size() int { + return m.Size() +} +func (m *RolloutInfoList) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutInfoList.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutInfoList proto.InternalMessageInfo + +func (m *RolloutInfoList) GetRollouts() []*RolloutInfo { + if m != nil { + return m.Rollouts + } + return nil +} + +type VersionInfo struct { + RolloutsVersion string `protobuf:"bytes,1,opt,name=rolloutsVersion,proto3" json:"rolloutsVersion,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *VersionInfo) Reset() { *m = VersionInfo{} } +func (m *VersionInfo) String() string { return proto.CompactTextString(m) } +func (*VersionInfo) ProtoMessage() {} +func (*VersionInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{11} +} +func (m *VersionInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *VersionInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_VersionInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *VersionInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_VersionInfo.Merge(m, src) +} +func (m *VersionInfo) XXX_Size() int { + return m.Size() +} +func (m *VersionInfo) XXX_DiscardUnknown() { + xxx_messageInfo_VersionInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_VersionInfo proto.InternalMessageInfo + +func (m *VersionInfo) GetRolloutsVersion() string { + if m != nil { + return m.RolloutsVersion + } + return "" +} + +type RolloutInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Status string `protobuf:"bytes,2,opt,name=status,proto3" json:"status,omitempty"` + Message string `protobuf:"bytes,3,opt,name=message,proto3" json:"message,omitempty"` + Icon string `protobuf:"bytes,4,opt,name=icon,proto3" json:"icon,omitempty"` + Strategy string `protobuf:"bytes,5,opt,name=strategy,proto3" json:"strategy,omitempty"` + Step string `protobuf:"bytes,6,opt,name=step,proto3" json:"step,omitempty"` + SetWeight string `protobuf:"bytes,7,opt,name=setWeight,proto3" json:"setWeight,omitempty"` + ActualWeight string `protobuf:"bytes,8,opt,name=actualWeight,proto3" json:"actualWeight,omitempty"` + Ready int32 `protobuf:"varint,9,opt,name=ready,proto3" json:"ready,omitempty"` + Current int32 `protobuf:"varint,10,opt,name=current,proto3" json:"current,omitempty"` + Desired int32 `protobuf:"varint,11,opt,name=desired,proto3" json:"desired,omitempty"` + Updated int32 `protobuf:"varint,12,opt,name=updated,proto3" json:"updated,omitempty"` + Available int32 `protobuf:"varint,13,opt,name=available,proto3" json:"available,omitempty"` + RestartedAt string `protobuf:"bytes,14,opt,name=restartedAt,proto3" json:"restartedAt,omitempty"` + Generation string `protobuf:"bytes,15,opt,name=generation,proto3" json:"generation,omitempty"` + ReplicaSets []*ReplicaSetInfo `protobuf:"bytes,16,rep,name=replicaSets,proto3" json:"replicaSets,omitempty"` + Experiments []*ExperimentInfo `protobuf:"bytes,17,rep,name=experiments,proto3" json:"experiments,omitempty"` + AnalysisRuns []*AnalysisRunInfo `protobuf:"bytes,18,rep,name=analysisRuns,proto3" json:"analysisRuns,omitempty"` + Containers []*ContainerInfo `protobuf:"bytes,19,rep,name=containers,proto3" json:"containers,omitempty"` + Steps []*v1alpha1.CanaryStep `protobuf:"bytes,20,rep,name=steps,proto3" json:"steps,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *RolloutInfo) Reset() { *m = RolloutInfo{} } +func (m *RolloutInfo) String() string { return proto.CompactTextString(m) } +func (*RolloutInfo) ProtoMessage() {} +func (*RolloutInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{12} +} +func (m *RolloutInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_RolloutInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *RolloutInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutInfo.Merge(m, src) +} +func (m *RolloutInfo) XXX_Size() int { + return m.Size() +} +func (m *RolloutInfo) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutInfo proto.InternalMessageInfo + +func (m *RolloutInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *RolloutInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *RolloutInfo) GetMessage() string { + if m != nil { + return m.Message + } + return "" +} + +func (m *RolloutInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +func (m *RolloutInfo) GetStrategy() string { + if m != nil { + return m.Strategy + } + return "" +} + +func (m *RolloutInfo) GetStep() string { + if m != nil { + return m.Step + } + return "" +} + +func (m *RolloutInfo) GetSetWeight() string { + if m != nil { + return m.SetWeight + } + return "" +} + +func (m *RolloutInfo) GetActualWeight() string { + if m != nil { + return m.ActualWeight + } + return "" +} + +func (m *RolloutInfo) GetReady() int32 { + if m != nil { + return m.Ready + } + return 0 +} + +func (m *RolloutInfo) GetCurrent() int32 { + if m != nil { + return m.Current + } + return 0 +} + +func (m *RolloutInfo) GetDesired() int32 { + if m != nil { + return m.Desired + } + return 0 +} + +func (m *RolloutInfo) GetUpdated() int32 { + if m != nil { + return m.Updated + } + return 0 +} + +func (m *RolloutInfo) GetAvailable() int32 { + if m != nil { + return m.Available + } + return 0 +} + +func (m *RolloutInfo) GetRestartedAt() string { + if m != nil { + return m.RestartedAt + } + return "" +} + +func (m *RolloutInfo) GetGeneration() string { + if m != nil { + return m.Generation + } + return "" +} + +func (m *RolloutInfo) GetReplicaSets() []*ReplicaSetInfo { + if m != nil { + return m.ReplicaSets + } + return nil +} + +func (m *RolloutInfo) GetExperiments() []*ExperimentInfo { + if m != nil { + return m.Experiments + } + return nil +} + +func (m *RolloutInfo) GetAnalysisRuns() []*AnalysisRunInfo { + if m != nil { + return m.AnalysisRuns + } + return nil +} + +func (m *RolloutInfo) GetContainers() []*ContainerInfo { + if m != nil { + return m.Containers + } + return nil +} + +func (m *RolloutInfo) GetSteps() []*v1alpha1.CanaryStep { + if m != nil { + return m.Steps + } + return nil +} + +type ExperimentInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Icon string `protobuf:"bytes,2,opt,name=icon,proto3" json:"icon,omitempty"` + Revision int32 `protobuf:"varint,3,opt,name=revision,proto3" json:"revision,omitempty"` + Status string `protobuf:"bytes,4,opt,name=status,proto3" json:"status,omitempty"` + Message string `protobuf:"bytes,5,opt,name=message,proto3" json:"message,omitempty"` + ReplicaSets []*ReplicaSetInfo `protobuf:"bytes,6,rep,name=replicaSets,proto3" json:"replicaSets,omitempty"` + AnalysisRuns []*AnalysisRunInfo `protobuf:"bytes,7,rep,name=analysisRuns,proto3" json:"analysisRuns,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ExperimentInfo) Reset() { *m = ExperimentInfo{} } +func (m *ExperimentInfo) String() string { return proto.CompactTextString(m) } +func (*ExperimentInfo) ProtoMessage() {} +func (*ExperimentInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{13} +} +func (m *ExperimentInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_ExperimentInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *ExperimentInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentInfo.Merge(m, src) +} +func (m *ExperimentInfo) XXX_Size() int { + return m.Size() +} +func (m *ExperimentInfo) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentInfo proto.InternalMessageInfo + +func (m *ExperimentInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *ExperimentInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +func (m *ExperimentInfo) GetRevision() int32 { + if m != nil { + return m.Revision + } + return 0 +} + +func (m *ExperimentInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *ExperimentInfo) GetMessage() string { + if m != nil { + return m.Message + } + return "" +} + +func (m *ExperimentInfo) GetReplicaSets() []*ReplicaSetInfo { + if m != nil { + return m.ReplicaSets + } + return nil +} + +func (m *ExperimentInfo) GetAnalysisRuns() []*AnalysisRunInfo { + if m != nil { + return m.AnalysisRuns + } + return nil +} + +type ReplicaSetInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Status string `protobuf:"bytes,2,opt,name=status,proto3" json:"status,omitempty"` + Icon string `protobuf:"bytes,3,opt,name=icon,proto3" json:"icon,omitempty"` + Revision int32 `protobuf:"varint,4,opt,name=revision,proto3" json:"revision,omitempty"` + Stable bool `protobuf:"varint,5,opt,name=stable,proto3" json:"stable,omitempty"` + Canary bool `protobuf:"varint,6,opt,name=canary,proto3" json:"canary,omitempty"` + Active bool `protobuf:"varint,7,opt,name=active,proto3" json:"active,omitempty"` + Preview bool `protobuf:"varint,8,opt,name=preview,proto3" json:"preview,omitempty"` + Replicas int32 `protobuf:"varint,9,opt,name=replicas,proto3" json:"replicas,omitempty"` + Available int32 `protobuf:"varint,10,opt,name=available,proto3" json:"available,omitempty"` + Template string `protobuf:"bytes,11,opt,name=template,proto3" json:"template,omitempty"` + ScaleDownDeadline string `protobuf:"bytes,12,opt,name=scaleDownDeadline,proto3" json:"scaleDownDeadline,omitempty"` + Images []string `protobuf:"bytes,13,rep,name=images,proto3" json:"images,omitempty"` + Pods []*PodInfo `protobuf:"bytes,14,rep,name=pods,proto3" json:"pods,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ReplicaSetInfo) Reset() { *m = ReplicaSetInfo{} } +func (m *ReplicaSetInfo) String() string { return proto.CompactTextString(m) } +func (*ReplicaSetInfo) ProtoMessage() {} +func (*ReplicaSetInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{14} +} +func (m *ReplicaSetInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ReplicaSetInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_ReplicaSetInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *ReplicaSetInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_ReplicaSetInfo.Merge(m, src) +} +func (m *ReplicaSetInfo) XXX_Size() int { + return m.Size() +} +func (m *ReplicaSetInfo) XXX_DiscardUnknown() { + xxx_messageInfo_ReplicaSetInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_ReplicaSetInfo proto.InternalMessageInfo + +func (m *ReplicaSetInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *ReplicaSetInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *ReplicaSetInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +func (m *ReplicaSetInfo) GetRevision() int32 { + if m != nil { + return m.Revision + } + return 0 +} + +func (m *ReplicaSetInfo) GetStable() bool { + if m != nil { + return m.Stable + } + return false +} + +func (m *ReplicaSetInfo) GetCanary() bool { + if m != nil { + return m.Canary + } + return false +} + +func (m *ReplicaSetInfo) GetActive() bool { + if m != nil { + return m.Active + } + return false +} + +func (m *ReplicaSetInfo) GetPreview() bool { + if m != nil { + return m.Preview + } + return false +} + +func (m *ReplicaSetInfo) GetReplicas() int32 { + if m != nil { + return m.Replicas + } + return 0 +} + +func (m *ReplicaSetInfo) GetAvailable() int32 { + if m != nil { + return m.Available + } + return 0 +} + +func (m *ReplicaSetInfo) GetTemplate() string { + if m != nil { + return m.Template + } + return "" +} + +func (m *ReplicaSetInfo) GetScaleDownDeadline() string { + if m != nil { + return m.ScaleDownDeadline + } + return "" +} + +func (m *ReplicaSetInfo) GetImages() []string { + if m != nil { + return m.Images + } + return nil +} + +func (m *ReplicaSetInfo) GetPods() []*PodInfo { + if m != nil { + return m.Pods + } + return nil +} + +type PodInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Status string `protobuf:"bytes,2,opt,name=status,proto3" json:"status,omitempty"` + Icon string `protobuf:"bytes,3,opt,name=icon,proto3" json:"icon,omitempty"` + Ready string `protobuf:"bytes,4,opt,name=ready,proto3" json:"ready,omitempty"` + Restarts int32 `protobuf:"varint,5,opt,name=restarts,proto3" json:"restarts,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *PodInfo) Reset() { *m = PodInfo{} } +func (m *PodInfo) String() string { return proto.CompactTextString(m) } +func (*PodInfo) ProtoMessage() {} +func (*PodInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{15} +} +func (m *PodInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PodInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_PodInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *PodInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_PodInfo.Merge(m, src) +} +func (m *PodInfo) XXX_Size() int { + return m.Size() +} +func (m *PodInfo) XXX_DiscardUnknown() { + xxx_messageInfo_PodInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_PodInfo proto.InternalMessageInfo + +func (m *PodInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *PodInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *PodInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +func (m *PodInfo) GetReady() string { + if m != nil { + return m.Ready + } + return "" +} + +func (m *PodInfo) GetRestarts() int32 { + if m != nil { + return m.Restarts + } + return 0 +} + +type ContainerInfo struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Image string `protobuf:"bytes,2,opt,name=image,proto3" json:"image,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ContainerInfo) Reset() { *m = ContainerInfo{} } +func (m *ContainerInfo) String() string { return proto.CompactTextString(m) } +func (*ContainerInfo) ProtoMessage() {} +func (*ContainerInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{16} +} +func (m *ContainerInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ContainerInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_ContainerInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *ContainerInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_ContainerInfo.Merge(m, src) +} +func (m *ContainerInfo) XXX_Size() int { + return m.Size() +} +func (m *ContainerInfo) XXX_DiscardUnknown() { + xxx_messageInfo_ContainerInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_ContainerInfo proto.InternalMessageInfo + +func (m *ContainerInfo) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *ContainerInfo) GetImage() string { + if m != nil { + return m.Image + } + return "" +} + +type JobInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Status string `protobuf:"bytes,2,opt,name=status,proto3" json:"status,omitempty"` + Icon string `protobuf:"bytes,3,opt,name=icon,proto3" json:"icon,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *JobInfo) Reset() { *m = JobInfo{} } +func (m *JobInfo) String() string { return proto.CompactTextString(m) } +func (*JobInfo) ProtoMessage() {} +func (*JobInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{17} +} +func (m *JobInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *JobInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_JobInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *JobInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_JobInfo.Merge(m, src) +} +func (m *JobInfo) XXX_Size() int { + return m.Size() +} +func (m *JobInfo) XXX_DiscardUnknown() { + xxx_messageInfo_JobInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_JobInfo proto.InternalMessageInfo + +func (m *JobInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *JobInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *JobInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +type AnalysisRunInfo struct { + ObjectMeta *v1.ObjectMeta `protobuf:"bytes,1,opt,name=objectMeta,proto3" json:"objectMeta,omitempty"` + Icon string `protobuf:"bytes,2,opt,name=icon,proto3" json:"icon,omitempty"` + Revision int32 `protobuf:"varint,3,opt,name=revision,proto3" json:"revision,omitempty"` + Status string `protobuf:"bytes,4,opt,name=status,proto3" json:"status,omitempty"` + Successful int32 `protobuf:"varint,5,opt,name=successful,proto3" json:"successful,omitempty"` + Failed int32 `protobuf:"varint,6,opt,name=failed,proto3" json:"failed,omitempty"` + Inconclusive int32 `protobuf:"varint,7,opt,name=inconclusive,proto3" json:"inconclusive,omitempty"` + Error int32 `protobuf:"varint,8,opt,name=error,proto3" json:"error,omitempty"` + Jobs []*JobInfo `protobuf:"bytes,9,rep,name=jobs,proto3" json:"jobs,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *AnalysisRunInfo) Reset() { *m = AnalysisRunInfo{} } +func (m *AnalysisRunInfo) String() string { return proto.CompactTextString(m) } +func (*AnalysisRunInfo) ProtoMessage() {} +func (*AnalysisRunInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_99101d942e8912a7, []int{18} +} +func (m *AnalysisRunInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRunInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_AnalysisRunInfo.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *AnalysisRunInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRunInfo.Merge(m, src) +} +func (m *AnalysisRunInfo) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRunInfo) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRunInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRunInfo proto.InternalMessageInfo + +func (m *AnalysisRunInfo) GetObjectMeta() *v1.ObjectMeta { + if m != nil { + return m.ObjectMeta + } + return nil +} + +func (m *AnalysisRunInfo) GetIcon() string { + if m != nil { + return m.Icon + } + return "" +} + +func (m *AnalysisRunInfo) GetRevision() int32 { + if m != nil { + return m.Revision + } + return 0 +} + +func (m *AnalysisRunInfo) GetStatus() string { + if m != nil { + return m.Status + } + return "" +} + +func (m *AnalysisRunInfo) GetSuccessful() int32 { + if m != nil { + return m.Successful + } + return 0 +} + +func (m *AnalysisRunInfo) GetFailed() int32 { + if m != nil { + return m.Failed + } + return 0 +} + +func (m *AnalysisRunInfo) GetInconclusive() int32 { + if m != nil { + return m.Inconclusive + } + return 0 +} + +func (m *AnalysisRunInfo) GetError() int32 { + if m != nil { + return m.Error + } + return 0 +} + +func (m *AnalysisRunInfo) GetJobs() []*JobInfo { + if m != nil { + return m.Jobs + } + return nil +} + +func init() { + proto.RegisterType((*RolloutInfoQuery)(nil), "rollout.RolloutInfoQuery") + proto.RegisterType((*RolloutInfoListQuery)(nil), "rollout.RolloutInfoListQuery") + proto.RegisterType((*SetImageRequest)(nil), "rollout.SetImageRequest") + proto.RegisterType((*UndoRolloutRequest)(nil), "rollout.UndoRolloutRequest") + proto.RegisterType((*RestartRolloutRequest)(nil), "rollout.RestartRolloutRequest") + proto.RegisterType((*PromoteRolloutRequest)(nil), "rollout.PromoteRolloutRequest") + proto.RegisterType((*AbortRolloutRequest)(nil), "rollout.AbortRolloutRequest") + proto.RegisterType((*RetryRolloutRequest)(nil), "rollout.RetryRolloutRequest") + proto.RegisterType((*RolloutWatchEvent)(nil), "rollout.RolloutWatchEvent") + proto.RegisterType((*NamespaceInfo)(nil), "rollout.NamespaceInfo") + proto.RegisterType((*RolloutInfoList)(nil), "rollout.RolloutInfoList") + proto.RegisterType((*VersionInfo)(nil), "rollout.VersionInfo") + proto.RegisterType((*RolloutInfo)(nil), "rollout.RolloutInfo") + proto.RegisterType((*ExperimentInfo)(nil), "rollout.ExperimentInfo") + proto.RegisterType((*ReplicaSetInfo)(nil), "rollout.ReplicaSetInfo") + proto.RegisterType((*PodInfo)(nil), "rollout.PodInfo") + proto.RegisterType((*ContainerInfo)(nil), "rollout.ContainerInfo") + proto.RegisterType((*JobInfo)(nil), "rollout.JobInfo") + proto.RegisterType((*AnalysisRunInfo)(nil), "rollout.AnalysisRunInfo") +} + +func init() { + proto.RegisterFile("pkg/apiclient/rollout/rollout.proto", fileDescriptor_99101d942e8912a7) +} + +var fileDescriptor_99101d942e8912a7 = []byte{ + // 1550 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xcc, 0x18, 0x4b, 0x6f, 0x1c, 0x45, + 0x53, 0xe3, 0xf5, 0xda, 0xeb, 0x5e, 0x3f, 0xdb, 0x4e, 0x32, 0xd9, 0xe4, 0xb3, 0xfc, 0x4d, 0x3e, + 0xe9, 0x73, 0x0c, 0x99, 0xb1, 0x43, 0xe4, 0x10, 0x1e, 0x07, 0x93, 0x58, 0xc6, 0x28, 0x80, 0x19, + 0x0b, 0x22, 0x38, 0x10, 0xf5, 0xce, 0xb6, 0xd7, 0x93, 0xcc, 0x4e, 0x0f, 0xd3, 0xbd, 0x1b, 0x56, + 0xd6, 0x1e, 0xe0, 0xc2, 0x91, 0x03, 0x3f, 0x02, 0x71, 0xe2, 0xc2, 0x85, 0x03, 0x27, 0x24, 0xc4, + 0x09, 0x21, 0xf1, 0x07, 0x50, 0xc4, 0x85, 0x7f, 0x81, 0xba, 0xa6, 0xa7, 0xe7, 0xe1, 0x75, 0xec, + 0xc8, 0x06, 0x73, 0x9a, 0xa9, 0xaa, 0xae, 0x47, 0x77, 0x3d, 0xba, 0xaa, 0xd1, 0xb5, 0xe8, 0x71, + 0xdb, 0x21, 0x91, 0xef, 0x05, 0x3e, 0x0d, 0x85, 0x13, 0xb3, 0x20, 0x60, 0x5d, 0xfd, 0xb5, 0xa3, + 0x98, 0x09, 0x86, 0xc7, 0x15, 0xd8, 0xb8, 0xda, 0x66, 0xac, 0x1d, 0x50, 0xc9, 0xe0, 0x90, 0x30, + 0x64, 0x82, 0x08, 0x9f, 0x85, 0x3c, 0x59, 0xd6, 0xb8, 0xdf, 0xf6, 0xc5, 0x7e, 0xb7, 0x69, 0x7b, + 0xac, 0xe3, 0x90, 0xb8, 0xcd, 0xa2, 0x98, 0x3d, 0x82, 0x9f, 0x1b, 0x8a, 0x9f, 0x3b, 0x4a, 0x1b, + 0x77, 0x34, 0xa6, 0xb7, 0x46, 0x82, 0x68, 0x9f, 0xac, 0x39, 0x6d, 0x1a, 0xd2, 0x98, 0x08, 0xda, + 0x52, 0xd2, 0x6e, 0x3d, 0x7e, 0x99, 0xdb, 0x3e, 0x93, 0xcb, 0x3b, 0xc4, 0xdb, 0xf7, 0x43, 0x1a, + 0xf7, 0x33, 0xfe, 0x0e, 0x15, 0xc4, 0xe9, 0x1d, 0xe6, 0xba, 0xa2, 0x2c, 0x04, 0xa8, 0xd9, 0xdd, + 0x73, 0x68, 0x27, 0x12, 0xfd, 0x84, 0x68, 0xdd, 0x43, 0xb3, 0x6e, 0xa2, 0x77, 0x3b, 0xdc, 0x63, + 0xef, 0x75, 0x69, 0xdc, 0xc7, 0x18, 0x8d, 0x86, 0xa4, 0x43, 0x4d, 0x63, 0xc9, 0x58, 0x9e, 0x70, + 0xe1, 0x1f, 0x5f, 0x45, 0x13, 0xf2, 0xcb, 0x23, 0xe2, 0x51, 0x73, 0x04, 0x08, 0x19, 0xc2, 0xba, + 0x85, 0x16, 0x72, 0x52, 0xee, 0xfb, 0x5c, 0x24, 0x92, 0x0a, 0x5c, 0x46, 0x99, 0xeb, 0x4b, 0x03, + 0xcd, 0xec, 0x52, 0xb1, 0xdd, 0x21, 0x6d, 0xea, 0xd2, 0x4f, 0xba, 0x94, 0x0b, 0x6c, 0xa2, 0xf4, + 0x64, 0xd5, 0xfa, 0x14, 0x94, 0xb2, 0x3c, 0x16, 0x0a, 0x22, 0x77, 0x9d, 0x5a, 0xa0, 0x11, 0x78, + 0x01, 0x55, 0x7d, 0x29, 0xc7, 0xac, 0x00, 0x25, 0x01, 0xf0, 0x2c, 0xaa, 0x08, 0xd2, 0x36, 0x47, + 0x01, 0x27, 0x7f, 0x8b, 0x16, 0x55, 0xcb, 0x16, 0xed, 0x23, 0xfc, 0x7e, 0xd8, 0x62, 0x6a, 0x2f, + 0xc7, 0xdb, 0xd4, 0x40, 0xb5, 0x98, 0xf6, 0x7c, 0xee, 0xb3, 0x10, 0x4c, 0xaa, 0xb8, 0x1a, 0x2e, + 0x6a, 0xaa, 0x94, 0x35, 0x6d, 0xa3, 0x0b, 0x2e, 0xe5, 0x82, 0xc4, 0xa2, 0xa4, 0xec, 0xf9, 0x0f, + 0x7f, 0x1b, 0x5d, 0xd8, 0x89, 0x59, 0x87, 0x09, 0x7a, 0x6a, 0x51, 0x5b, 0x68, 0x7e, 0xa3, 0xc9, + 0xce, 0xc0, 0xa6, 0x2d, 0x34, 0xef, 0x52, 0x11, 0xf7, 0x4f, 0x2d, 0xe8, 0x21, 0x9a, 0x53, 0x32, + 0x1e, 0x10, 0xe1, 0xed, 0x6f, 0xf6, 0x68, 0x08, 0x62, 0x44, 0x3f, 0xd2, 0x62, 0xe4, 0x3f, 0x5e, + 0x47, 0xf5, 0x38, 0x0b, 0x41, 0x10, 0x54, 0xbf, 0xb9, 0x60, 0xa7, 0x59, 0x9b, 0x0b, 0x4f, 0x37, + 0xbf, 0xd0, 0xba, 0x81, 0xa6, 0xde, 0x49, 0xb5, 0x49, 0xc4, 0x31, 0x31, 0x7b, 0x17, 0xcd, 0x94, + 0x22, 0x1d, 0xaf, 0xa2, 0x5a, 0x9a, 0xba, 0xa6, 0xb1, 0x54, 0x39, 0x52, 0xad, 0x5e, 0x65, 0xdd, + 0x46, 0xf5, 0x0f, 0x68, 0x2c, 0xa3, 0x04, 0x34, 0x2e, 0xa3, 0x99, 0x94, 0xa4, 0xd0, 0x4a, 0x6f, + 0x19, 0x6d, 0x7d, 0x3d, 0x86, 0xea, 0x39, 0x91, 0x78, 0x07, 0x21, 0xd6, 0x7c, 0x44, 0x3d, 0xf1, + 0x36, 0x15, 0x04, 0x98, 0xea, 0x37, 0x57, 0xed, 0xa4, 0x4a, 0xd8, 0xf9, 0x2a, 0x61, 0x47, 0x8f, + 0xdb, 0x12, 0xc1, 0x6d, 0x59, 0x25, 0xec, 0xde, 0x9a, 0xfd, 0xae, 0xe6, 0x73, 0x73, 0x32, 0xf0, + 0x45, 0x34, 0xc6, 0x05, 0x11, 0x5d, 0xae, 0x5c, 0xa1, 0x20, 0x99, 0x03, 0x1d, 0xca, 0x79, 0x96, + 0x61, 0x29, 0x28, 0x9d, 0xe1, 0x7b, 0x2c, 0x54, 0x49, 0x06, 0xff, 0x32, 0x2f, 0xb8, 0x90, 0x35, + 0xa8, 0xdd, 0x57, 0x49, 0xa6, 0x61, 0xb9, 0x9e, 0x0b, 0x1a, 0x99, 0x63, 0xc9, 0x7a, 0xf9, 0x2f, + 0xcf, 0x9c, 0x53, 0xf1, 0x80, 0xfa, 0xed, 0x7d, 0x61, 0x8e, 0x27, 0x67, 0xae, 0x11, 0xd8, 0x42, + 0x93, 0xc4, 0x13, 0x5d, 0x12, 0xa8, 0x05, 0x35, 0x58, 0x50, 0xc0, 0xc9, 0xfc, 0x8f, 0x29, 0x69, + 0xf5, 0xcd, 0x89, 0x25, 0x63, 0xb9, 0xea, 0x26, 0x80, 0xb4, 0xda, 0xeb, 0xc6, 0x31, 0x0d, 0x85, + 0x89, 0x00, 0x9f, 0x82, 0x92, 0xd2, 0xa2, 0xdc, 0x8f, 0x69, 0xcb, 0xac, 0x27, 0x14, 0x05, 0x4a, + 0x4a, 0x37, 0x6a, 0xc9, 0xfa, 0x69, 0x4e, 0x26, 0x14, 0x05, 0x4a, 0x2b, 0x49, 0x8f, 0xf8, 0x01, + 0x69, 0x06, 0xd4, 0x9c, 0x02, 0x5a, 0x86, 0xc0, 0x4b, 0xa8, 0x1e, 0x27, 0x19, 0x4d, 0x5b, 0x1b, + 0xc2, 0x9c, 0x06, 0x23, 0xf3, 0x28, 0xbc, 0x88, 0x90, 0xaa, 0xcd, 0xd2, 0xc5, 0x33, 0xb0, 0x20, + 0x87, 0xc1, 0x77, 0xa4, 0x84, 0x28, 0xf0, 0x3d, 0xb2, 0x4b, 0x05, 0x37, 0x67, 0x21, 0x96, 0x2e, + 0x65, 0xb1, 0xa4, 0x69, 0x2a, 0x8a, 0xb3, 0xb5, 0x92, 0x95, 0x7e, 0x1a, 0xd1, 0xd8, 0xef, 0xd0, + 0x50, 0x70, 0x73, 0xae, 0xc4, 0xba, 0xa9, 0x69, 0x09, 0x6b, 0x6e, 0x2d, 0x7e, 0x0d, 0x4d, 0x92, + 0x90, 0x04, 0x7d, 0xee, 0x73, 0xb7, 0x1b, 0x72, 0x13, 0x03, 0xaf, 0xa9, 0x79, 0x37, 0x32, 0x22, + 0x30, 0x17, 0x56, 0xe3, 0x75, 0x84, 0x74, 0x11, 0xe6, 0xe6, 0x3c, 0xf0, 0x5e, 0xd4, 0xbc, 0x77, + 0x53, 0x12, 0x70, 0xe6, 0x56, 0xe2, 0x8f, 0x51, 0x55, 0x7a, 0x9e, 0x9b, 0x0b, 0xc0, 0xf2, 0xa6, + 0x9d, 0x5d, 0x94, 0x76, 0x7a, 0x51, 0xc2, 0xcf, 0xc3, 0x34, 0x07, 0xb2, 0x10, 0xd6, 0x98, 0xf4, + 0xa2, 0xb4, 0xef, 0x92, 0x90, 0xc4, 0xfd, 0x5d, 0x41, 0x23, 0x37, 0x11, 0x6b, 0xfd, 0x30, 0x82, + 0xa6, 0x8b, 0xbb, 0xfe, 0x1b, 0x92, 0x25, 0x0d, 0xfd, 0x91, 0x62, 0xe8, 0xeb, 0x2b, 0xa1, 0x02, + 0x31, 0x92, 0x5d, 0x09, 0x59, 0x72, 0x8d, 0x1e, 0x95, 0x5c, 0xd5, 0x62, 0x72, 0x95, 0x42, 0x62, + 0xec, 0x39, 0x42, 0xa2, 0xec, 0xd7, 0xf1, 0xe7, 0xf1, 0xab, 0xf5, 0x4b, 0x05, 0x4d, 0x17, 0xa5, + 0xff, 0x83, 0xc5, 0x26, 0x3d, 0xd7, 0xca, 0x11, 0xe7, 0x3a, 0x3a, 0xf4, 0x5c, 0x65, 0x56, 0xca, + 0xe3, 0xab, 0xb9, 0x0a, 0x92, 0x78, 0x0f, 0x22, 0x03, 0x8a, 0x4d, 0xcd, 0x55, 0x90, 0xc4, 0x13, + 0x4f, 0xf8, 0x3d, 0x0a, 0xb5, 0xa6, 0xe6, 0x2a, 0x48, 0xfa, 0x21, 0x92, 0x42, 0xe9, 0x13, 0xa8, + 0x31, 0x35, 0x37, 0x05, 0x13, 0xed, 0x70, 0x1a, 0x5c, 0x55, 0x18, 0x0d, 0x17, 0xcb, 0x02, 0x2a, + 0x97, 0x85, 0x06, 0xaa, 0x09, 0xda, 0x89, 0x02, 0x22, 0x28, 0x54, 0x9a, 0x09, 0x57, 0xc3, 0xf8, + 0x45, 0x34, 0xc7, 0x3d, 0x12, 0xd0, 0x7b, 0xec, 0x49, 0x78, 0x8f, 0x92, 0x56, 0xe0, 0x87, 0x14, + 0x8a, 0xce, 0x84, 0x7b, 0x98, 0x20, 0xad, 0x86, 0xae, 0x86, 0x9b, 0x53, 0x4b, 0x15, 0x79, 0x5a, + 0x09, 0x84, 0xff, 0x87, 0x46, 0x23, 0xd6, 0xe2, 0xe6, 0x34, 0x38, 0x78, 0x56, 0x3b, 0x78, 0x87, + 0xb5, 0xc0, 0xb1, 0x40, 0xb5, 0xbe, 0x37, 0xd0, 0xb8, 0xc2, 0x9c, 0xb3, 0x27, 0x75, 0xa9, 0x4e, + 0x92, 0x40, 0x95, 0x6a, 0x38, 0x61, 0xa8, 0x95, 0x1c, 0xbc, 0x08, 0x27, 0x9c, 0xc0, 0xd6, 0x1d, + 0x34, 0x55, 0xa8, 0x24, 0x43, 0xfb, 0x08, 0xdd, 0x01, 0x8e, 0xe4, 0x3a, 0x40, 0xeb, 0x0b, 0x03, + 0x8d, 0xbf, 0xc5, 0x9a, 0xe7, 0xbf, 0x6d, 0xeb, 0xc7, 0x11, 0x34, 0x53, 0xca, 0xb9, 0x7f, 0x71, + 0x49, 0x5a, 0x44, 0x88, 0x77, 0x3d, 0x8f, 0x72, 0xbe, 0xd7, 0x0d, 0x94, 0x43, 0x72, 0x18, 0xc9, + 0xb7, 0x47, 0xfc, 0x80, 0xb6, 0x20, 0xb5, 0xaa, 0xae, 0x82, 0xe4, 0x5d, 0xed, 0x87, 0x1e, 0x0b, + 0xbd, 0xa0, 0xcb, 0xd3, 0x04, 0xab, 0xba, 0x05, 0x9c, 0xf4, 0x14, 0x8d, 0x63, 0x16, 0x43, 0x92, + 0x55, 0xdd, 0x04, 0x90, 0x61, 0xfc, 0x88, 0x35, 0x65, 0x7a, 0x15, 0xc3, 0x58, 0x79, 0xcf, 0x05, + 0xea, 0xcd, 0x3f, 0xa7, 0xd0, 0xb4, 0xea, 0x80, 0x76, 0x69, 0xdc, 0xf3, 0x3d, 0x8a, 0x39, 0x9a, + 0xde, 0xa2, 0x22, 0xdf, 0x16, 0x5d, 0x1e, 0xd6, 0x7f, 0xc1, 0x44, 0xd2, 0x18, 0xda, 0x9a, 0x59, + 0xab, 0x9f, 0xff, 0xf6, 0xc7, 0x57, 0x23, 0x2b, 0x78, 0x19, 0xc6, 0xb8, 0xde, 0x5a, 0x36, 0x8b, + 0x1d, 0xe8, 0xd6, 0x6f, 0x90, 0xfc, 0x0f, 0x1c, 0x5f, 0xaa, 0x18, 0xa0, 0x59, 0x68, 0x48, 0x4f, + 0xa5, 0x76, 0x1d, 0xd4, 0xae, 0x62, 0xfb, 0xa4, 0x6a, 0x9d, 0x27, 0x52, 0xe7, 0xaa, 0x81, 0x7b, + 0x68, 0x56, 0xf6, 0x9e, 0x39, 0x61, 0x1c, 0xff, 0x67, 0x98, 0x0e, 0x3d, 0x8b, 0x35, 0xcc, 0xa3, + 0xc8, 0xd6, 0x75, 0x30, 0xe3, 0x1a, 0xfe, 0xef, 0x33, 0xcd, 0x80, 0x6d, 0x7f, 0x66, 0xa0, 0xb9, + 0xf2, 0xbe, 0x8f, 0xd5, 0xdc, 0x28, 0x93, 0xb3, 0x56, 0xde, 0x72, 0x40, 0xf7, 0x75, 0xfc, 0xff, + 0x63, 0x75, 0xeb, 0xbd, 0x7f, 0x88, 0x26, 0xb7, 0xa8, 0xd0, 0x4d, 0x3b, 0xbe, 0x68, 0x27, 0x03, + 0xae, 0x9d, 0x0e, 0xb8, 0xf6, 0xa6, 0x1c, 0x70, 0x1b, 0x59, 0x1b, 0x52, 0x68, 0xf0, 0xad, 0xcb, + 0xa0, 0x72, 0x1e, 0xcf, 0xa5, 0x2a, 0xb5, 0x22, 0xfc, 0xad, 0x21, 0x6f, 0xbd, 0xfc, 0x58, 0x86, + 0x17, 0x73, 0x97, 0xed, 0x90, 0x79, 0xad, 0xb1, 0x79, 0xba, 0xce, 0x45, 0x49, 0x4b, 0x43, 0xa1, + 0xf1, 0xc2, 0x49, 0x42, 0x41, 0x15, 0xc6, 0x57, 0x8c, 0x15, 0xb0, 0xb8, 0x38, 0xfd, 0xe5, 0x2c, + 0x1e, 0x3a, 0x16, 0x9e, 0x8b, 0xc5, 0x51, 0x62, 0x89, 0xb4, 0xf8, 0x1b, 0x03, 0x4d, 0xe6, 0x87, + 0x4c, 0x7c, 0x35, 0x6b, 0x49, 0x0e, 0xcf, 0x9e, 0x67, 0x65, 0xed, 0x2d, 0xb0, 0xd6, 0x6e, 0x5c, + 0x3f, 0x89, 0xb5, 0x44, 0xda, 0x21, 0x6d, 0xfd, 0x29, 0x79, 0xa1, 0x48, 0xa3, 0x1a, 0xde, 0x14, + 0xb2, 0x3c, 0x2a, 0xbd, 0x5d, 0x9c, 0x95, 0xa9, 0x2e, 0x98, 0x7a, 0xbf, 0xb1, 0xf5, 0x6c, 0x53, + 0x15, 0x76, 0xe0, 0x70, 0x2a, 0x9c, 0x03, 0xdd, 0x5a, 0x0f, 0x9c, 0x03, 0xb8, 0xf9, 0x5e, 0x5f, + 0x59, 0x19, 0x38, 0x07, 0x82, 0xb4, 0x07, 0x72, 0x23, 0xdf, 0x19, 0xa8, 0x9e, 0x7b, 0xd9, 0xc0, + 0x57, 0xf4, 0x26, 0x0e, 0xbf, 0x77, 0x9c, 0xd5, 0x3e, 0x36, 0x60, 0x1f, 0xaf, 0x36, 0xd6, 0x4f, + 0xb8, 0x8f, 0x6e, 0xd8, 0x62, 0xce, 0x41, 0x7a, 0x33, 0x0d, 0xd2, 0x58, 0xc9, 0xbf, 0x23, 0xe4, + 0x62, 0x65, 0xc8, 0xf3, 0xc2, 0xb9, 0xc4, 0x4a, 0x2c, 0xed, 0x90, 0xb6, 0xee, 0xa0, 0x71, 0x35, + 0xa6, 0x1f, 0x59, 0x91, 0xb2, 0x5b, 0x20, 0x37, 0xfe, 0x5b, 0x97, 0x40, 0xdd, 0x1c, 0x9e, 0x49, + 0xd5, 0xf5, 0x12, 0xe2, 0x1b, 0x9b, 0x3f, 0x3f, 0x5d, 0x34, 0x7e, 0x7d, 0xba, 0x68, 0xfc, 0xfe, + 0x74, 0xd1, 0xf8, 0xe8, 0xf6, 0x89, 0x9f, 0x12, 0x8b, 0x0f, 0x97, 0xcd, 0x31, 0xb0, 0xe2, 0xa5, + 0xbf, 0x02, 0x00, 0x00, 0xff, 0xff, 0xe3, 0xf7, 0x99, 0x17, 0xd8, 0x14, 0x00, 0x00, +} + +// Reference imports to suppress errors if they are not otherwise used. +var _ context.Context +var _ grpc.ClientConn + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion4 + +// RolloutServiceClient is the client API for RolloutService service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. +type RolloutServiceClient interface { + GetRolloutInfo(ctx context.Context, in *RolloutInfoQuery, opts ...grpc.CallOption) (*RolloutInfo, error) + WatchRolloutInfo(ctx context.Context, in *RolloutInfoQuery, opts ...grpc.CallOption) (RolloutService_WatchRolloutInfoClient, error) + ListRolloutInfos(ctx context.Context, in *RolloutInfoListQuery, opts ...grpc.CallOption) (*RolloutInfoList, error) + WatchRolloutInfos(ctx context.Context, in *RolloutInfoListQuery, opts ...grpc.CallOption) (RolloutService_WatchRolloutInfosClient, error) + GetNamespace(ctx context.Context, in *empty.Empty, opts ...grpc.CallOption) (*NamespaceInfo, error) + RestartRollout(ctx context.Context, in *RestartRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + PromoteRollout(ctx context.Context, in *PromoteRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + AbortRollout(ctx context.Context, in *AbortRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + SetRolloutImage(ctx context.Context, in *SetImageRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + UndoRollout(ctx context.Context, in *UndoRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + RetryRollout(ctx context.Context, in *RetryRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) + Version(ctx context.Context, in *empty.Empty, opts ...grpc.CallOption) (*VersionInfo, error) +} + +type rolloutServiceClient struct { + cc *grpc.ClientConn +} + +func NewRolloutServiceClient(cc *grpc.ClientConn) RolloutServiceClient { + return &rolloutServiceClient{cc} +} + +func (c *rolloutServiceClient) GetRolloutInfo(ctx context.Context, in *RolloutInfoQuery, opts ...grpc.CallOption) (*RolloutInfo, error) { + out := new(RolloutInfo) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/GetRolloutInfo", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) WatchRolloutInfo(ctx context.Context, in *RolloutInfoQuery, opts ...grpc.CallOption) (RolloutService_WatchRolloutInfoClient, error) { + stream, err := c.cc.NewStream(ctx, &_RolloutService_serviceDesc.Streams[0], "/rollout.RolloutService/WatchRolloutInfo", opts...) + if err != nil { + return nil, err + } + x := &rolloutServiceWatchRolloutInfoClient{stream} + if err := x.ClientStream.SendMsg(in); err != nil { + return nil, err + } + if err := x.ClientStream.CloseSend(); err != nil { + return nil, err + } + return x, nil +} + +type RolloutService_WatchRolloutInfoClient interface { + Recv() (*RolloutInfo, error) + grpc.ClientStream +} + +type rolloutServiceWatchRolloutInfoClient struct { + grpc.ClientStream +} + +func (x *rolloutServiceWatchRolloutInfoClient) Recv() (*RolloutInfo, error) { + m := new(RolloutInfo) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +func (c *rolloutServiceClient) ListRolloutInfos(ctx context.Context, in *RolloutInfoListQuery, opts ...grpc.CallOption) (*RolloutInfoList, error) { + out := new(RolloutInfoList) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/ListRolloutInfos", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) WatchRolloutInfos(ctx context.Context, in *RolloutInfoListQuery, opts ...grpc.CallOption) (RolloutService_WatchRolloutInfosClient, error) { + stream, err := c.cc.NewStream(ctx, &_RolloutService_serviceDesc.Streams[1], "/rollout.RolloutService/WatchRolloutInfos", opts...) + if err != nil { + return nil, err + } + x := &rolloutServiceWatchRolloutInfosClient{stream} + if err := x.ClientStream.SendMsg(in); err != nil { + return nil, err + } + if err := x.ClientStream.CloseSend(); err != nil { + return nil, err + } + return x, nil +} + +type RolloutService_WatchRolloutInfosClient interface { + Recv() (*RolloutWatchEvent, error) + grpc.ClientStream +} + +type rolloutServiceWatchRolloutInfosClient struct { + grpc.ClientStream +} + +func (x *rolloutServiceWatchRolloutInfosClient) Recv() (*RolloutWatchEvent, error) { + m := new(RolloutWatchEvent) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +func (c *rolloutServiceClient) GetNamespace(ctx context.Context, in *empty.Empty, opts ...grpc.CallOption) (*NamespaceInfo, error) { + out := new(NamespaceInfo) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/GetNamespace", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) RestartRollout(ctx context.Context, in *RestartRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/RestartRollout", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) PromoteRollout(ctx context.Context, in *PromoteRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/PromoteRollout", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) AbortRollout(ctx context.Context, in *AbortRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/AbortRollout", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) SetRolloutImage(ctx context.Context, in *SetImageRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/SetRolloutImage", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) UndoRollout(ctx context.Context, in *UndoRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/UndoRollout", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) RetryRollout(ctx context.Context, in *RetryRolloutRequest, opts ...grpc.CallOption) (*v1alpha1.Rollout, error) { + out := new(v1alpha1.Rollout) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/RetryRollout", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *rolloutServiceClient) Version(ctx context.Context, in *empty.Empty, opts ...grpc.CallOption) (*VersionInfo, error) { + out := new(VersionInfo) + err := c.cc.Invoke(ctx, "/rollout.RolloutService/Version", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// RolloutServiceServer is the server API for RolloutService service. +type RolloutServiceServer interface { + GetRolloutInfo(context.Context, *RolloutInfoQuery) (*RolloutInfo, error) + WatchRolloutInfo(*RolloutInfoQuery, RolloutService_WatchRolloutInfoServer) error + ListRolloutInfos(context.Context, *RolloutInfoListQuery) (*RolloutInfoList, error) + WatchRolloutInfos(*RolloutInfoListQuery, RolloutService_WatchRolloutInfosServer) error + GetNamespace(context.Context, *empty.Empty) (*NamespaceInfo, error) + RestartRollout(context.Context, *RestartRolloutRequest) (*v1alpha1.Rollout, error) + PromoteRollout(context.Context, *PromoteRolloutRequest) (*v1alpha1.Rollout, error) + AbortRollout(context.Context, *AbortRolloutRequest) (*v1alpha1.Rollout, error) + SetRolloutImage(context.Context, *SetImageRequest) (*v1alpha1.Rollout, error) + UndoRollout(context.Context, *UndoRolloutRequest) (*v1alpha1.Rollout, error) + RetryRollout(context.Context, *RetryRolloutRequest) (*v1alpha1.Rollout, error) + Version(context.Context, *empty.Empty) (*VersionInfo, error) +} + +// UnimplementedRolloutServiceServer can be embedded to have forward compatible implementations. +type UnimplementedRolloutServiceServer struct { +} + +func (*UnimplementedRolloutServiceServer) GetRolloutInfo(ctx context.Context, req *RolloutInfoQuery) (*RolloutInfo, error) { + return nil, status.Errorf(codes.Unimplemented, "method GetRolloutInfo not implemented") +} +func (*UnimplementedRolloutServiceServer) WatchRolloutInfo(req *RolloutInfoQuery, srv RolloutService_WatchRolloutInfoServer) error { + return status.Errorf(codes.Unimplemented, "method WatchRolloutInfo not implemented") +} +func (*UnimplementedRolloutServiceServer) ListRolloutInfos(ctx context.Context, req *RolloutInfoListQuery) (*RolloutInfoList, error) { + return nil, status.Errorf(codes.Unimplemented, "method ListRolloutInfos not implemented") +} +func (*UnimplementedRolloutServiceServer) WatchRolloutInfos(req *RolloutInfoListQuery, srv RolloutService_WatchRolloutInfosServer) error { + return status.Errorf(codes.Unimplemented, "method WatchRolloutInfos not implemented") +} +func (*UnimplementedRolloutServiceServer) GetNamespace(ctx context.Context, req *empty.Empty) (*NamespaceInfo, error) { + return nil, status.Errorf(codes.Unimplemented, "method GetNamespace not implemented") +} +func (*UnimplementedRolloutServiceServer) RestartRollout(ctx context.Context, req *RestartRolloutRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method RestartRollout not implemented") +} +func (*UnimplementedRolloutServiceServer) PromoteRollout(ctx context.Context, req *PromoteRolloutRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method PromoteRollout not implemented") +} +func (*UnimplementedRolloutServiceServer) AbortRollout(ctx context.Context, req *AbortRolloutRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method AbortRollout not implemented") +} +func (*UnimplementedRolloutServiceServer) SetRolloutImage(ctx context.Context, req *SetImageRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method SetRolloutImage not implemented") +} +func (*UnimplementedRolloutServiceServer) UndoRollout(ctx context.Context, req *UndoRolloutRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method UndoRollout not implemented") +} +func (*UnimplementedRolloutServiceServer) RetryRollout(ctx context.Context, req *RetryRolloutRequest) (*v1alpha1.Rollout, error) { + return nil, status.Errorf(codes.Unimplemented, "method RetryRollout not implemented") +} +func (*UnimplementedRolloutServiceServer) Version(ctx context.Context, req *empty.Empty) (*VersionInfo, error) { + return nil, status.Errorf(codes.Unimplemented, "method Version not implemented") +} + +func RegisterRolloutServiceServer(s *grpc.Server, srv RolloutServiceServer) { + s.RegisterService(&_RolloutService_serviceDesc, srv) +} + +func _RolloutService_GetRolloutInfo_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(RolloutInfoQuery) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).GetRolloutInfo(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/GetRolloutInfo", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).GetRolloutInfo(ctx, req.(*RolloutInfoQuery)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_WatchRolloutInfo_Handler(srv interface{}, stream grpc.ServerStream) error { + m := new(RolloutInfoQuery) + if err := stream.RecvMsg(m); err != nil { + return err + } + return srv.(RolloutServiceServer).WatchRolloutInfo(m, &rolloutServiceWatchRolloutInfoServer{stream}) +} + +type RolloutService_WatchRolloutInfoServer interface { + Send(*RolloutInfo) error + grpc.ServerStream +} + +type rolloutServiceWatchRolloutInfoServer struct { + grpc.ServerStream +} + +func (x *rolloutServiceWatchRolloutInfoServer) Send(m *RolloutInfo) error { + return x.ServerStream.SendMsg(m) +} + +func _RolloutService_ListRolloutInfos_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(RolloutInfoListQuery) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).ListRolloutInfos(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/ListRolloutInfos", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).ListRolloutInfos(ctx, req.(*RolloutInfoListQuery)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_WatchRolloutInfos_Handler(srv interface{}, stream grpc.ServerStream) error { + m := new(RolloutInfoListQuery) + if err := stream.RecvMsg(m); err != nil { + return err + } + return srv.(RolloutServiceServer).WatchRolloutInfos(m, &rolloutServiceWatchRolloutInfosServer{stream}) +} + +type RolloutService_WatchRolloutInfosServer interface { + Send(*RolloutWatchEvent) error + grpc.ServerStream +} + +type rolloutServiceWatchRolloutInfosServer struct { + grpc.ServerStream +} + +func (x *rolloutServiceWatchRolloutInfosServer) Send(m *RolloutWatchEvent) error { + return x.ServerStream.SendMsg(m) +} + +func _RolloutService_GetNamespace_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(empty.Empty) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).GetNamespace(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/GetNamespace", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).GetNamespace(ctx, req.(*empty.Empty)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_RestartRollout_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(RestartRolloutRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).RestartRollout(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/RestartRollout", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).RestartRollout(ctx, req.(*RestartRolloutRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_PromoteRollout_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(PromoteRolloutRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).PromoteRollout(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/PromoteRollout", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).PromoteRollout(ctx, req.(*PromoteRolloutRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_AbortRollout_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(AbortRolloutRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).AbortRollout(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/AbortRollout", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).AbortRollout(ctx, req.(*AbortRolloutRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_SetRolloutImage_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(SetImageRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).SetRolloutImage(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/SetRolloutImage", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).SetRolloutImage(ctx, req.(*SetImageRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_UndoRollout_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(UndoRolloutRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).UndoRollout(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/UndoRollout", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).UndoRollout(ctx, req.(*UndoRolloutRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_RetryRollout_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(RetryRolloutRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).RetryRollout(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/RetryRollout", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).RetryRollout(ctx, req.(*RetryRolloutRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _RolloutService_Version_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(empty.Empty) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(RolloutServiceServer).Version(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/rollout.RolloutService/Version", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(RolloutServiceServer).Version(ctx, req.(*empty.Empty)) + } + return interceptor(ctx, in, info, handler) +} + +var _RolloutService_serviceDesc = grpc.ServiceDesc{ + ServiceName: "rollout.RolloutService", + HandlerType: (*RolloutServiceServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "GetRolloutInfo", + Handler: _RolloutService_GetRolloutInfo_Handler, + }, + { + MethodName: "ListRolloutInfos", + Handler: _RolloutService_ListRolloutInfos_Handler, + }, + { + MethodName: "GetNamespace", + Handler: _RolloutService_GetNamespace_Handler, + }, + { + MethodName: "RestartRollout", + Handler: _RolloutService_RestartRollout_Handler, + }, + { + MethodName: "PromoteRollout", + Handler: _RolloutService_PromoteRollout_Handler, + }, + { + MethodName: "AbortRollout", + Handler: _RolloutService_AbortRollout_Handler, + }, + { + MethodName: "SetRolloutImage", + Handler: _RolloutService_SetRolloutImage_Handler, + }, + { + MethodName: "UndoRollout", + Handler: _RolloutService_UndoRollout_Handler, + }, + { + MethodName: "RetryRollout", + Handler: _RolloutService_RetryRollout_Handler, + }, + { + MethodName: "Version", + Handler: _RolloutService_Version_Handler, + }, + }, + Streams: []grpc.StreamDesc{ + { + StreamName: "WatchRolloutInfo", + Handler: _RolloutService_WatchRolloutInfo_Handler, + ServerStreams: true, + }, + { + StreamName: "WatchRolloutInfos", + Handler: _RolloutService_WatchRolloutInfos_Handler, + ServerStreams: true, + }, + }, + Metadata: "pkg/apiclient/rollout/rollout.proto", +} + +func (m *RolloutInfoQuery) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutInfoQuery) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutInfoQuery) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutInfoListQuery) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutInfoListQuery) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutInfoListQuery) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *SetImageRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *SetImageRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *SetImageRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x2a + } + if len(m.Tag) > 0 { + i -= len(m.Tag) + copy(dAtA[i:], m.Tag) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Tag))) + i-- + dAtA[i] = 0x22 + } + if len(m.Image) > 0 { + i -= len(m.Image) + copy(dAtA[i:], m.Image) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Image))) + i-- + dAtA[i] = 0x1a + } + if len(m.Container) > 0 { + i -= len(m.Container) + copy(dAtA[i:], m.Container) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Container))) + i-- + dAtA[i] = 0x12 + } + if len(m.Rollout) > 0 { + i -= len(m.Rollout) + copy(dAtA[i:], m.Rollout) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Rollout))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *UndoRolloutRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *UndoRolloutRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *UndoRolloutRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x1a + } + if m.Revision != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Revision)) + i-- + dAtA[i] = 0x10 + } + if len(m.Rollout) > 0 { + i -= len(m.Rollout) + copy(dAtA[i:], m.Rollout) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Rollout))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RestartRolloutRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RestartRolloutRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RestartRolloutRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *PromoteRolloutRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PromoteRolloutRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PromoteRolloutRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *AbortRolloutRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AbortRolloutRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AbortRolloutRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RetryRolloutRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RetryRolloutRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RetryRolloutRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutWatchEvent) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutWatchEvent) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutWatchEvent) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if m.RolloutInfo != nil { + { + size, err := m.RolloutInfo.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if len(m.Type) > 0 { + i -= len(m.Type) + copy(dAtA[i:], m.Type) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Type))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *NamespaceInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *NamespaceInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *NamespaceInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Namespace) > 0 { + i -= len(m.Namespace) + copy(dAtA[i:], m.Namespace) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Namespace))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutInfoList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutInfoList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutInfoList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Rollouts) > 0 { + for iNdEx := len(m.Rollouts) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Rollouts[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *VersionInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *VersionInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *VersionInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.RolloutsVersion) > 0 { + i -= len(m.RolloutsVersion) + copy(dAtA[i:], m.RolloutsVersion) + i = encodeVarintRollout(dAtA, i, uint64(len(m.RolloutsVersion))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Steps) > 0 { + for iNdEx := len(m.Steps) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Steps[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0xa2 + } + } + if len(m.Containers) > 0 { + for iNdEx := len(m.Containers) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Containers[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x9a + } + } + if len(m.AnalysisRuns) > 0 { + for iNdEx := len(m.AnalysisRuns) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.AnalysisRuns[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x92 + } + } + if len(m.Experiments) > 0 { + for iNdEx := len(m.Experiments) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Experiments[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x8a + } + } + if len(m.ReplicaSets) > 0 { + for iNdEx := len(m.ReplicaSets) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.ReplicaSets[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x82 + } + } + if len(m.Generation) > 0 { + i -= len(m.Generation) + copy(dAtA[i:], m.Generation) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Generation))) + i-- + dAtA[i] = 0x7a + } + if len(m.RestartedAt) > 0 { + i -= len(m.RestartedAt) + copy(dAtA[i:], m.RestartedAt) + i = encodeVarintRollout(dAtA, i, uint64(len(m.RestartedAt))) + i-- + dAtA[i] = 0x72 + } + if m.Available != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Available)) + i-- + dAtA[i] = 0x68 + } + if m.Updated != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Updated)) + i-- + dAtA[i] = 0x60 + } + if m.Desired != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Desired)) + i-- + dAtA[i] = 0x58 + } + if m.Current != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Current)) + i-- + dAtA[i] = 0x50 + } + if m.Ready != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Ready)) + i-- + dAtA[i] = 0x48 + } + if len(m.ActualWeight) > 0 { + i -= len(m.ActualWeight) + copy(dAtA[i:], m.ActualWeight) + i = encodeVarintRollout(dAtA, i, uint64(len(m.ActualWeight))) + i-- + dAtA[i] = 0x42 + } + if len(m.SetWeight) > 0 { + i -= len(m.SetWeight) + copy(dAtA[i:], m.SetWeight) + i = encodeVarintRollout(dAtA, i, uint64(len(m.SetWeight))) + i-- + dAtA[i] = 0x3a + } + if len(m.Step) > 0 { + i -= len(m.Step) + copy(dAtA[i:], m.Step) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Step))) + i-- + dAtA[i] = 0x32 + } + if len(m.Strategy) > 0 { + i -= len(m.Strategy) + copy(dAtA[i:], m.Strategy) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Strategy))) + i-- + dAtA[i] = 0x2a + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x22 + } + if len(m.Message) > 0 { + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x1a + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *ExperimentInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.AnalysisRuns) > 0 { + for iNdEx := len(m.AnalysisRuns) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.AnalysisRuns[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } + } + if len(m.ReplicaSets) > 0 { + for iNdEx := len(m.ReplicaSets) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.ReplicaSets[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x32 + } + } + if len(m.Message) > 0 { + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x2a + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x22 + } + if m.Revision != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Revision)) + i-- + dAtA[i] = 0x18 + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *ReplicaSetInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ReplicaSetInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ReplicaSetInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Pods) > 0 { + for iNdEx := len(m.Pods) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Pods[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x72 + } + } + if len(m.Images) > 0 { + for iNdEx := len(m.Images) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Images[iNdEx]) + copy(dAtA[i:], m.Images[iNdEx]) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Images[iNdEx]))) + i-- + dAtA[i] = 0x6a + } + } + if len(m.ScaleDownDeadline) > 0 { + i -= len(m.ScaleDownDeadline) + copy(dAtA[i:], m.ScaleDownDeadline) + i = encodeVarintRollout(dAtA, i, uint64(len(m.ScaleDownDeadline))) + i-- + dAtA[i] = 0x62 + } + if len(m.Template) > 0 { + i -= len(m.Template) + copy(dAtA[i:], m.Template) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Template))) + i-- + dAtA[i] = 0x5a + } + if m.Available != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Available)) + i-- + dAtA[i] = 0x50 + } + if m.Replicas != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Replicas)) + i-- + dAtA[i] = 0x48 + } + if m.Preview { + i-- + if m.Preview { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x40 + } + if m.Active { + i-- + if m.Active { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x38 + } + if m.Canary { + i-- + if m.Canary { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x30 + } + if m.Stable { + i-- + if m.Stable { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x28 + } + if m.Revision != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Revision)) + i-- + dAtA[i] = 0x20 + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x1a + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *PodInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PodInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PodInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if m.Restarts != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Restarts)) + i-- + dAtA[i] = 0x28 + } + if len(m.Ready) > 0 { + i -= len(m.Ready) + copy(dAtA[i:], m.Ready) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Ready))) + i-- + dAtA[i] = 0x22 + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x1a + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *ContainerInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ContainerInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ContainerInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Image) > 0 { + i -= len(m.Image) + copy(dAtA[i:], m.Image) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Image))) + i-- + dAtA[i] = 0x12 + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *JobInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *JobInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *JobInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x1a + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *AnalysisRunInfo) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRunInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRunInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.Jobs) > 0 { + for iNdEx := len(m.Jobs) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Jobs[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + } + if m.Error != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Error)) + i-- + dAtA[i] = 0x40 + } + if m.Inconclusive != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Inconclusive)) + i-- + dAtA[i] = 0x38 + } + if m.Failed != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Failed)) + i-- + dAtA[i] = 0x30 + } + if m.Successful != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Successful)) + i-- + dAtA[i] = 0x28 + } + if len(m.Status) > 0 { + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x22 + } + if m.Revision != 0 { + i = encodeVarintRollout(dAtA, i, uint64(m.Revision)) + i-- + dAtA[i] = 0x18 + } + if len(m.Icon) > 0 { + i -= len(m.Icon) + copy(dAtA[i:], m.Icon) + i = encodeVarintRollout(dAtA, i, uint64(len(m.Icon))) + i-- + dAtA[i] = 0x12 + } + if m.ObjectMeta != nil { + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintRollout(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func encodeVarintRollout(dAtA []byte, offset int, v uint64) int { + offset -= sovRollout(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *RolloutInfoQuery) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RolloutInfoListQuery) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *SetImageRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Rollout) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Container) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Image) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Tag) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *UndoRolloutRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Rollout) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Revision != 0 { + n += 1 + sovRollout(uint64(m.Revision)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RestartRolloutRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *PromoteRolloutRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *AbortRolloutRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RetryRolloutRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RolloutWatchEvent) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Type) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.RolloutInfo != nil { + l = m.RolloutInfo.Size() + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *NamespaceInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Namespace) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RolloutInfoList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Rollouts) > 0 { + for _, e := range m.Rollouts { + l = e.Size() + n += 1 + l + sovRollout(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *VersionInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.RolloutsVersion) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *RolloutInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Message) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Strategy) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Step) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.SetWeight) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.ActualWeight) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Ready != 0 { + n += 1 + sovRollout(uint64(m.Ready)) + } + if m.Current != 0 { + n += 1 + sovRollout(uint64(m.Current)) + } + if m.Desired != 0 { + n += 1 + sovRollout(uint64(m.Desired)) + } + if m.Updated != 0 { + n += 1 + sovRollout(uint64(m.Updated)) + } + if m.Available != 0 { + n += 1 + sovRollout(uint64(m.Available)) + } + l = len(m.RestartedAt) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Generation) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if len(m.ReplicaSets) > 0 { + for _, e := range m.ReplicaSets { + l = e.Size() + n += 2 + l + sovRollout(uint64(l)) + } + } + if len(m.Experiments) > 0 { + for _, e := range m.Experiments { + l = e.Size() + n += 2 + l + sovRollout(uint64(l)) + } + } + if len(m.AnalysisRuns) > 0 { + for _, e := range m.AnalysisRuns { + l = e.Size() + n += 2 + l + sovRollout(uint64(l)) + } + } + if len(m.Containers) > 0 { + for _, e := range m.Containers { + l = e.Size() + n += 2 + l + sovRollout(uint64(l)) + } + } + if len(m.Steps) > 0 { + for _, e := range m.Steps { + l = e.Size() + n += 2 + l + sovRollout(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *ExperimentInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Revision != 0 { + n += 1 + sovRollout(uint64(m.Revision)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Message) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if len(m.ReplicaSets) > 0 { + for _, e := range m.ReplicaSets { + l = e.Size() + n += 1 + l + sovRollout(uint64(l)) + } + } + if len(m.AnalysisRuns) > 0 { + for _, e := range m.AnalysisRuns { + l = e.Size() + n += 1 + l + sovRollout(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *ReplicaSetInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Revision != 0 { + n += 1 + sovRollout(uint64(m.Revision)) + } + if m.Stable { + n += 2 + } + if m.Canary { + n += 2 + } + if m.Active { + n += 2 + } + if m.Preview { + n += 2 + } + if m.Replicas != 0 { + n += 1 + sovRollout(uint64(m.Replicas)) + } + if m.Available != 0 { + n += 1 + sovRollout(uint64(m.Available)) + } + l = len(m.Template) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.ScaleDownDeadline) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if len(m.Images) > 0 { + for _, s := range m.Images { + l = len(s) + n += 1 + l + sovRollout(uint64(l)) + } + } + if len(m.Pods) > 0 { + for _, e := range m.Pods { + l = e.Size() + n += 1 + l + sovRollout(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *PodInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Ready) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Restarts != 0 { + n += 1 + sovRollout(uint64(m.Restarts)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *ContainerInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Image) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *JobInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func (m *AnalysisRunInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ObjectMeta != nil { + l = m.ObjectMeta.Size() + n += 1 + l + sovRollout(uint64(l)) + } + l = len(m.Icon) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Revision != 0 { + n += 1 + sovRollout(uint64(m.Revision)) + } + l = len(m.Status) + if l > 0 { + n += 1 + l + sovRollout(uint64(l)) + } + if m.Successful != 0 { + n += 1 + sovRollout(uint64(m.Successful)) + } + if m.Failed != 0 { + n += 1 + sovRollout(uint64(m.Failed)) + } + if m.Inconclusive != 0 { + n += 1 + sovRollout(uint64(m.Inconclusive)) + } + if m.Error != 0 { + n += 1 + sovRollout(uint64(m.Error)) + } + if len(m.Jobs) > 0 { + for _, e := range m.Jobs { + l = e.Size() + n += 1 + l + sovRollout(uint64(l)) + } + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + +func sovRollout(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozRollout(x uint64) (n int) { + return sovRollout(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *RolloutInfoQuery) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutInfoQuery: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutInfoQuery: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutInfoListQuery) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutInfoListQuery: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutInfoListQuery: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SetImageRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: SetImageRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SetImageRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Rollout", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Rollout = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Container", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Container = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Image", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Image = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Tag", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Tag = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *UndoRolloutRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: UndoRolloutRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: UndoRolloutRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Rollout", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Rollout = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Revision", wireType) + } + m.Revision = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Revision |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RestartRolloutRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RestartRolloutRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RestartRolloutRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PromoteRolloutRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PromoteRolloutRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PromoteRolloutRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AbortRolloutRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AbortRolloutRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AbortRolloutRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RetryRolloutRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RetryRolloutRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RetryRolloutRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutWatchEvent) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutWatchEvent: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutWatchEvent: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Type", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Type = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RolloutInfo", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.RolloutInfo == nil { + m.RolloutInfo = &RolloutInfo{} + } + if err := m.RolloutInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *NamespaceInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: NamespaceInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: NamespaceInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Namespace", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Namespace = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutInfoList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutInfoList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutInfoList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Rollouts", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Rollouts = append(m.Rollouts, &RolloutInfo{}) + if err := m.Rollouts[len(m.Rollouts)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *VersionInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: VersionInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: VersionInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RolloutsVersion", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.RolloutsVersion = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Strategy", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Strategy = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Step", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Step = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SetWeight", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.SetWeight = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ActualWeight", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ActualWeight = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Ready", wireType) + } + m.Ready = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Ready |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 10: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Current", wireType) + } + m.Current = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Current |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 11: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Desired", wireType) + } + m.Desired = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Desired |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 12: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Updated", wireType) + } + m.Updated = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Updated |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 13: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Available", wireType) + } + m.Available = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Available |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 14: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RestartedAt", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.RestartedAt = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 15: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Generation", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Generation = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 16: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ReplicaSets", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ReplicaSets = append(m.ReplicaSets, &ReplicaSetInfo{}) + if err := m.ReplicaSets[len(m.ReplicaSets)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 17: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Experiments", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Experiments = append(m.Experiments, &ExperimentInfo{}) + if err := m.Experiments[len(m.Experiments)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 18: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnalysisRuns", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnalysisRuns = append(m.AnalysisRuns, &AnalysisRunInfo{}) + if err := m.AnalysisRuns[len(m.AnalysisRuns)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 19: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Containers", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Containers = append(m.Containers, &ContainerInfo{}) + if err := m.Containers[len(m.Containers)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 20: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Steps", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Steps = append(m.Steps, &v1alpha1.CanaryStep{}) + if err := m.Steps[len(m.Steps)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Revision", wireType) + } + m.Revision = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Revision |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ReplicaSets", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ReplicaSets = append(m.ReplicaSets, &ReplicaSetInfo{}) + if err := m.ReplicaSets[len(m.ReplicaSets)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnalysisRuns", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnalysisRuns = append(m.AnalysisRuns, &AnalysisRunInfo{}) + if err := m.AnalysisRuns[len(m.AnalysisRuns)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ReplicaSetInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ReplicaSetInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ReplicaSetInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Revision", wireType) + } + m.Revision = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Revision |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Stable", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Stable = bool(v != 0) + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Canary", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Canary = bool(v != 0) + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Active", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Active = bool(v != 0) + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Preview", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Preview = bool(v != 0) + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + m.Replicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Replicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 10: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Available", wireType) + } + m.Available = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Available |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 11: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Template", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Template = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 12: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ScaleDownDeadline", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ScaleDownDeadline = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 13: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Images", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Images = append(m.Images, string(dAtA[iNdEx:postIndex])) + iNdEx = postIndex + case 14: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Pods", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Pods = append(m.Pods, &PodInfo{}) + if err := m.Pods[len(m.Pods)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PodInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PodInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PodInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Ready", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Ready = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Restarts", wireType) + } + m.Restarts = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Restarts |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ContainerInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ContainerInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ContainerInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Image", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Image = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *JobInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: JobInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: JobInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRunInfo) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRunInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRunInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ObjectMeta == nil { + m.ObjectMeta = &v1.ObjectMeta{} + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Icon", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Icon = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Revision", wireType) + } + m.Revision = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Revision |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Successful", wireType) + } + m.Successful = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Successful |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Failed", wireType) + } + m.Failed = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Failed |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Inconclusive", wireType) + } + m.Inconclusive = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Inconclusive |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Error", wireType) + } + m.Error = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Error |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Jobs", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowRollout + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthRollout + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthRollout + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Jobs = append(m.Jobs, &JobInfo{}) + if err := m.Jobs[len(m.Jobs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipRollout(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthRollout + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipRollout(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowRollout + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowRollout + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowRollout + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthRollout + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupRollout + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthRollout + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthRollout = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowRollout = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupRollout = fmt.Errorf("proto: unexpected end of group") +) diff --git a/pkg/apiclient/rollout/rollout.pb.gw.go b/pkg/apiclient/rollout/rollout.pb.gw.go new file mode 100644 index 0000000000..2ab97fb555 --- /dev/null +++ b/pkg/apiclient/rollout/rollout.pb.gw.go @@ -0,0 +1,1475 @@ +// Code generated by protoc-gen-grpc-gateway. DO NOT EDIT. +// source: pkg/apiclient/rollout/rollout.proto + +/* +Package rollout is a reverse proxy. + +It translates gRPC into RESTful JSON APIs. +*/ +package rollout + +import ( + "context" + "io" + "net/http" + + "github.com/golang/protobuf/descriptor" + "github.com/golang/protobuf/proto" + "github.com/golang/protobuf/ptypes/empty" + "github.com/grpc-ecosystem/grpc-gateway/runtime" + "github.com/grpc-ecosystem/grpc-gateway/utilities" + "google.golang.org/grpc" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/status" +) + +// Suppress "imported and not used" errors +var _ codes.Code +var _ io.Reader +var _ status.Status +var _ = runtime.String +var _ = utilities.NewDoubleArray +var _ = descriptor.ForMessage + +func request_RolloutService_GetRolloutInfo_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RolloutInfoQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.GetRolloutInfo(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_GetRolloutInfo_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RolloutInfoQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := server.GetRolloutInfo(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_WatchRolloutInfo_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (RolloutService_WatchRolloutInfoClient, runtime.ServerMetadata, error) { + var protoReq RolloutInfoQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + stream, err := client.WatchRolloutInfo(ctx, &protoReq) + if err != nil { + return nil, metadata, err + } + header, err := stream.Header() + if err != nil { + return nil, metadata, err + } + metadata.HeaderMD = header + return stream, metadata, nil + +} + +func request_RolloutService_ListRolloutInfos_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RolloutInfoListQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + msg, err := client.ListRolloutInfos(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_ListRolloutInfos_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RolloutInfoListQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + msg, err := server.ListRolloutInfos(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_WatchRolloutInfos_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (RolloutService_WatchRolloutInfosClient, runtime.ServerMetadata, error) { + var protoReq RolloutInfoListQuery + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + stream, err := client.WatchRolloutInfos(ctx, &protoReq) + if err != nil { + return nil, metadata, err + } + header, err := stream.Header() + if err != nil { + return nil, metadata, err + } + metadata.HeaderMD = header + return stream, metadata, nil + +} + +func request_RolloutService_GetNamespace_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq empty.Empty + var metadata runtime.ServerMetadata + + msg, err := client.GetNamespace(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_GetNamespace_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq empty.Empty + var metadata runtime.ServerMetadata + + msg, err := server.GetNamespace(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_RestartRollout_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RestartRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.RestartRollout(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_RestartRollout_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RestartRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := server.RestartRollout(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_PromoteRollout_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq PromoteRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.PromoteRollout(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_PromoteRollout_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq PromoteRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := server.PromoteRollout(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_AbortRollout_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq AbortRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.AbortRollout(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_AbortRollout_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq AbortRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := server.AbortRollout(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_SetRolloutImage_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq SetImageRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["rollout"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "rollout") + } + + protoReq.Rollout, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "rollout", err) + } + + val, ok = pathParams["container"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "container") + } + + protoReq.Container, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "container", err) + } + + val, ok = pathParams["image"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "image") + } + + protoReq.Image, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "image", err) + } + + val, ok = pathParams["tag"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "tag") + } + + protoReq.Tag, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "tag", err) + } + + msg, err := client.SetRolloutImage(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_SetRolloutImage_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq SetImageRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["rollout"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "rollout") + } + + protoReq.Rollout, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "rollout", err) + } + + val, ok = pathParams["container"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "container") + } + + protoReq.Container, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "container", err) + } + + val, ok = pathParams["image"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "image") + } + + protoReq.Image, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "image", err) + } + + val, ok = pathParams["tag"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "tag") + } + + protoReq.Tag, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "tag", err) + } + + msg, err := server.SetRolloutImage(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_UndoRollout_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq UndoRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["rollout"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "rollout") + } + + protoReq.Rollout, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "rollout", err) + } + + val, ok = pathParams["revision"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "revision") + } + + protoReq.Revision, err = runtime.Int64(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "revision", err) + } + + msg, err := client.UndoRollout(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_UndoRollout_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq UndoRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["rollout"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "rollout") + } + + protoReq.Rollout, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "rollout", err) + } + + val, ok = pathParams["revision"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "revision") + } + + protoReq.Revision, err = runtime.Int64(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "revision", err) + } + + msg, err := server.UndoRollout(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_RetryRollout_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RetryRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.RetryRollout(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_RetryRollout_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq RetryRolloutRequest + var metadata runtime.ServerMetadata + + newReader, berr := utilities.IOReaderFactory(req.Body) + if berr != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", berr) + } + if err := marshaler.NewDecoder(newReader()).Decode(&protoReq); err != nil && err != io.EOF { + return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) + } + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := server.RetryRollout(ctx, &protoReq) + return msg, metadata, err + +} + +func request_RolloutService_Version_0(ctx context.Context, marshaler runtime.Marshaler, client RolloutServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq empty.Empty + var metadata runtime.ServerMetadata + + msg, err := client.Version(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_RolloutService_Version_0(ctx context.Context, marshaler runtime.Marshaler, server RolloutServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq empty.Empty + var metadata runtime.ServerMetadata + + msg, err := server.Version(ctx, &protoReq) + return msg, metadata, err + +} + +// RegisterRolloutServiceHandlerServer registers the http handlers for service RolloutService to "mux". +// UnaryRPC :call RolloutServiceServer directly. +// StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. +func RegisterRolloutServiceHandlerServer(ctx context.Context, mux *runtime.ServeMux, server RolloutServiceServer) error { + + mux.Handle("GET", pattern_RolloutService_GetRolloutInfo_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_GetRolloutInfo_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_GetRolloutInfo_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_WatchRolloutInfo_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + err := status.Error(codes.Unimplemented, "streaming calls are not yet supported in the in-process transport") + _, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + }) + + mux.Handle("GET", pattern_RolloutService_ListRolloutInfos_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_ListRolloutInfos_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_ListRolloutInfos_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_WatchRolloutInfos_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + err := status.Error(codes.Unimplemented, "streaming calls are not yet supported in the in-process transport") + _, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + }) + + mux.Handle("GET", pattern_RolloutService_GetNamespace_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_GetNamespace_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_GetNamespace_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_RestartRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_RestartRollout_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_RestartRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_PromoteRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_PromoteRollout_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_PromoteRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_AbortRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_AbortRollout_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_AbortRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_SetRolloutImage_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_SetRolloutImage_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_SetRolloutImage_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_UndoRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_UndoRollout_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_UndoRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_RetryRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_RetryRollout_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_RetryRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_Version_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_RolloutService_Version_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_Version_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + return nil +} + +// RegisterRolloutServiceHandlerFromEndpoint is same as RegisterRolloutServiceHandler but +// automatically dials to "endpoint" and closes the connection when "ctx" gets done. +func RegisterRolloutServiceHandlerFromEndpoint(ctx context.Context, mux *runtime.ServeMux, endpoint string, opts []grpc.DialOption) (err error) { + conn, err := grpc.Dial(endpoint, opts...) + if err != nil { + return err + } + defer func() { + if err != nil { + if cerr := conn.Close(); cerr != nil { + grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) + } + return + } + go func() { + <-ctx.Done() + if cerr := conn.Close(); cerr != nil { + grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) + } + }() + }() + + return RegisterRolloutServiceHandler(ctx, mux, conn) +} + +// RegisterRolloutServiceHandler registers the http handlers for service RolloutService to "mux". +// The handlers forward requests to the grpc endpoint over "conn". +func RegisterRolloutServiceHandler(ctx context.Context, mux *runtime.ServeMux, conn *grpc.ClientConn) error { + return RegisterRolloutServiceHandlerClient(ctx, mux, NewRolloutServiceClient(conn)) +} + +// RegisterRolloutServiceHandlerClient registers the http handlers for service RolloutService +// to "mux". The handlers forward requests to the grpc endpoint over the given implementation of "RolloutServiceClient". +// Note: the gRPC framework executes interceptors within the gRPC handler. If the passed in "RolloutServiceClient" +// doesn't go through the normal gRPC flow (creating a gRPC client etc.) then it will be up to the passed in +// "RolloutServiceClient" to call the correct interceptors. +func RegisterRolloutServiceHandlerClient(ctx context.Context, mux *runtime.ServeMux, client RolloutServiceClient) error { + + mux.Handle("GET", pattern_RolloutService_GetRolloutInfo_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_GetRolloutInfo_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_GetRolloutInfo_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_WatchRolloutInfo_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_WatchRolloutInfo_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_WatchRolloutInfo_0(ctx, mux, outboundMarshaler, w, req, func() (proto.Message, error) { return resp.Recv() }, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_ListRolloutInfos_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_ListRolloutInfos_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_ListRolloutInfos_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_WatchRolloutInfos_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_WatchRolloutInfos_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_WatchRolloutInfos_0(ctx, mux, outboundMarshaler, w, req, func() (proto.Message, error) { return resp.Recv() }, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_GetNamespace_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_GetNamespace_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_GetNamespace_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_RestartRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_RestartRollout_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_RestartRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_PromoteRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_PromoteRollout_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_PromoteRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_AbortRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_AbortRollout_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_AbortRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_SetRolloutImage_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_SetRolloutImage_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_SetRolloutImage_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_UndoRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_UndoRollout_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_UndoRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("PUT", pattern_RolloutService_RetryRollout_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_RetryRollout_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_RetryRollout_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_RolloutService_Version_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_RolloutService_Version_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_RolloutService_Version_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + return nil +} + +var ( + pattern_RolloutService_GetRolloutInfo_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "name", "info"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_WatchRolloutInfo_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5, 2, 6}, []string{"api", "v1", "rollouts", "namespace", "name", "info", "watch"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_ListRolloutInfos_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 2, 4}, []string{"api", "v1", "rollouts", "namespace", "info"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_WatchRolloutInfos_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 2, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "info", "watch"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_GetNamespace_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"api", "v1", "namespace"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_RestartRollout_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "name", "restart"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_PromoteRollout_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "name", "promote"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_AbortRollout_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "name", "abort"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_SetRolloutImage_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5, 1, 0, 4, 1, 5, 6, 3, 0, 4, 1, 5, 7, 1, 0, 4, 1, 5, 8}, []string{"api", "v1", "rollouts", "namespace", "rollout", "set", "container", "image", "tag"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_UndoRollout_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5, 1, 0, 4, 1, 5, 6}, []string{"api", "v1", "rollouts", "namespace", "rollout", "undo", "revision"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_RetryRollout_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"api", "v1", "rollouts", "namespace", "name", "retry"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_RolloutService_Version_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"api", "v1", "version"}, "", runtime.AssumeColonVerbOpt(true))) +) + +var ( + forward_RolloutService_GetRolloutInfo_0 = runtime.ForwardResponseMessage + + forward_RolloutService_WatchRolloutInfo_0 = runtime.ForwardResponseStream + + forward_RolloutService_ListRolloutInfos_0 = runtime.ForwardResponseMessage + + forward_RolloutService_WatchRolloutInfos_0 = runtime.ForwardResponseStream + + forward_RolloutService_GetNamespace_0 = runtime.ForwardResponseMessage + + forward_RolloutService_RestartRollout_0 = runtime.ForwardResponseMessage + + forward_RolloutService_PromoteRollout_0 = runtime.ForwardResponseMessage + + forward_RolloutService_AbortRollout_0 = runtime.ForwardResponseMessage + + forward_RolloutService_SetRolloutImage_0 = runtime.ForwardResponseMessage + + forward_RolloutService_UndoRollout_0 = runtime.ForwardResponseMessage + + forward_RolloutService_RetryRollout_0 = runtime.ForwardResponseMessage + + forward_RolloutService_Version_0 = runtime.ForwardResponseMessage +) diff --git a/pkg/apiclient/rollout/rollout.proto b/pkg/apiclient/rollout/rollout.proto new file mode 100644 index 0000000000..96101face2 --- /dev/null +++ b/pkg/apiclient/rollout/rollout.proto @@ -0,0 +1,223 @@ +syntax = "proto3"; +option go_package = "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout"; + +import "google/api/annotations.proto"; +import "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1/generated.proto"; +import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; +import "google/protobuf/empty.proto"; + +package rollout; + +message RolloutInfoQuery { + string name = 1; + string namespace = 2; +} + +message RolloutInfoListQuery { + string namespace = 1; +} + +message SetImageRequest { + string rollout = 1; + string container = 2; + string image = 3; + string tag = 4; + string namespace = 5; +} + +message UndoRolloutRequest { + string rollout = 1; + int64 revision = 2; + string namespace = 3; +} + +message RestartRolloutRequest { + string name = 1; + string namespace = 2; +} + +message PromoteRolloutRequest { + string name = 1; + string namespace = 2; +} + +message AbortRolloutRequest { + string name = 1; + string namespace = 2; +} + +message RetryRolloutRequest { + string name = 1; + string namespace = 2; +} + +message RolloutWatchEvent { + string type = 1; + RolloutInfo rolloutInfo = 2; +} + +message NamespaceInfo { + string namespace = 1; +} + +message RolloutInfoList { + repeated RolloutInfo rollouts = 1; +} + +message VersionInfo { + string rolloutsVersion = 1; +} + +message RolloutInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + + string status = 2; + string message = 3; + string icon = 4; + string strategy = 5; + string step = 6; + string setWeight = 7; + string actualWeight = 8; + + int32 ready = 9; + int32 current = 10; + int32 desired = 11; + int32 updated = 12; + int32 available = 13; + string restartedAt = 14; + string generation = 15; + + repeated ReplicaSetInfo replicaSets = 16; + repeated ExperimentInfo experiments = 17; + repeated AnalysisRunInfo analysisRuns = 18; + + repeated ContainerInfo containers = 19; + + repeated github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStep steps = 20; +} + +message ExperimentInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + string icon = 2; + int32 revision = 3; + string status = 4; + string message = 5; + repeated ReplicaSetInfo replicaSets = 6; + repeated AnalysisRunInfo analysisRuns = 7; +} + +message ReplicaSetInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + string status = 2; + string icon = 3; + int32 revision = 4; + bool stable = 5; + bool canary = 6; + bool active = 7; + bool preview = 8; + int32 replicas = 9; + int32 available = 10; + string template = 11; + string scaleDownDeadline = 12; + repeated string images = 13; + repeated PodInfo pods = 14; +} + +message PodInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + string status = 2; + string icon = 3; + string ready = 4; + int32 restarts = 5; +} + +message ContainerInfo { + string name = 1; + string image = 2; +} + +message JobInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + string status = 2; + string icon = 3; +} + +message AnalysisRunInfo { + k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta objectMeta = 1; + string icon = 2; + int32 revision = 3; + string status = 4; + int32 successful = 5; + int32 failed = 6; + int32 inconclusive = 7; + int32 error = 8; + repeated JobInfo jobs = 9; +} + +service RolloutService { + rpc GetRolloutInfo(RolloutInfoQuery) returns (RolloutInfo) { + option (google.api.http).get = "/api/v1/rollouts/{namespace}/{name}/info"; + } + + rpc WatchRolloutInfo(RolloutInfoQuery) returns (stream RolloutInfo) { + option (google.api.http).get = "/api/v1/rollouts/{namespace}/{name}/info/watch"; + } + + rpc ListRolloutInfos(RolloutInfoListQuery) returns (RolloutInfoList) { + option (google.api.http).get = "/api/v1/rollouts/{namespace}/info"; + } + + rpc WatchRolloutInfos(RolloutInfoListQuery) returns (stream RolloutWatchEvent) { + option (google.api.http).get = "/api/v1/rollouts/{namespace}/info/watch"; + } + + rpc GetNamespace(google.protobuf.Empty) returns (NamespaceInfo) { + option (google.api.http).get = "/api/v1/namespace"; + } + + rpc RestartRollout(RestartRolloutRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{name}/restart" + body: "*" + }; + } + + rpc PromoteRollout(PromoteRolloutRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{name}/promote" + body: "*" + }; + } + + rpc AbortRollout(AbortRolloutRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{name}/abort" + body: "*" + }; + } + + rpc SetRolloutImage(SetImageRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{rollout}/set/{container}/{image=**}/{tag}" + body: "*" + }; + } + + rpc UndoRollout(UndoRolloutRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{rollout}/undo/{revision}" + body: "*" + }; + } + + rpc RetryRollout(RetryRolloutRequest) returns (github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout) { + option (google.api.http) = { + put: "/api/v1/rollouts/{namespace}/{name}/retry" + body: "*" + }; + } + + rpc Version(google.protobuf.Empty) returns (VersionInfo) { + option (google.api.http).get = "/api/v1/version"; + } +} \ No newline at end of file diff --git a/pkg/apiclient/rollout/rollout.swagger.json b/pkg/apiclient/rollout/rollout.swagger.json new file mode 100644 index 0000000000..7a52d30224 --- /dev/null +++ b/pkg/apiclient/rollout/rollout.swagger.json @@ -0,0 +1,4340 @@ +{ + "swagger": "2.0", + "info": { + "title": "pkg/apiclient/rollout/rollout.proto", + "version": "version not set" + }, + "consumes": [ + "application/json" + ], + "produces": [ + "application/json" + ], + "paths": { + "/api/v1/namespace": { + "get": { + "operationId": "RolloutService_GetNamespace", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/rollout.NamespaceInfo" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/info": { + "get": { + "operationId": "RolloutService_ListRolloutInfos", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/rollout.RolloutInfoList" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/info/watch": { + "get": { + "operationId": "RolloutService_WatchRolloutInfos", + "responses": { + "200": { + "description": "A successful response.(streaming responses)", + "schema": { + "type": "object", + "properties": { + "result": { + "$ref": "#/definitions/rollout.RolloutWatchEvent" + }, + "error": { + "$ref": "#/definitions/grpc.gateway.runtime.StreamError" + } + }, + "title": "Stream result of rollout.RolloutWatchEvent" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/abort": { + "put": { + "operationId": "RolloutService_AbortRollout", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.AbortRolloutRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/info": { + "get": { + "operationId": "RolloutService_GetRolloutInfo", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/rollout.RolloutInfo" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/info/watch": { + "get": { + "operationId": "RolloutService_WatchRolloutInfo", + "responses": { + "200": { + "description": "A successful response.(streaming responses)", + "schema": { + "type": "object", + "properties": { + "result": { + "$ref": "#/definitions/rollout.RolloutInfo" + }, + "error": { + "$ref": "#/definitions/grpc.gateway.runtime.StreamError" + } + }, + "title": "Stream result of rollout.RolloutInfo" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/promote": { + "put": { + "operationId": "RolloutService_PromoteRollout", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.PromoteRolloutRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/restart": { + "put": { + "operationId": "RolloutService_RestartRollout", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.RestartRolloutRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{name}/retry": { + "put": { + "operationId": "RolloutService_RetryRollout", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "name", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.RetryRolloutRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{rollout}/set/{container}/{image}/{tag}": { + "put": { + "operationId": "RolloutService_SetRolloutImage", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "rollout", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "container", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "image", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "tag", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.SetImageRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/rollouts/{namespace}/{rollout}/undo/{revision}": { + "put": { + "operationId": "RolloutService_UndoRollout", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "rollout", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "revision", + "in": "path", + "required": true, + "type": "string", + "format": "int64" + }, + { + "name": "body", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/rollout.UndoRolloutRequest" + } + } + ], + "tags": [ + "RolloutService" + ] + } + }, + "/api/v1/version": { + "get": { + "operationId": "RolloutService_Version", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/rollout.VersionInfo" + } + }, + "default": { + "description": "An unexpected error response.", + "schema": { + "$ref": "#/definitions/grpc.gateway.runtime.Error" + } + } + }, + "tags": [ + "RolloutService" + ] + } + } + }, + "definitions": { + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ALBTrafficRouting": { + "type": "object", + "properties": { + "ingress": { + "type": "string", + "title": "Ingress refers to the name of an `Ingress` resource in the same namespace as the `Rollout`" + }, + "servicePort": { + "type": "integer", + "format": "int32", + "title": "ServicePort refers to the port that the Ingress action should route traffic to" + }, + "rootService": { + "type": "string", + "title": "RootService references the service in the ingress to the controller should add the action to" + }, + "annotationPrefix": { + "type": "string", + "title": "AnnotationPrefix has to match the configured annotation prefix on the alb ingress controller\n+optional" + } + }, + "title": "ALBTrafficRouting configuration for ALB ingress controller to control traffic routing" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunArgument": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name argument name" + }, + "value": { + "type": "string", + "title": "Value a hardcoded value for the argument. This field is a one of field with valueFrom" + }, + "valueFrom": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ArgumentValueFrom", + "title": "ValueFrom A reference to where the value is stored. This field is a one of field with valueFrom" + } + }, + "title": "AnalysisRunArgument argument to add to analysisRun" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AntiAffinity": { + "type": "object", + "properties": { + "preferredDuringSchedulingIgnoredDuringExecution": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PreferredDuringSchedulingIgnoredDuringExecution", + "title": "+optional" + }, + "requiredDuringSchedulingIgnoredDuringExecution": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RequiredDuringSchedulingIgnoredDuringExecution", + "title": "+optional" + } + }, + "title": "AntiAffinity defines which inter-pod scheduling rule to use for anti-affinity injection" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ArgumentValueFrom": { + "type": "object", + "properties": { + "podTemplateHashValue": { + "type": "string", + "title": "PodTemplateHashValue gets the value from one of the children ReplicaSet's Pod Template Hash" + }, + "fieldRef": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.FieldRef", + "title": "FieldRef" + } + }, + "title": "ArgumentValueFrom defines references to fields within resources to grab for the value (i.e. Pod Template Hash)" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStatus": { + "type": "object", + "properties": { + "previewSelector": { + "type": "string", + "title": "PreviewSelector indicates which replicas set the preview service is serving traffic to\n+optional" + }, + "activeSelector": { + "type": "string", + "title": "ActiveSelector indicates which replicas set the active service is serving traffic to\n+optional" + }, + "scaleUpPreviewCheckPoint": { + "type": "boolean", + "title": "ScaleUpPreviewCheckPoint indicates that the Replicaset receiving traffic from the preview service is ready to be scaled up after the rollout is unpaused\n+optional" + }, + "prePromotionAnalysisRunStatus": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus", + "title": "PrePromotionAnalysisRunStatus indicates the status of the current prepromotion analysis run" + }, + "postPromotionAnalysisRunStatus": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus", + "title": "PostPromotionAnalysisRunStatus indicates the status of the current post promotion analysis run" + } + }, + "title": "BlueGreenStatus status fields that only pertain to the blueGreen rollout" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStrategy": { + "type": "object", + "properties": { + "activeService": { + "type": "string", + "description": "Name of the service that the rollout modifies as the active service." + }, + "previewService": { + "type": "string", + "title": "Name of the service that the rollout modifies as the preview service.\n+optional" + }, + "previewReplicaCount": { + "type": "integer", + "format": "int32", + "title": "PreviewReplicaCount is the number of replicas to run for the preview stack before the\nswitchover. Once the rollout is resumed the desired replicaset will be full scaled up before the switch occurs\n+optional" + }, + "autoPromotionEnabled": { + "type": "boolean", + "title": "AutoPromotionEnabled indicates if the rollout should automatically promote the new ReplicaSet\nto the active service or enter a paused state. If not specified, the default value is true.\n+optional" + }, + "autoPromotionSeconds": { + "type": "integer", + "format": "int32", + "title": "AutoPromotionSeconds is a duration in seconds in which to delay auto-promotion (default: 0).\nThe countdown begins after the preview ReplicaSet have reached full availability.\nThis option is ignored if autoPromotionEnabled is set to false.\n+optional" + }, + "maxUnavailable": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "title": "MaxUnavailable The maximum number of pods that can be unavailable during a restart operation.\nDefaults to 25% of total replicas.\n+optional" + }, + "scaleDownDelaySeconds": { + "type": "integer", + "format": "int32", + "title": "ScaleDownDelaySeconds adds a delay before scaling down the previous replicaset.\nIf omitted, the Rollout waits 30 seconds before scaling down the previous ReplicaSet.\nA minimum of 30 seconds is recommended to ensure IP table propagation across the nodes in\na cluster. See https://github.com/argoproj/argo-rollouts/issues/19#issuecomment-476329960 for\nmore information\n+optional" + }, + "scaleDownDelayRevisionLimit": { + "type": "integer", + "format": "int32", + "title": "ScaleDownDelayRevisionLimit limits the number of old RS that can run at one time before getting scaled down\n+optional" + }, + "prePromotionAnalysis": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis", + "title": "PrePromotionAnalysis configuration to run analysis before a selector switch" + }, + "antiAffinity": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AntiAffinity", + "title": "AntiAffinity enables anti-affinity rules for Blue Green deployment\n+optional" + }, + "postPromotionAnalysis": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis", + "title": "PostPromotionAnalysis configuration to run analysis after a selector switch" + }, + "previewMetadata": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata", + "title": "PreviewMetadata specify labels and annotations which will be attached to the preview pods for\nthe duration which they act as a preview pod, and will be removed after" + }, + "activeMetadata": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata", + "title": "ActiveMetadata specify labels and annotations which will be attached to the active pods for\nthe duration which they act as a active pod, and will be removed after" + } + }, + "title": "BlueGreenStrategy defines parameters for Blue Green deployment" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStatus": { + "type": "object", + "properties": { + "currentStepAnalysisRunStatus": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus", + "title": "CurrentStepAnalysisRunStatus indicates the status of the current step analysis run" + }, + "currentBackgroundAnalysisRunStatus": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus", + "title": "CurrentBackgroundAnalysisRunStatus indicates the status of the current background analysis run" + }, + "currentExperiment": { + "type": "string", + "title": "CurrentExperiment indicates the running experiment" + } + }, + "title": "CanaryStatus status fields that only pertain to the canary rollout" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStep": { + "type": "object", + "properties": { + "setWeight": { + "type": "integer", + "format": "int32", + "title": "SetWeight sets what percentage of the newRS should receive" + }, + "pause": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutPause", + "title": "Pause freezes the rollout by setting spec.Paused to true.\nA Rollout will resume when spec.Paused is reset to false.\n+optional" + }, + "experiment": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStep", + "title": "Experiment defines the experiment object that should be created" + }, + "analysis": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis", + "title": "Analysis defines the AnalysisRun that will run for a step" + }, + "setCanaryScale": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SetCanaryScale", + "title": "SetCanaryScale defines how to scale the newRS without changing traffic weight\n+optional" + } + }, + "description": "CanaryStep defines a step of a canary deployment." + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStrategy": { + "type": "object", + "properties": { + "canaryService": { + "type": "string", + "title": "CanaryService holds the name of a service which selects pods with canary version and don't select any pods with stable version.\n+optional" + }, + "stableService": { + "type": "string", + "title": "StableService holds the name of a service which selects pods with stable version and don't select any pods with canary version.\n+optional" + }, + "steps": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStep" + }, + "title": "Steps define the order of phases to execute the canary deployment\n+optional" + }, + "trafficRouting": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutTrafficRouting", + "title": "TrafficRouting hosts all the supported service meshes supported to enable more fine-grained traffic routing" + }, + "maxUnavailable": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "title": "MaxUnavailable The maximum number of pods that can be unavailable during the update.\nValue can be an absolute number (ex: 5) or a percentage of total pods at the start of update (ex: 10%).\nAbsolute number is calculated from percentage by rounding down.\nThis can not be 0 if MaxSurge is 0.\nBy default, a fixed value of 25% is used.\nExample: when this is set to 30%, the old RC can be scaled down by 30%\nimmediately when the rolling update starts. Once new pods are ready, old RC\ncan be scaled down further, followed by scaling up the new RC, ensuring\nthat at least 70% of original number of pods are available at all times\nduring the update.\n+optional" + }, + "maxSurge": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "title": "MaxSurge The maximum number of pods that can be scheduled above the original number of\npods.\nValue can be an absolute number (ex: 5) or a percentage of total pods at\nthe start of the update (ex: 10%). This can not be 0 if MaxUnavailable is 0.\nAbsolute number is calculated from percentage by rounding up.\nBy default, a value of 25% is used.\nExample: when this is set to 30%, the new RC can be scaled up by 30%\nimmediately when the rolling update starts. Once old pods have been killed,\nnew RC can be scaled up further, ensuring that total number of pods running\nat any time during the update is at most 130% of original pods.\n+optional" + }, + "analysis": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisBackground", + "title": "Analysis runs a separate analysisRun while all the steps execute. This is intended to be a continuous validation of the new ReplicaSet" + }, + "antiAffinity": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AntiAffinity", + "title": "AntiAffinity enables anti-affinity rules for Canary deployment\n+optional" + }, + "canaryMetadata": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata", + "title": "CanaryMetadata specify labels and annotations which will be attached to the canary pods for\nthe duration which they act as a canary, and will be removed after" + }, + "stableMetadata": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata", + "title": "StableMetadata specify labels and annotations which will be attached to the stable pods for\nthe duration which they act as a canary, and will be removed after" + } + }, + "title": "CanaryStrategy defines parameters for a Replica Based Canary" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.FieldRef": { + "type": "object", + "properties": { + "fieldPath": { + "type": "string", + "title": "Required: Path of the field to select in the specified API version" + } + } + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioDestinationRule": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name holds the name of the DestinationRule" + }, + "canarySubsetName": { + "type": "string", + "title": "CanarySubsetName is the subset name to modify labels with canary ReplicaSet pod template hash value" + }, + "stableSubsetName": { + "type": "string", + "title": "StableSubsetName is the subset name to modify labels with stable ReplicaSet pod template hash value" + } + }, + "title": "IstioDestinationRule is a reference to an Istio DestinationRule to modify and shape traffic" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioTrafficRouting": { + "type": "object", + "properties": { + "virtualService": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioVirtualService", + "title": "VirtualService references an Istio VirtualService to modify to shape traffic" + }, + "destinationRule": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioDestinationRule", + "title": "DestinationRule references an Istio DestinationRule to modify to shape traffic" + } + }, + "title": "IstioTrafficRouting configuration for Istio service mesh to enable fine grain configuration" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioVirtualService": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name holds the name of the VirtualService" + }, + "routes": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Routes list of routes within VirtualService to edit" + } + }, + "title": "IstioVirtualService holds information on the virtual service the rollout needs to modify" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.NginxTrafficRouting": { + "type": "object", + "properties": { + "annotationPrefix": { + "type": "string", + "title": "AnnotationPrefix has to match the configured annotation prefix on the nginx ingress controller\n+optional" + }, + "stableIngress": { + "type": "string", + "title": "StableIngress refers to the name of an `Ingress` resource in the same namespace as the `Rollout`" + }, + "additionalIngressAnnotations": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "+optional" + } + }, + "title": "NginxTrafficRouting configuration for Nginx ingress controller to control traffic routing" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PauseCondition": { + "type": "object", + "properties": { + "reason": { + "type": "string" + }, + "startTime": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time" + } + }, + "title": "PauseCondition the reason for a pause and when it started" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata": { + "type": "object", + "properties": { + "labels": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "Labels Additional labels to add to the experiment\n+optional" + }, + "annotations": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "Annotations additional annotations to add to the experiment\n+optional" + } + }, + "title": "PodTemplateMetadata extra labels to add to the template" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PreferredDuringSchedulingIgnoredDuringExecution": { + "type": "object", + "properties": { + "weight": { + "type": "integer", + "format": "int32", + "description": "Weight associated with matching the corresponding podAffinityTerm, in the range 1-100." + } + }, + "title": "PreferredDuringSchedulingIgnoredDuringExecution defines the weight of the anti-affinity injection" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RequiredDuringSchedulingIgnoredDuringExecution": { + "type": "object", + "title": "RequiredDuringSchedulingIgnoredDuringExecution defines inter-pod scheduling rule to be RequiredDuringSchedulingIgnoredDuringExecution" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout": { + "type": "object", + "properties": { + "metadata": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "spec": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutSpec" + }, + "status": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStatus" + } + }, + "title": "Rollout is a specification for a Rollout resource" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis": { + "type": "object", + "properties": { + "templates": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisTemplate" + }, + "title": "Templates reference to a list of analysis templates to combine for an AnalysisRun" + }, + "args": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunArgument" + }, + "title": "Args the arguments that will be added to the AnalysisRuns\n+patchMergeKey=name\n+patchStrategy=merge" + } + }, + "title": "RolloutAnalysis defines a template that is used to create a analysisRun" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisBackground": { + "type": "object", + "properties": { + "rolloutAnalysis": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis" + }, + "startingStep": { + "type": "integer", + "format": "int32", + "title": "StartingStep indicates which step the background analysis should start on\nIf not listed, controller defaults to 0" + } + }, + "title": "RolloutAnalysisBackground defines a template that is used to create a background analysisRun" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "status": { + "type": "string" + }, + "message": { + "type": "string" + } + } + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisTemplate": { + "type": "object", + "properties": { + "templateName": { + "type": "string", + "title": "TemplateName name of template to use in AnalysisRun\n+optional" + }, + "clusterScope": { + "type": "boolean", + "title": "Whether to look for the templateName at cluster scope or namespace scope\n+optional" + } + } + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutCondition": { + "type": "object", + "properties": { + "type": { + "type": "string", + "description": "Type of deployment condition." + }, + "status": { + "type": "string", + "description": "Phase of the condition, one of True, False, Unknown." + }, + "lastUpdateTime": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "description": "The last time this condition was updated." + }, + "lastTransitionTime": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "description": "Last time the condition transitioned from one status to another." + }, + "reason": { + "type": "string", + "description": "The reason for the condition's last transition." + }, + "message": { + "type": "string", + "description": "A human readable message indicating details about the transition." + } + }, + "description": "RolloutCondition describes the state of a rollout at a certain point." + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStep": { + "type": "object", + "properties": { + "templates": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentTemplate" + }, + "title": "Templates what templates that should be added to the experiment. Should be non-nil\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "duration": { + "type": "string", + "title": "Duration is a duration string (e.g. 30s, 5m, 1h) that the experiment should run for\n+optional" + }, + "analyses": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStepAnalysisTemplateRef" + }, + "title": "Analyses reference which analysis templates to run with the experiment\n+patchMergeKey=name\n+patchStrategy=merge" + } + }, + "title": "RolloutExperimentStep defines a template that is used to create a experiment for a step" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStepAnalysisTemplateRef": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name is a name for this analysis template invocation" + }, + "templateName": { + "type": "string", + "title": "TemplateName reference of the AnalysisTemplate name used by the Experiment to create the run" + }, + "clusterScope": { + "type": "boolean", + "title": "Whether to look for the templateName at cluster scope or namespace scope\n+optional" + }, + "args": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunArgument" + }, + "title": "Args the arguments that will be added to the AnalysisRuns\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "requiredForCompletion": { + "type": "boolean", + "title": "RequiredForCompletion blocks the Experiment from completing until the analysis has completed" + } + } + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentTemplate": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name description of template that passed to the template" + }, + "specRef": { + "type": "string", + "title": "SpecRef indicates where the rollout should get the RS template from" + }, + "replicas": { + "type": "integer", + "format": "int32", + "title": "Replicas replica count for the template\n+optional" + }, + "metadata": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata", + "title": "Metadata sets labels and annotations to use for the RS created from the template\n+optional" + }, + "selector": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector", + "title": "Selector overrides the selector to be used for the template's ReplicaSet. If omitted, will\nuse the same selector as the Rollout\n+optional" + } + }, + "title": "RolloutExperimentTemplate defines the template used to create experiments for the Rollout's experiment canary step" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutPause": { + "type": "object", + "properties": { + "duration": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "title": "Duration the amount of time to wait before moving to the next step.\n+optional" + } + }, + "title": "RolloutPause defines a pause stage for a rollout" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutSpec": { + "type": "object", + "properties": { + "replicas": { + "type": "integer", + "format": "int32", + "title": "Number of desired pods. This is a pointer to distinguish between explicit\nzero and not specified. Defaults to 1.\n+optional" + }, + "selector": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector", + "description": "Label selector for pods. Existing ReplicaSets whose pods are\nselected by this will be the ones affected by this rollout.\nIt must match the pod template's labels." + }, + "template": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodTemplateSpec", + "description": "Template describes the pods that will be created." + }, + "minReadySeconds": { + "type": "integer", + "format": "int32", + "title": "Minimum number of seconds for which a newly created pod should be ready\nwithout any of its container crashing, for it to be considered available.\nDefaults to 0 (pod will be considered available as soon as it is ready)\n+optional" + }, + "strategy": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStrategy", + "title": "The deployment strategy to use to replace existing pods with new ones.\n+optional" + }, + "revisionHistoryLimit": { + "type": "integer", + "format": "int32", + "title": "The number of old ReplicaSets to retain. If unspecified, will retain 10 old ReplicaSets" + }, + "paused": { + "type": "boolean", + "description": "Paused pauses the rollout at its current step." + }, + "progressDeadlineSeconds": { + "type": "integer", + "format": "int32", + "description": "ProgressDeadlineSeconds The maximum time in seconds for a rollout to\nmake progress before it is considered to be failed. Argo Rollouts will\ncontinue to process failed rollouts and a condition with a\nProgressDeadlineExceeded reason will be surfaced in the rollout status.\nNote that progress will not be estimated during the time a rollout is paused.\nDefaults to 600s." + }, + "restartAt": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "title": "RestartAt indicates when all the pods of a Rollout should be restarted" + } + }, + "title": "RolloutSpec is the spec for a Rollout resource" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStatus": { + "type": "object", + "properties": { + "abort": { + "type": "boolean", + "title": "Abort cancel the current rollout progression" + }, + "pauseConditions": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PauseCondition" + }, + "title": "PauseConditions indicates why the rollout is currently paused" + }, + "controllerPause": { + "type": "boolean", + "description": "ControllerPause indicates the controller has paused the rollout. It is set to true when\nthe controller adds a pause condition. This field helps to discern the scenario where a\nrollout was resumed after being paused by the controller (e.g. via the plugin). In that\nsituation, the pauseConditions would have been cleared , but controllerPause would still be\nset to true." + }, + "abortedAt": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "description": "AbortedAt indicates the controller reconciled an aborted rollout. The controller uses this to understand if\nthe controller needs to do some specific work when a Rollout is aborted. For example, the reconcileAbort is used\nto indicate if the Rollout should enter an aborted state when the latest AnalysisRun is a failure, or the controller\nhas already put the Rollout into an aborted and should create a new AnalysisRun." + }, + "currentPodHash": { + "type": "string", + "title": "CurrentPodHash the hash of the current pod template\n+optional" + }, + "currentStepHash": { + "type": "string", + "title": "CurrentStepHash the hash of the current list of steps for the current strategy. This is used to detect when the\nlist of current steps change\n+optional" + }, + "replicas": { + "type": "integer", + "format": "int32", + "title": "Total number of non-terminated pods targeted by this rollout (their labels match the selector).\n+optional" + }, + "updatedReplicas": { + "type": "integer", + "format": "int32", + "title": "Total number of non-terminated pods targeted by this rollout that have the desired template spec.\n+optional" + }, + "readyReplicas": { + "type": "integer", + "format": "int32", + "title": "Total number of ready pods targeted by this rollout.\n+optional" + }, + "availableReplicas": { + "type": "integer", + "format": "int32", + "title": "Total number of available pods (ready for at least minReadySeconds) targeted by this rollout.\n+optional" + }, + "currentStepIndex": { + "type": "integer", + "format": "int32", + "title": "CurrentStepIndex defines the current step of the rollout is on. If the current step index is null, the\ncontroller will execute the rollout.\n+optional" + }, + "collisionCount": { + "type": "integer", + "format": "int32", + "title": "Count of hash collisions for the Rollout. The Rollout controller uses this\nfield as a collision avoidance mechanism when it needs to create the name for the\nnewest ReplicaSet.\n+optional" + }, + "observedGeneration": { + "type": "string", + "title": "The generation observed by the rollout controller by taking a hash of the spec.\n+optional" + }, + "conditions": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutCondition" + }, + "title": "Conditions a list of conditions a rollout can have.\n+optional" + }, + "canary": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStatus", + "title": "Canary describes the state of the canary rollout\n+optional" + }, + "blueGreen": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStatus", + "title": "BlueGreen describes the state of the bluegreen rollout\n+optional" + }, + "HPAReplicas": { + "type": "integer", + "format": "int32", + "title": "HPAReplicas the number of non-terminated replicas that are receiving active traffic\n+optional" + }, + "selector": { + "type": "string", + "title": "Selector that identifies the pods that are receiving active traffic\n+optional" + }, + "stableRS": { + "type": "string", + "title": "StableRS indicates the replicaset that has successfully rolled out\n+optional" + }, + "restartedAt": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "title": "RestartedAt indicates last time a Rollout was restarted" + }, + "promoteFull": { + "type": "boolean", + "description": "PromoteFull indicates if the rollout should perform a full promotion, skipping analysis and pauses." + } + }, + "title": "RolloutStatus is the status for a Rollout resource" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStrategy": { + "type": "object", + "properties": { + "blueGreen": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStrategy", + "title": "+optional" + }, + "canary": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStrategy", + "title": "+optional" + } + }, + "title": "RolloutStrategy defines strategy to apply during next rollout" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutTrafficRouting": { + "type": "object", + "properties": { + "istio": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioTrafficRouting", + "title": "Istio holds Istio specific configuration to route traffic" + }, + "nginx": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.NginxTrafficRouting", + "title": "Nginx holds Nginx Ingress specific configuration to route traffic" + }, + "alb": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ALBTrafficRouting", + "title": "Nginx holds ALB Ingress specific configuration to route traffic" + }, + "smi": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SMITrafficRouting", + "title": "SMI holds TrafficSplit specific configuration to route traffic" + } + }, + "title": "RolloutTrafficRouting hosts all the different configuration for supported service meshes to enable more fine-grained traffic routing" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SMITrafficRouting": { + "type": "object", + "properties": { + "rootService": { + "type": "string", + "title": "RootService holds the name of that clients use to communicate.\n+optional" + }, + "trafficSplitName": { + "type": "string", + "title": "TrafficSplitName holds the name of the TrafficSplit.\n+optional" + } + }, + "title": "SMITrafficRouting configuration for TrafficSplit Custom Resource to control traffic routing" + }, + "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SetCanaryScale": { + "type": "object", + "properties": { + "weight": { + "type": "integer", + "format": "int32", + "title": "Weight sets the percentage of replicas the newRS should have\n+optional" + }, + "replicas": { + "type": "integer", + "format": "int32", + "title": "Replicas sets the number of replicas the newRS should have\n+optional" + }, + "matchTrafficWeight": { + "type": "boolean", + "title": "MatchTrafficWeight cancels out previously set Replicas or Weight, effectively activating SetWeight\n+optional" + } + }, + "title": "SetCanaryScale defines how to scale the newRS without changing traffic weight" + }, + "google.protobuf.Any": { + "type": "object", + "properties": { + "type_url": { + "type": "string" + }, + "value": { + "type": "string", + "format": "byte" + } + } + }, + "grpc.gateway.runtime.Error": { + "type": "object", + "properties": { + "error": { + "type": "string" + }, + "code": { + "type": "integer", + "format": "int32" + }, + "message": { + "type": "string" + }, + "details": { + "type": "array", + "items": { + "$ref": "#/definitions/google.protobuf.Any" + } + } + } + }, + "grpc.gateway.runtime.StreamError": { + "type": "object", + "properties": { + "grpc_code": { + "type": "integer", + "format": "int32" + }, + "http_code": { + "type": "integer", + "format": "int32" + }, + "message": { + "type": "string" + }, + "http_status": { + "type": "string" + }, + "details": { + "type": "array", + "items": { + "$ref": "#/definitions/google.protobuf.Any" + } + } + } + }, + "k8s.io.api.core.v1.AWSElasticBlockStoreVolumeSource": { + "type": "object", + "properties": { + "volumeID": { + "type": "string", + "title": "Unique ID of the persistent disk resource in AWS (Amazon EBS volume).\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore" + }, + "fsType": { + "type": "string", + "title": "Filesystem type of the volume that you want to mount.\nTip: Ensure that the filesystem type is supported by the host operating system.\nExamples: \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore\nTODO: how do we prevent errors in the filesystem from compromising the machine\n+optional" + }, + "partition": { + "type": "integer", + "format": "int32", + "title": "The partition in the volume that you want to mount.\nIf omitted, the default is to mount by volume name.\nExamples: For volume /dev/sda1, you specify the partition as \"1\".\nSimilarly, the volume partition for /dev/sda is \"0\" (or you can leave the property empty).\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Specify \"true\" to force and set the ReadOnly property in VolumeMounts to \"true\".\nIf omitted, the default is \"false\".\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore\n+optional" + } + }, + "description": "Represents a Persistent Disk resource in AWS.\n\nAn AWS EBS disk must exist before mounting to a container. The disk\nmust also be in the same AWS zone as the kubelet. An AWS EBS disk\ncan only be mounted as read/write once. AWS EBS volumes support\nownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.Affinity": { + "type": "object", + "properties": { + "nodeAffinity": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeAffinity", + "title": "Describes node affinity scheduling rules for the pod.\n+optional" + }, + "podAffinity": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodAffinity", + "title": "Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)).\n+optional" + }, + "podAntiAffinity": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodAntiAffinity", + "title": "Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)).\n+optional" + } + }, + "description": "Affinity is a group of affinity scheduling rules." + }, + "k8s.io.api.core.v1.AzureDiskVolumeSource": { + "type": "object", + "properties": { + "diskName": { + "type": "string", + "title": "The Name of the data disk in the blob storage" + }, + "diskURI": { + "type": "string", + "title": "The URI the data disk in the blob storage" + }, + "cachingMode": { + "type": "string", + "title": "Host Caching mode: None, Read Only, Read Write.\n+optional" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + }, + "kind": { + "type": "string", + "title": "Expected values Shared: multiple blob disks per storage account Dedicated: single blob disk per storage account Managed: azure managed data disk (only in managed availability set). defaults to shared" + } + }, + "description": "AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod." + }, + "k8s.io.api.core.v1.AzureFileVolumeSource": { + "type": "object", + "properties": { + "secretName": { + "type": "string", + "title": "the name of secret that contains Azure Storage Account Name and Key" + }, + "shareName": { + "type": "string", + "title": "Share Name" + }, + "readOnly": { + "type": "boolean", + "title": "Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + } + }, + "description": "AzureFile represents an Azure File Service mount on the host and bind mount to the pod." + }, + "k8s.io.api.core.v1.CSIVolumeSource": { + "type": "object", + "properties": { + "driver": { + "type": "string", + "description": "Driver is the name of the CSI driver that handles this volume.\nConsult with your admin for the correct name as registered in the cluster." + }, + "readOnly": { + "type": "boolean", + "title": "Specifies a read-only configuration for the volume.\nDefaults to false (read/write).\n+optional" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount. Ex. \"ext4\", \"xfs\", \"ntfs\".\nIf not provided, the empty value is passed to the associated CSI driver\nwhich will determine the default filesystem to apply.\n+optional" + }, + "volumeAttributes": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "VolumeAttributes stores driver-specific properties that are passed to the CSI\ndriver. Consult your driver's documentation for supported values.\n+optional" + }, + "nodePublishSecretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "NodePublishSecretRef is a reference to the secret object containing\nsensitive information to pass to the CSI driver to complete the CSI\nNodePublishVolume and NodeUnpublishVolume calls.\nThis field is optional, and may be empty if no secret is required. If the\nsecret object contains more than one secret, all secret references are passed.\n+optional" + } + }, + "title": "Represents a source location of a volume to mount, managed by an external CSI driver" + }, + "k8s.io.api.core.v1.Capabilities": { + "type": "object", + "properties": { + "add": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Added capabilities\n+optional" + }, + "drop": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Removed capabilities\n+optional" + } + }, + "description": "Adds and removes POSIX capabilities from running containers." + }, + "k8s.io.api.core.v1.CephFSVolumeSource": { + "type": "object", + "properties": { + "monitors": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Required: Monitors is a collection of Ceph monitors\nMore info: https://examples.k8s.io/volumes/cephfs/README.md#how-to-use-it" + }, + "path": { + "type": "string", + "title": "Optional: Used as the mounted root, rather than the full Ceph tree, default is /\n+optional" + }, + "user": { + "type": "string", + "title": "Optional: User is the rados user name, default is admin\nMore info: https://examples.k8s.io/volumes/cephfs/README.md#how-to-use-it\n+optional" + }, + "secretFile": { + "type": "string", + "title": "Optional: SecretFile is the path to key ring for User, default is /etc/ceph/user.secret\nMore info: https://examples.k8s.io/volumes/cephfs/README.md#how-to-use-it\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "Optional: SecretRef is reference to the authentication secret for User, default is empty.\nMore info: https://examples.k8s.io/volumes/cephfs/README.md#how-to-use-it\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Optional: Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\nMore info: https://examples.k8s.io/volumes/cephfs/README.md#how-to-use-it\n+optional" + } + }, + "description": "Represents a Ceph Filesystem mount that lasts the lifetime of a pod\nCephfs volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.CinderVolumeSource": { + "type": "object", + "properties": { + "volumeID": { + "type": "string", + "title": "volume id used to identify the volume in cinder.\nMore info: https://examples.k8s.io/mysql-cinder-pd/README.md" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nExamples: \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nMore info: https://examples.k8s.io/mysql-cinder-pd/README.md\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Optional: Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\nMore info: https://examples.k8s.io/mysql-cinder-pd/README.md\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "Optional: points to a secret object containing parameters used to connect\nto OpenStack.\n+optional" + } + }, + "description": "Represents a cinder volume resource in Openstack.\nA Cinder volume must exist before mounting to a container.\nThe volume must also be in the same region as the kubelet.\nCinder volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.ConfigMapEnvSource": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "description": "The ConfigMap to select from." + }, + "optional": { + "type": "boolean", + "title": "Specify whether the ConfigMap must be defined\n+optional" + } + }, + "description": "ConfigMapEnvSource selects a ConfigMap to populate the environment\nvariables with.\n\nThe contents of the target ConfigMap's Data field will represent the\nkey-value pairs as environment variables." + }, + "k8s.io.api.core.v1.ConfigMapKeySelector": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "description": "The ConfigMap to select from." + }, + "key": { + "type": "string", + "description": "The key to select." + }, + "optional": { + "type": "boolean", + "title": "Specify whether the ConfigMap or its key must be defined\n+optional" + } + }, + "description": "Selects a key from a ConfigMap." + }, + "k8s.io.api.core.v1.ConfigMapProjection": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference" + }, + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.KeyToPath" + }, + "title": "If unspecified, each key-value pair in the Data field of the referenced\nConfigMap will be projected into the volume as a file whose name is the\nkey and content is the value. If specified, the listed keys will be\nprojected into the specified paths, and unlisted keys will not be\npresent. If a key is specified which is not present in the ConfigMap,\nthe volume setup will error unless it is marked optional. Paths must be\nrelative and may not contain the '..' path or start with '..'.\n+optional" + }, + "optional": { + "type": "boolean", + "title": "Specify whether the ConfigMap or its keys must be defined\n+optional" + } + }, + "description": "Adapts a ConfigMap into a projected volume.\n\nThe contents of the target ConfigMap's Data field will be presented in a\nprojected volume as files using the keys in the Data field as the file names,\nunless the items element is populated with specific mappings of keys to paths.\nNote that this is identical to a configmap volume source without the default\nmode." + }, + "k8s.io.api.core.v1.ConfigMapVolumeSource": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference" + }, + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.KeyToPath" + }, + "title": "If unspecified, each key-value pair in the Data field of the referenced\nConfigMap will be projected into the volume as a file whose name is the\nkey and content is the value. If specified, the listed keys will be\nprojected into the specified paths, and unlisted keys will not be\npresent. If a key is specified which is not present in the ConfigMap,\nthe volume setup will error unless it is marked optional. Paths must be\nrelative and may not contain the '..' path or start with '..'.\n+optional" + }, + "defaultMode": { + "type": "integer", + "format": "int32", + "title": "Optional: mode bits used to set permissions on created files by default.\nMust be an octal value between 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values for mode bits.\nDefaults to 0644.\nDirectories within the path are not affected by this setting.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + }, + "optional": { + "type": "boolean", + "title": "Specify whether the ConfigMap or its keys must be defined\n+optional" + } + }, + "description": "Adapts a ConfigMap into a volume.\n\nThe contents of the target ConfigMap's Data field will be presented in a\nvolume as files using the keys in the Data field as the file names, unless\nthe items element is populated with specific mappings of keys to paths.\nConfigMap volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.Container": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Name of the container specified as a DNS_LABEL.\nEach container in a pod must have a unique name (DNS_LABEL).\nCannot be updated." + }, + "image": { + "type": "string", + "title": "Docker image name.\nMore info: https://kubernetes.io/docs/concepts/containers/images\nThis field is optional to allow higher level config management to default or override\ncontainer images in workload controllers like Deployments and StatefulSets.\n+optional" + }, + "command": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Entrypoint array. Not executed within a shell.\nThe docker image's ENTRYPOINT is used if this is not provided.\nVariable references $(VAR_NAME) are expanded using the container's environment. If a variable\ncannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax\ncan be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded,\nregardless of whether the variable exists or not.\nCannot be updated.\nMore info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n+optional" + }, + "args": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Arguments to the entrypoint.\nThe docker image's CMD is used if this is not provided.\nVariable references $(VAR_NAME) are expanded using the container's environment. If a variable\ncannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax\ncan be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded,\nregardless of whether the variable exists or not.\nCannot be updated.\nMore info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n+optional" + }, + "workingDir": { + "type": "string", + "title": "Container's working directory.\nIf not specified, the container runtime's default will be used, which\nmight be configured in the container image.\nCannot be updated.\n+optional" + }, + "ports": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.ContainerPort" + }, + "title": "List of ports to expose from the container. Exposing a port here gives\nthe system additional information about the network connections a\ncontainer uses, but is primarily informational. Not specifying a port here\nDOES NOT prevent that port from being exposed. Any port which is\nlistening on the default \"0.0.0.0\" address inside a container will be\naccessible from the network.\nCannot be updated.\n+optional\n+patchMergeKey=containerPort\n+patchStrategy=merge\n+listType=map\n+listMapKey=containerPort\n+listMapKey=protocol" + }, + "envFrom": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.EnvFromSource" + }, + "title": "List of sources to populate environment variables in the container.\nThe keys defined within a source must be a C_IDENTIFIER. All invalid keys\nwill be reported as an event when the container is starting. When a key exists in multiple\nsources, the value associated with the last source will take precedence.\nValues defined by an Env with a duplicate key will take precedence.\nCannot be updated.\n+optional" + }, + "env": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.EnvVar" + }, + "title": "List of environment variables to set in the container.\nCannot be updated.\n+optional\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "resources": { + "$ref": "#/definitions/k8s.io.api.core.v1.ResourceRequirements", + "title": "Compute Resources required by this container.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/\n+optional" + }, + "volumeMounts": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeMount" + }, + "title": "Pod volumes to mount into the container's filesystem.\nCannot be updated.\n+optional\n+patchMergeKey=mountPath\n+patchStrategy=merge" + }, + "volumeDevices": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeDevice" + }, + "title": "volumeDevices is the list of block devices to be used by the container.\n+patchMergeKey=devicePath\n+patchStrategy=merge\n+optional" + }, + "livenessProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "Periodic probe of container liveness.\nContainer will be restarted if the probe fails.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n+optional" + }, + "readinessProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "Periodic probe of container service readiness.\nContainer will be removed from service endpoints if the probe fails.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n+optional" + }, + "startupProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "StartupProbe indicates that the Pod has successfully initialized.\nIf specified, no other probes are executed until this completes successfully.\nIf this probe fails, the Pod will be restarted, just as if the livenessProbe failed.\nThis can be used to provide different probe parameters at the beginning of a Pod's lifecycle,\nwhen it might take a long time to load data or warm a cache, than during steady-state operation.\nThis cannot be updated.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n+optional" + }, + "lifecycle": { + "$ref": "#/definitions/k8s.io.api.core.v1.Lifecycle", + "title": "Actions that the management system should take in response to container lifecycle events.\nCannot be updated.\n+optional" + }, + "terminationMessagePath": { + "type": "string", + "title": "Optional: Path at which the file to which the container's termination message\nwill be written is mounted into the container's filesystem.\nMessage written is intended to be brief final status, such as an assertion failure message.\nWill be truncated by the node if greater than 4096 bytes. The total message length across\nall containers will be limited to 12kb.\nDefaults to /dev/termination-log.\nCannot be updated.\n+optional" + }, + "terminationMessagePolicy": { + "type": "string", + "title": "Indicate how the termination message should be populated. File will use the contents of\nterminationMessagePath to populate the container status message on both success and failure.\nFallbackToLogsOnError will use the last chunk of container log output if the termination\nmessage file is empty and the container exited with an error.\nThe log output is limited to 2048 bytes or 80 lines, whichever is smaller.\nDefaults to File.\nCannot be updated.\n+optional" + }, + "imagePullPolicy": { + "type": "string", + "title": "Image pull policy.\nOne of Always, Never, IfNotPresent.\nDefaults to Always if :latest tag is specified, or IfNotPresent otherwise.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/containers/images#updating-images\n+optional" + }, + "securityContext": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecurityContext", + "title": "Security options the pod should run with.\nMore info: https://kubernetes.io/docs/concepts/policy/security-context/\nMore info: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/\n+optional" + }, + "stdin": { + "type": "boolean", + "title": "Whether this container should allocate a buffer for stdin in the container runtime. If this\nis not set, reads from stdin in the container will always result in EOF.\nDefault is false.\n+optional" + }, + "stdinOnce": { + "type": "boolean", + "title": "Whether the container runtime should close the stdin channel after it has been opened by\na single attach. When stdin is true the stdin stream will remain open across multiple attach\nsessions. If stdinOnce is set to true, stdin is opened on container start, is empty until the\nfirst client attaches to stdin, and then remains open and accepts data until the client disconnects,\nat which time stdin is closed and remains closed until the container is restarted. If this\nflag is false, a container processes that reads from stdin will never receive an EOF.\nDefault is false\n+optional" + }, + "tty": { + "type": "boolean", + "title": "Whether this container should allocate a TTY for itself, also requires 'stdin' to be true.\nDefault is false.\n+optional" + } + }, + "description": "A single application container that you want to run within a pod." + }, + "k8s.io.api.core.v1.ContainerPort": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "If specified, this must be an IANA_SVC_NAME and unique within the pod. Each\nnamed port in a pod must have a unique name. Name for the port that can be\nreferred to by services.\n+optional" + }, + "hostPort": { + "type": "integer", + "format": "int32", + "title": "Number of port to expose on the host.\nIf specified, this must be a valid port number, 0 \u003c x \u003c 65536.\nIf HostNetwork is specified, this must match ContainerPort.\nMost containers do not need this.\n+optional" + }, + "containerPort": { + "type": "integer", + "format": "int32", + "description": "Number of port to expose on the pod's IP address.\nThis must be a valid port number, 0 \u003c x \u003c 65536." + }, + "protocol": { + "type": "string", + "title": "Protocol for port. Must be UDP, TCP, or SCTP.\nDefaults to \"TCP\".\n+optional\n+default=\"TCP\"" + }, + "hostIP": { + "type": "string", + "title": "What host IP to bind the external port to.\n+optional" + } + }, + "description": "ContainerPort represents a network port in a single container." + }, + "k8s.io.api.core.v1.DownwardAPIProjection": { + "type": "object", + "properties": { + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.DownwardAPIVolumeFile" + }, + "title": "Items is a list of DownwardAPIVolume file\n+optional" + } + }, + "description": "Represents downward API info for projecting into a projected volume.\nNote that this is identical to a downwardAPI volume source without the default\nmode." + }, + "k8s.io.api.core.v1.DownwardAPIVolumeFile": { + "type": "object", + "properties": { + "path": { + "type": "string", + "title": "Required: Path is the relative path name of the file to be created. Must not be absolute or contain the '..' path. Must be utf-8 encoded. The first item of the relative path must not start with '..'" + }, + "fieldRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ObjectFieldSelector", + "title": "Required: Selects a field of the pod: only annotations, labels, name and namespace are supported.\n+optional" + }, + "resourceFieldRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ResourceFieldSelector", + "title": "Selects a resource of the container: only resources limits and requests\n(limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported.\n+optional" + }, + "mode": { + "type": "integer", + "format": "int32", + "title": "Optional: mode bits used to set permissions on this file, must be an octal value\nbetween 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values for mode bits.\nIf not specified, the volume defaultMode will be used.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + } + }, + "title": "DownwardAPIVolumeFile represents information to create the file containing the pod field" + }, + "k8s.io.api.core.v1.DownwardAPIVolumeSource": { + "type": "object", + "properties": { + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.DownwardAPIVolumeFile" + }, + "title": "Items is a list of downward API volume file\n+optional" + }, + "defaultMode": { + "type": "integer", + "format": "int32", + "title": "Optional: mode bits to use on created files by default. Must be a\nOptional: mode bits used to set permissions on created files by default.\nMust be an octal value between 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values for mode bits.\nDefaults to 0644.\nDirectories within the path are not affected by this setting.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + } + }, + "description": "DownwardAPIVolumeSource represents a volume containing downward API info.\nDownward API volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.EmptyDirVolumeSource": { + "type": "object", + "properties": { + "medium": { + "type": "string", + "title": "What type of storage medium should back this directory.\nThe default is \"\" which means to use the node's default medium.\nMust be an empty string (default) or Memory.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#emptydir\n+optional" + }, + "sizeLimit": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.api.resource.Quantity", + "title": "Total amount of local storage required for this EmptyDir volume.\nThe size limit is also applicable for memory medium.\nThe maximum usage on memory medium EmptyDir would be the minimum value between\nthe SizeLimit specified here and the sum of memory limits of all containers in a pod.\nThe default is nil which means that the limit is undefined.\nMore info: http://kubernetes.io/docs/user-guide/volumes#emptydir\n+optional" + } + }, + "description": "Represents an empty directory for a pod.\nEmpty directory volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.EnvFromSource": { + "type": "object", + "properties": { + "prefix": { + "type": "string", + "title": "An optional identifier to prepend to each key in the ConfigMap. Must be a C_IDENTIFIER.\n+optional" + }, + "configMapRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ConfigMapEnvSource", + "title": "The ConfigMap to select from\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecretEnvSource", + "title": "The Secret to select from\n+optional" + } + }, + "title": "EnvFromSource represents the source of a set of ConfigMaps" + }, + "k8s.io.api.core.v1.EnvVar": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Name of the environment variable. Must be a C_IDENTIFIER." + }, + "value": { + "type": "string", + "title": "Variable references $(VAR_NAME) are expanded\nusing the previous defined environment variables in the container and\nany service environment variables. If a variable cannot be resolved,\nthe reference in the input string will be unchanged. The $(VAR_NAME)\nsyntax can be escaped with a double $$, ie: $$(VAR_NAME). Escaped\nreferences will never be expanded, regardless of whether the variable\nexists or not.\nDefaults to \"\".\n+optional" + }, + "valueFrom": { + "$ref": "#/definitions/k8s.io.api.core.v1.EnvVarSource", + "title": "Source for the environment variable's value. Cannot be used if value is not empty.\n+optional" + } + }, + "description": "EnvVar represents an environment variable present in a Container." + }, + "k8s.io.api.core.v1.EnvVarSource": { + "type": "object", + "properties": { + "fieldRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ObjectFieldSelector", + "title": "Selects a field of the pod: supports metadata.name, metadata.namespace, `metadata.labels['\u003cKEY\u003e']`, `metadata.annotations['\u003cKEY\u003e']`,\nspec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs.\n+optional" + }, + "resourceFieldRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ResourceFieldSelector", + "title": "Selects a resource of the container: only resources limits and requests\n(limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported.\n+optional" + }, + "configMapKeyRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.ConfigMapKeySelector", + "title": "Selects a key of a ConfigMap.\n+optional" + }, + "secretKeyRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecretKeySelector", + "title": "Selects a key of a secret in the pod's namespace\n+optional" + } + }, + "description": "EnvVarSource represents a source for the value of an EnvVar." + }, + "k8s.io.api.core.v1.EphemeralContainer": { + "type": "object", + "properties": { + "ephemeralContainerCommon": { + "$ref": "#/definitions/k8s.io.api.core.v1.EphemeralContainerCommon", + "description": "Ephemeral containers have all of the fields of Container, plus additional fields\nspecific to ephemeral containers. Fields in common with Container are in the\nfollowing inlined struct so than an EphemeralContainer may easily be converted\nto a Container." + }, + "targetContainerName": { + "type": "string", + "title": "If set, the name of the container from PodSpec that this ephemeral container targets.\nThe ephemeral container will be run in the namespaces (IPC, PID, etc) of this container.\nIf not set then the ephemeral container is run in whatever namespaces are shared\nfor the pod. Note that the container runtime must support this feature.\n+optional" + } + }, + "description": "An EphemeralContainer is a container that may be added temporarily to an existing pod for\nuser-initiated activities such as debugging. Ephemeral containers have no resource or\nscheduling guarantees, and they will not be restarted when they exit or when a pod is\nremoved or restarted. If an ephemeral container causes a pod to exceed its resource\nallocation, the pod may be evicted.\nEphemeral containers may not be added by directly updating the pod spec. They must be added\nvia the pod's ephemeralcontainers subresource, and they will appear in the pod spec\nonce added.\nThis is an alpha feature enabled by the EphemeralContainers feature flag." + }, + "k8s.io.api.core.v1.EphemeralContainerCommon": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Name of the ephemeral container specified as a DNS_LABEL.\nThis name must be unique among all containers, init containers and ephemeral containers." + }, + "image": { + "type": "string", + "title": "Docker image name.\nMore info: https://kubernetes.io/docs/concepts/containers/images" + }, + "command": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Entrypoint array. Not executed within a shell.\nThe docker image's ENTRYPOINT is used if this is not provided.\nVariable references $(VAR_NAME) are expanded using the container's environment. If a variable\ncannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax\ncan be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded,\nregardless of whether the variable exists or not.\nCannot be updated.\nMore info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n+optional" + }, + "args": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Arguments to the entrypoint.\nThe docker image's CMD is used if this is not provided.\nVariable references $(VAR_NAME) are expanded using the container's environment. If a variable\ncannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax\ncan be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded,\nregardless of whether the variable exists or not.\nCannot be updated.\nMore info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n+optional" + }, + "workingDir": { + "type": "string", + "title": "Container's working directory.\nIf not specified, the container runtime's default will be used, which\nmight be configured in the container image.\nCannot be updated.\n+optional" + }, + "ports": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.ContainerPort" + }, + "description": "Ports are not allowed for ephemeral containers." + }, + "envFrom": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.EnvFromSource" + }, + "title": "List of sources to populate environment variables in the container.\nThe keys defined within a source must be a C_IDENTIFIER. All invalid keys\nwill be reported as an event when the container is starting. When a key exists in multiple\nsources, the value associated with the last source will take precedence.\nValues defined by an Env with a duplicate key will take precedence.\nCannot be updated.\n+optional" + }, + "env": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.EnvVar" + }, + "title": "List of environment variables to set in the container.\nCannot be updated.\n+optional\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "resources": { + "$ref": "#/definitions/k8s.io.api.core.v1.ResourceRequirements", + "title": "Resources are not allowed for ephemeral containers. Ephemeral containers use spare resources\nalready allocated to the pod.\n+optional" + }, + "volumeMounts": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeMount" + }, + "title": "Pod volumes to mount into the container's filesystem.\nCannot be updated.\n+optional\n+patchMergeKey=mountPath\n+patchStrategy=merge" + }, + "volumeDevices": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeDevice" + }, + "title": "volumeDevices is the list of block devices to be used by the container.\n+patchMergeKey=devicePath\n+patchStrategy=merge\n+optional" + }, + "livenessProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "Probes are not allowed for ephemeral containers.\n+optional" + }, + "readinessProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "Probes are not allowed for ephemeral containers.\n+optional" + }, + "startupProbe": { + "$ref": "#/definitions/k8s.io.api.core.v1.Probe", + "title": "Probes are not allowed for ephemeral containers.\n+optional" + }, + "lifecycle": { + "$ref": "#/definitions/k8s.io.api.core.v1.Lifecycle", + "title": "Lifecycle is not allowed for ephemeral containers.\n+optional" + }, + "terminationMessagePath": { + "type": "string", + "title": "Optional: Path at which the file to which the container's termination message\nwill be written is mounted into the container's filesystem.\nMessage written is intended to be brief final status, such as an assertion failure message.\nWill be truncated by the node if greater than 4096 bytes. The total message length across\nall containers will be limited to 12kb.\nDefaults to /dev/termination-log.\nCannot be updated.\n+optional" + }, + "terminationMessagePolicy": { + "type": "string", + "title": "Indicate how the termination message should be populated. File will use the contents of\nterminationMessagePath to populate the container status message on both success and failure.\nFallbackToLogsOnError will use the last chunk of container log output if the termination\nmessage file is empty and the container exited with an error.\nThe log output is limited to 2048 bytes or 80 lines, whichever is smaller.\nDefaults to File.\nCannot be updated.\n+optional" + }, + "imagePullPolicy": { + "type": "string", + "title": "Image pull policy.\nOne of Always, Never, IfNotPresent.\nDefaults to Always if :latest tag is specified, or IfNotPresent otherwise.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/containers/images#updating-images\n+optional" + }, + "securityContext": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecurityContext", + "title": "SecurityContext is not allowed for ephemeral containers.\n+optional" + }, + "stdin": { + "type": "boolean", + "title": "Whether this container should allocate a buffer for stdin in the container runtime. If this\nis not set, reads from stdin in the container will always result in EOF.\nDefault is false.\n+optional" + }, + "stdinOnce": { + "type": "boolean", + "title": "Whether the container runtime should close the stdin channel after it has been opened by\na single attach. When stdin is true the stdin stream will remain open across multiple attach\nsessions. If stdinOnce is set to true, stdin is opened on container start, is empty until the\nfirst client attaches to stdin, and then remains open and accepts data until the client disconnects,\nat which time stdin is closed and remains closed until the container is restarted. If this\nflag is false, a container processes that reads from stdin will never receive an EOF.\nDefault is false\n+optional" + }, + "tty": { + "type": "boolean", + "title": "Whether this container should allocate a TTY for itself, also requires 'stdin' to be true.\nDefault is false.\n+optional" + } + }, + "description": "EphemeralContainerCommon is a copy of all fields in Container to be inlined in\nEphemeralContainer. This separate type allows easy conversion from EphemeralContainer\nto Container and allows separate documentation for the fields of EphemeralContainer.\nWhen a new field is added to Container it must be added here as well." + }, + "k8s.io.api.core.v1.EphemeralVolumeSource": { + "type": "object", + "properties": { + "volumeClaimTemplate": { + "$ref": "#/definitions/k8s.io.api.core.v1.PersistentVolumeClaimTemplate", + "description": "Will be used to create a stand-alone PVC to provision the volume.\nThe pod in which this EphemeralVolumeSource is embedded will be the\nowner of the PVC, i.e. the PVC will be deleted together with the\npod. The name of the PVC will be `\u003cpod name\u003e-\u003cvolume name\u003e` where\n`\u003cvolume name\u003e` is the name from the `PodSpec.Volumes` array\nentry. Pod validation will reject the pod if the concatenated name\nis not valid for a PVC (for example, too long).\n\nAn existing PVC with that name that is not owned by the pod\nwill *not* be used for the pod to avoid using an unrelated\nvolume by mistake. Starting the pod is then blocked until\nthe unrelated PVC is removed. If such a pre-created PVC is\nmeant to be used by the pod, the PVC has to updated with an\nowner reference to the pod once the pod exists. Normally\nthis should not be necessary, but it may be useful when\nmanually reconstructing a broken cluster.\n\nThis field is read-only and no changes will be made by Kubernetes\nto the PVC after it has been created.\n\nRequired, must not be nil." + }, + "readOnly": { + "type": "boolean", + "title": "Specifies a read-only configuration for the volume.\nDefaults to false (read/write).\n+optional" + } + }, + "description": "Represents an ephemeral volume that is handled by a normal storage driver." + }, + "k8s.io.api.core.v1.ExecAction": { + "type": "object", + "properties": { + "command": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Command is the command line to execute inside the container, the working directory for the\ncommand is root ('/') in the container's filesystem. The command is simply exec'd, it is\nnot run inside a shell, so traditional shell instructions ('|', etc) won't work. To use\na shell, you need to explicitly call out to that shell.\nExit status of 0 is treated as live/healthy and non-zero is unhealthy.\n+optional" + } + }, + "description": "ExecAction describes a \"run in container\" action." + }, + "k8s.io.api.core.v1.FCVolumeSource": { + "type": "object", + "properties": { + "targetWWNs": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Optional: FC target worldwide names (WWNs)\n+optional" + }, + "lun": { + "type": "integer", + "format": "int32", + "title": "Optional: FC target lun number\n+optional" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nTODO: how do we prevent errors in the filesystem from compromising the machine\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Optional: Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + }, + "wwids": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Optional: FC volume world wide identifiers (wwids)\nEither wwids or combination of targetWWNs and lun must be set, but not both simultaneously.\n+optional" + } + }, + "description": "Represents a Fibre Channel volume.\nFibre Channel volumes can only be mounted as read/write once.\nFibre Channel volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.FlexVolumeSource": { + "type": "object", + "properties": { + "driver": { + "type": "string", + "description": "Driver is the name of the driver to use for this volume." + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". The default filesystem depends on FlexVolume script.\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "Optional: SecretRef is reference to the secret object containing\nsensitive information to pass to the plugin scripts. This may be\nempty if no secret object is specified. If the secret object\ncontains more than one secret, all secrets are passed to the plugin\nscripts.\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Optional: Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + }, + "options": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "Optional: Extra command options if any.\n+optional" + } + }, + "description": "FlexVolume represents a generic volume resource that is\nprovisioned/attached using an exec based plugin." + }, + "k8s.io.api.core.v1.FlockerVolumeSource": { + "type": "object", + "properties": { + "datasetName": { + "type": "string", + "title": "Name of the dataset stored as metadata -\u003e name on the dataset for Flocker\nshould be considered as deprecated\n+optional" + }, + "datasetUUID": { + "type": "string", + "title": "UUID of the dataset. This is unique identifier of a Flocker dataset\n+optional" + } + }, + "description": "Represents a Flocker volume mounted by the Flocker agent.\nOne and only one of datasetName and datasetUUID should be set.\nFlocker volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.GCEPersistentDiskVolumeSource": { + "type": "object", + "properties": { + "pdName": { + "type": "string", + "title": "Unique name of the PD resource in GCE. Used to identify the disk in GCE.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk" + }, + "fsType": { + "type": "string", + "title": "Filesystem type of the volume that you want to mount.\nTip: Ensure that the filesystem type is supported by the host operating system.\nExamples: \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk\nTODO: how do we prevent errors in the filesystem from compromising the machine\n+optional" + }, + "partition": { + "type": "integer", + "format": "int32", + "title": "The partition in the volume that you want to mount.\nIf omitted, the default is to mount by volume name.\nExamples: For volume /dev/sda1, you specify the partition as \"1\".\nSimilarly, the volume partition for /dev/sda is \"0\" (or you can leave the property empty).\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force the ReadOnly setting in VolumeMounts.\nDefaults to false.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk\n+optional" + } + }, + "description": "Represents a Persistent Disk resource in Google Compute Engine.\n\nA GCE PD must exist before mounting to a container. The disk must\nalso be in the same GCE project and zone as the kubelet. A GCE PD\ncan only be mounted as read/write once or read-only many times. GCE\nPDs support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.GitRepoVolumeSource": { + "type": "object", + "properties": { + "repository": { + "type": "string", + "title": "Repository URL" + }, + "revision": { + "type": "string", + "title": "Commit hash for the specified revision.\n+optional" + }, + "directory": { + "type": "string", + "title": "Target directory name.\nMust not contain or start with '..'. If '.' is supplied, the volume directory will be the\ngit repository. Otherwise, if specified, the volume will contain the git repository in\nthe subdirectory with the given name.\n+optional" + } + }, + "description": "Represents a volume that is populated with the contents of a git repository.\nGit repo volumes do not support ownership management.\nGit repo volumes support SELinux relabeling.\n\nDEPRECATED: GitRepo is deprecated. To provision a container with a git repo, mount an\nEmptyDir into an InitContainer that clones the repo using git, then mount the EmptyDir\ninto the Pod's container." + }, + "k8s.io.api.core.v1.GlusterfsVolumeSource": { + "type": "object", + "properties": { + "endpoints": { + "type": "string", + "title": "EndpointsName is the endpoint name that details Glusterfs topology.\nMore info: https://examples.k8s.io/volumes/glusterfs/README.md#create-a-pod" + }, + "path": { + "type": "string", + "title": "Path is the Glusterfs volume path.\nMore info: https://examples.k8s.io/volumes/glusterfs/README.md#create-a-pod" + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force the Glusterfs volume to be mounted with read-only permissions.\nDefaults to false.\nMore info: https://examples.k8s.io/volumes/glusterfs/README.md#create-a-pod\n+optional" + } + }, + "description": "Represents a Glusterfs mount that lasts the lifetime of a pod.\nGlusterfs volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.HTTPGetAction": { + "type": "object", + "properties": { + "path": { + "type": "string", + "title": "Path to access on the HTTP server.\n+optional" + }, + "port": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "description": "Name or number of the port to access on the container.\nNumber must be in the range 1 to 65535.\nName must be an IANA_SVC_NAME." + }, + "host": { + "type": "string", + "title": "Host name to connect to, defaults to the pod IP. You probably want to set\n\"Host\" in httpHeaders instead.\n+optional" + }, + "scheme": { + "type": "string", + "title": "Scheme to use for connecting to the host.\nDefaults to HTTP.\n+optional" + }, + "httpHeaders": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.HTTPHeader" + }, + "title": "Custom headers to set in the request. HTTP allows repeated headers.\n+optional" + } + }, + "description": "HTTPGetAction describes an action based on HTTP Get requests." + }, + "k8s.io.api.core.v1.HTTPHeader": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "The header field name" + }, + "value": { + "type": "string", + "title": "The header field value" + } + }, + "title": "HTTPHeader describes a custom header to be used in HTTP probes" + }, + "k8s.io.api.core.v1.Handler": { + "type": "object", + "properties": { + "exec": { + "$ref": "#/definitions/k8s.io.api.core.v1.ExecAction", + "title": "One and only one of the following should be specified.\nExec specifies the action to take.\n+optional" + }, + "httpGet": { + "$ref": "#/definitions/k8s.io.api.core.v1.HTTPGetAction", + "title": "HTTPGet specifies the http request to perform.\n+optional" + }, + "tcpSocket": { + "$ref": "#/definitions/k8s.io.api.core.v1.TCPSocketAction", + "title": "TCPSocket specifies an action involving a TCP port.\nTCP hooks not yet supported\nTODO: implement a realistic TCP lifecycle hook\n+optional" + } + }, + "description": "Handler defines a specific action that should be taken\nTODO: pass structured data to these actions, and document that data here." + }, + "k8s.io.api.core.v1.HostAlias": { + "type": "object", + "properties": { + "ip": { + "type": "string", + "description": "IP address of the host file entry." + }, + "hostnames": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Hostnames for the above IP address." + } + }, + "description": "HostAlias holds the mapping between IP and hostnames that will be injected as an entry in the\npod's hosts file." + }, + "k8s.io.api.core.v1.HostPathVolumeSource": { + "type": "object", + "properties": { + "path": { + "type": "string", + "title": "Path of the directory on the host.\nIf the path is a symlink, it will follow the link to the real path.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#hostpath" + }, + "type": { + "type": "string", + "title": "Type for HostPath Volume\nDefaults to \"\"\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#hostpath\n+optional" + } + }, + "description": "Represents a host path mapped into a pod.\nHost path volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.ISCSIVolumeSource": { + "type": "object", + "properties": { + "targetPortal": { + "type": "string", + "description": "iSCSI Target Portal. The Portal is either an IP or ip_addr:port if the port\nis other than default (typically TCP ports 860 and 3260)." + }, + "iqn": { + "type": "string", + "description": "Target iSCSI Qualified Name." + }, + "lun": { + "type": "integer", + "format": "int32", + "description": "iSCSI Target Lun number." + }, + "iscsiInterface": { + "type": "string", + "title": "iSCSI Interface Name that uses an iSCSI transport.\nDefaults to 'default' (tcp).\n+optional" + }, + "fsType": { + "type": "string", + "title": "Filesystem type of the volume that you want to mount.\nTip: Ensure that the filesystem type is supported by the host operating system.\nExamples: \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#iscsi\nTODO: how do we prevent errors in the filesystem from compromising the machine\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force the ReadOnly setting in VolumeMounts.\nDefaults to false.\n+optional" + }, + "portals": { + "type": "array", + "items": { + "type": "string" + }, + "title": "iSCSI Target Portal List. The portal is either an IP or ip_addr:port if the port\nis other than default (typically TCP ports 860 and 3260).\n+optional" + }, + "chapAuthDiscovery": { + "type": "boolean", + "title": "whether support iSCSI Discovery CHAP authentication\n+optional" + }, + "chapAuthSession": { + "type": "boolean", + "title": "whether support iSCSI Session CHAP authentication\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "CHAP Secret for iSCSI target and initiator authentication\n+optional" + }, + "initiatorName": { + "type": "string", + "title": "Custom iSCSI Initiator Name.\nIf initiatorName is specified with iscsiInterface simultaneously, new iSCSI interface\n\u003ctarget portal\u003e:\u003cvolume name\u003e will be created for the connection.\n+optional" + } + }, + "description": "Represents an ISCSI disk.\nISCSI volumes can only be mounted as read/write once.\nISCSI volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.KeyToPath": { + "type": "object", + "properties": { + "key": { + "type": "string", + "description": "The key to project." + }, + "path": { + "type": "string", + "description": "The relative path of the file to map the key to.\nMay not be an absolute path.\nMay not contain the path element '..'.\nMay not start with the string '..'." + }, + "mode": { + "type": "integer", + "format": "int32", + "title": "Optional: mode bits used to set permissions on this file.\nMust be an octal value between 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values for mode bits.\nIf not specified, the volume defaultMode will be used.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + } + }, + "description": "Maps a string key to a path within a volume." + }, + "k8s.io.api.core.v1.Lifecycle": { + "type": "object", + "properties": { + "postStart": { + "$ref": "#/definitions/k8s.io.api.core.v1.Handler", + "title": "PostStart is called immediately after a container is created. If the handler fails,\nthe container is terminated and restarted according to its restart policy.\nOther management of the container blocks until the hook completes.\nMore info: https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks\n+optional" + }, + "preStop": { + "$ref": "#/definitions/k8s.io.api.core.v1.Handler", + "title": "PreStop is called immediately before a container is terminated due to an\nAPI request or management event such as liveness/startup probe failure,\npreemption, resource contention, etc. The handler is not called if the\ncontainer crashes or exits. The reason for termination is passed to the\nhandler. The Pod's termination grace period countdown begins before the\nPreStop hooked is executed. Regardless of the outcome of the handler, the\ncontainer will eventually terminate within the Pod's termination grace\nperiod. Other management of the container blocks until the hook completes\nor until the termination grace period is reached.\nMore info: https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks\n+optional" + } + }, + "description": "Lifecycle describes actions that the management system should take in response to container lifecycle\nevents. For the PostStart and PreStop lifecycle handlers, management of the container blocks\nuntil the action is complete, unless the container process fails, in which case the handler is aborted." + }, + "k8s.io.api.core.v1.LocalObjectReference": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name of the referent.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names\nTODO: Add other useful fields. apiVersion, kind, uid?\n+optional" + } + }, + "description": "LocalObjectReference contains enough information to let you locate the\nreferenced object inside the same namespace." + }, + "k8s.io.api.core.v1.NFSVolumeSource": { + "type": "object", + "properties": { + "server": { + "type": "string", + "title": "Server is the hostname or IP address of the NFS server.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#nfs" + }, + "path": { + "type": "string", + "title": "Path that is exported by the NFS server.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#nfs" + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force\nthe NFS export to be mounted with read-only permissions.\nDefaults to false.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#nfs\n+optional" + } + }, + "description": "Represents an NFS mount that lasts the lifetime of a pod.\nNFS volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.NodeAffinity": { + "type": "object", + "properties": { + "requiredDuringSchedulingIgnoredDuringExecution": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeSelector", + "title": "If the affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to an update), the system\nmay or may not try to eventually evict the pod from its node.\n+optional" + }, + "preferredDuringSchedulingIgnoredDuringExecution": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.PreferredSchedulingTerm" + }, + "title": "The scheduler will prefer to schedule pods to nodes that satisfy\nthe affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node matches the corresponding matchExpressions; the\nnode(s) with the highest sum are the most preferred.\n+optional" + } + }, + "description": "Node affinity is a group of node affinity scheduling rules." + }, + "k8s.io.api.core.v1.NodeSelector": { + "type": "object", + "properties": { + "nodeSelectorTerms": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeSelectorTerm" + }, + "description": "Required. A list of node selector terms. The terms are ORed." + } + }, + "description": "A node selector represents the union of the results of one or more label queries\nover a set of nodes; that is, it represents the OR of the selectors represented\nby the node selector terms." + }, + "k8s.io.api.core.v1.NodeSelectorRequirement": { + "type": "object", + "properties": { + "key": { + "type": "string", + "description": "The label key that the selector applies to." + }, + "operator": { + "type": "string", + "description": "Represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt." + }, + "values": { + "type": "array", + "items": { + "type": "string" + }, + "title": "An array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. If the operator is Gt or Lt, the values\narray must have a single element, which will be interpreted as an integer.\nThis array is replaced during a strategic merge patch.\n+optional" + } + }, + "description": "A node selector requirement is a selector that contains values, a key, and an operator\nthat relates the key and values." + }, + "k8s.io.api.core.v1.NodeSelectorTerm": { + "type": "object", + "properties": { + "matchExpressions": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeSelectorRequirement" + }, + "title": "A list of node selector requirements by node's labels.\n+optional" + }, + "matchFields": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeSelectorRequirement" + }, + "title": "A list of node selector requirements by node's fields.\n+optional" + } + }, + "description": "A null or empty node selector term matches no objects. The requirements of\nthem are ANDed.\nThe TopologySelectorTerm type implements a subset of the NodeSelectorTerm." + }, + "k8s.io.api.core.v1.ObjectFieldSelector": { + "type": "object", + "properties": { + "apiVersion": { + "type": "string", + "title": "Version of the schema the FieldPath is written in terms of, defaults to \"v1\".\n+optional" + }, + "fieldPath": { + "type": "string", + "description": "Path of the field to select in the specified API version." + } + }, + "description": "ObjectFieldSelector selects an APIVersioned field of an object." + }, + "k8s.io.api.core.v1.PersistentVolumeClaimSpec": { + "type": "object", + "properties": { + "accessModes": { + "type": "array", + "items": { + "type": "string" + }, + "title": "AccessModes contains the desired access modes the volume should have.\nMore info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes-1\n+optional" + }, + "selector": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector", + "title": "A label query over volumes to consider for binding.\n+optional" + }, + "resources": { + "$ref": "#/definitions/k8s.io.api.core.v1.ResourceRequirements", + "title": "Resources represents the minimum resources the volume should have.\nMore info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources\n+optional" + }, + "volumeName": { + "type": "string", + "title": "VolumeName is the binding reference to the PersistentVolume backing this claim.\n+optional" + }, + "storageClassName": { + "type": "string", + "title": "Name of the StorageClass required by the claim.\nMore info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#class-1\n+optional" + }, + "volumeMode": { + "type": "string", + "title": "volumeMode defines what type of volume is required by the claim.\nValue of Filesystem is implied when not included in claim spec.\n+optional" + }, + "dataSource": { + "$ref": "#/definitions/k8s.io.api.core.v1.TypedLocalObjectReference", + "title": "This field can be used to specify either:\n* An existing VolumeSnapshot object (snapshot.storage.k8s.io/VolumeSnapshot)\n* An existing PVC (PersistentVolumeClaim)\n* An existing custom resource that implements data population (Alpha)\nIn order to use custom resource types that implement data population,\nthe AnyVolumeDataSource feature gate must be enabled.\nIf the provisioner or an external controller can support the specified data source,\nit will create a new volume based on the contents of the specified data source.\n+optional" + } + }, + "title": "PersistentVolumeClaimSpec describes the common attributes of storage devices\nand allows a Source for provider-specific attributes" + }, + "k8s.io.api.core.v1.PersistentVolumeClaimTemplate": { + "type": "object", + "properties": { + "metadata": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta", + "description": "May contain labels and annotations that will be copied into the PVC\nwhen creating it. No other fields are allowed and will be rejected during\nvalidation.\n\n+optional" + }, + "spec": { + "$ref": "#/definitions/k8s.io.api.core.v1.PersistentVolumeClaimSpec", + "description": "The specification for the PersistentVolumeClaim. The entire content is\ncopied unchanged into the PVC that gets created from this\ntemplate. The same fields as in a PersistentVolumeClaim\nare also valid here." + } + }, + "description": "PersistentVolumeClaimTemplate is used to produce\nPersistentVolumeClaim objects as part of an EphemeralVolumeSource." + }, + "k8s.io.api.core.v1.PersistentVolumeClaimVolumeSource": { + "type": "object", + "properties": { + "claimName": { + "type": "string", + "title": "ClaimName is the name of a PersistentVolumeClaim in the same namespace as the pod using this volume.\nMore info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistentvolumeclaims" + }, + "readOnly": { + "type": "boolean", + "title": "Will force the ReadOnly setting in VolumeMounts.\nDefault false.\n+optional" + } + }, + "description": "PersistentVolumeClaimVolumeSource references the user's PVC in the same namespace.\nThis volume finds the bound PV and mounts that volume for the pod. A\nPersistentVolumeClaimVolumeSource is, essentially, a wrapper around another\ntype of volume that is owned by someone else (the system)." + }, + "k8s.io.api.core.v1.PhotonPersistentDiskVolumeSource": { + "type": "object", + "properties": { + "pdID": { + "type": "string", + "title": "ID that identifies Photon Controller persistent disk" + }, + "fsType": { + "type": "string", + "description": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified." + } + }, + "description": "Represents a Photon Controller persistent disk resource." + }, + "k8s.io.api.core.v1.PodAffinity": { + "type": "object", + "properties": { + "requiredDuringSchedulingIgnoredDuringExecution": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodAffinityTerm" + }, + "title": "If the affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to a pod label update), the\nsystem may or may not try to eventually evict the pod from its node.\nWhen there are multiple elements, the lists of nodes corresponding to each\npodAffinityTerm are intersected, i.e. all terms must be satisfied.\n+optional" + }, + "preferredDuringSchedulingIgnoredDuringExecution": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.WeightedPodAffinityTerm" + }, + "title": "The scheduler will prefer to schedule pods to nodes that satisfy\nthe affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the\nnode(s) with the highest sum are the most preferred.\n+optional" + } + }, + "description": "Pod affinity is a group of inter pod affinity scheduling rules." + }, + "k8s.io.api.core.v1.PodAffinityTerm": { + "type": "object", + "properties": { + "labelSelector": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector", + "title": "A label query over a set of resources, in this case pods.\n+optional" + }, + "namespaces": { + "type": "array", + "items": { + "type": "string" + }, + "title": "namespaces specifies which namespaces the labelSelector applies to (matches against);\nnull or empty list means \"this pod's namespace\"\n+optional" + }, + "topologyKey": { + "type": "string", + "description": "This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching\nthe labelSelector in the specified namespaces, where co-located is defined as running on a node\nwhose value of the label with key topologyKey matches that of any node on which any of the\nselected pods is running.\nEmpty topologyKey is not allowed." + } + }, + "title": "Defines a set of pods (namely those matching the labelSelector\nrelative to the given namespace(s)) that this pod should be\nco-located (affinity) or not co-located (anti-affinity) with,\nwhere co-located is defined as running on a node whose value of\nthe label with key \u003ctopologyKey\u003e matches that of any node on which\na pod of the set of pods is running" + }, + "k8s.io.api.core.v1.PodAntiAffinity": { + "type": "object", + "properties": { + "requiredDuringSchedulingIgnoredDuringExecution": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodAffinityTerm" + }, + "title": "If the anti-affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the anti-affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to a pod label update), the\nsystem may or may not try to eventually evict the pod from its node.\nWhen there are multiple elements, the lists of nodes corresponding to each\npodAffinityTerm are intersected, i.e. all terms must be satisfied.\n+optional" + }, + "preferredDuringSchedulingIgnoredDuringExecution": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.WeightedPodAffinityTerm" + }, + "title": "The scheduler will prefer to schedule pods to nodes that satisfy\nthe anti-affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling anti-affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the\nnode(s) with the highest sum are the most preferred.\n+optional" + } + }, + "description": "Pod anti affinity is a group of inter pod anti affinity scheduling rules." + }, + "k8s.io.api.core.v1.PodDNSConfig": { + "type": "object", + "properties": { + "nameservers": { + "type": "array", + "items": { + "type": "string" + }, + "title": "A list of DNS name server IP addresses.\nThis will be appended to the base nameservers generated from DNSPolicy.\nDuplicated nameservers will be removed.\n+optional" + }, + "searches": { + "type": "array", + "items": { + "type": "string" + }, + "title": "A list of DNS search domains for host-name lookup.\nThis will be appended to the base search paths generated from DNSPolicy.\nDuplicated search paths will be removed.\n+optional" + }, + "options": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodDNSConfigOption" + }, + "title": "A list of DNS resolver options.\nThis will be merged with the base options generated from DNSPolicy.\nDuplicated entries will be removed. Resolution options given in Options\nwill override those that appear in the base DNSPolicy.\n+optional" + } + }, + "description": "PodDNSConfig defines the DNS parameters of a pod in addition to\nthose generated from DNSPolicy." + }, + "k8s.io.api.core.v1.PodDNSConfigOption": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Required." + }, + "value": { + "type": "string", + "title": "+optional" + } + }, + "description": "PodDNSConfigOption defines DNS resolver options of a pod." + }, + "k8s.io.api.core.v1.PodReadinessGate": { + "type": "object", + "properties": { + "conditionType": { + "type": "string", + "description": "ConditionType refers to a condition in the pod's condition list with matching type." + } + }, + "title": "PodReadinessGate contains the reference to a pod condition" + }, + "k8s.io.api.core.v1.PodSecurityContext": { + "type": "object", + "properties": { + "seLinuxOptions": { + "$ref": "#/definitions/k8s.io.api.core.v1.SELinuxOptions", + "title": "The SELinux context to be applied to all containers.\nIf unspecified, the container runtime will allocate a random SELinux context for each\ncontainer. May also be set in SecurityContext. If set in\nboth SecurityContext and PodSecurityContext, the value specified in SecurityContext\ntakes precedence for that container.\n+optional" + }, + "windowsOptions": { + "$ref": "#/definitions/k8s.io.api.core.v1.WindowsSecurityContextOptions", + "title": "The Windows specific settings applied to all containers.\nIf unspecified, the options within a container's SecurityContext will be used.\nIf set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "runAsUser": { + "type": "string", + "format": "int64", + "title": "The UID to run the entrypoint of the container process.\nDefaults to user specified in image metadata if unspecified.\nMay also be set in SecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence\nfor that container.\n+optional" + }, + "runAsGroup": { + "type": "string", + "format": "int64", + "title": "The GID to run the entrypoint of the container process.\nUses runtime default if unset.\nMay also be set in SecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence\nfor that container.\n+optional" + }, + "runAsNonRoot": { + "type": "boolean", + "title": "Indicates that the container must run as a non-root user.\nIf true, the Kubelet will validate the image at runtime to ensure that it\ndoes not run as UID 0 (root) and fail to start the container if it does.\nIf unset or false, no such validation will be performed.\nMay also be set in SecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "supplementalGroups": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "title": "A list of groups applied to the first process run in each container, in addition\nto the container's primary GID. If unspecified, no groups will be added to\nany container.\n+optional" + }, + "fsGroup": { + "type": "string", + "format": "int64", + "description": "1. The owning GID will be the FSGroup\n2. The setgid bit is set (new files created in the volume will be owned by FSGroup)\n3. The permission bits are OR'd with rw-rw----\n\nIf unset, the Kubelet will not modify the ownership and permissions of any volume.\n+optional", + "title": "A special supplemental group that applies to all containers in a pod.\nSome volume types allow the Kubelet to change the ownership of that volume\nto be owned by the pod:" + }, + "sysctls": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.Sysctl" + }, + "title": "Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported\nsysctls (by the container runtime) might fail to launch.\n+optional" + }, + "fsGroupChangePolicy": { + "type": "string", + "title": "fsGroupChangePolicy defines behavior of changing ownership and permission of the volume\nbefore being exposed inside Pod. This field will only apply to\nvolume types which support fsGroup based ownership(and permissions).\nIt will have no effect on ephemeral volume types such as: secret, configmaps\nand emptydir.\nValid values are \"OnRootMismatch\" and \"Always\". If not specified, \"Always\" is used.\n+optional" + }, + "seccompProfile": { + "$ref": "#/definitions/k8s.io.api.core.v1.SeccompProfile", + "title": "The seccomp options to use by the containers in this pod.\n+optional" + } + }, + "description": "PodSecurityContext holds pod-level security attributes and common container settings.\nSome fields are also present in container.securityContext. Field values of\ncontainer.securityContext take precedence over field values of PodSecurityContext." + }, + "k8s.io.api.core.v1.PodSpec": { + "type": "object", + "properties": { + "volumes": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.Volume" + }, + "title": "List of volumes that can be mounted by containers belonging to the pod.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes\n+optional\n+patchMergeKey=name\n+patchStrategy=merge,retainKeys" + }, + "initContainers": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.Container" + }, + "title": "List of initialization containers belonging to the pod.\nInit containers are executed in order prior to containers being started. If any\ninit container fails, the pod is considered to have failed and is handled according\nto its restartPolicy. The name for an init container or normal container must be\nunique among all containers.\nInit containers may not have Lifecycle actions, Readiness probes, Liveness probes, or Startup probes.\nThe resourceRequirements of an init container are taken into account during scheduling\nby finding the highest request/limit for each resource type, and then using the max of\nof that value or the sum of the normal containers. Limits are applied to init containers\nin a similar fashion.\nInit containers cannot currently be added or removed.\nCannot be updated.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/init-containers/\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "containers": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.Container" + }, + "title": "List of containers belonging to the pod.\nContainers cannot currently be added or removed.\nThere must be at least one container in a Pod.\nCannot be updated.\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "ephemeralContainers": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.EphemeralContainer" + }, + "title": "List of ephemeral containers run in this pod. Ephemeral containers may be run in an existing\npod to perform user-initiated actions such as debugging. This list cannot be specified when\ncreating a pod, and it cannot be modified by updating the pod spec. In order to add an\nephemeral container to an existing pod, use the pod's ephemeralcontainers subresource.\nThis field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.\n+optional\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "restartPolicy": { + "type": "string", + "title": "Restart policy for all containers within the pod.\nOne of Always, OnFailure, Never.\nDefault to Always.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#restart-policy\n+optional" + }, + "terminationGracePeriodSeconds": { + "type": "string", + "format": "int64", + "title": "Optional duration in seconds the pod needs to terminate gracefully. May be decreased in delete request.\nValue must be non-negative integer. The value zero indicates delete immediately.\nIf this value is nil, the default grace period will be used instead.\nThe grace period is the duration in seconds after the processes running in the pod are sent\na termination signal and the time when the processes are forcibly halted with a kill signal.\nSet this value longer than the expected cleanup time for your process.\nDefaults to 30 seconds.\n+optional" + }, + "activeDeadlineSeconds": { + "type": "string", + "format": "int64", + "title": "Optional duration in seconds the pod may be active on the node relative to\nStartTime before the system will actively try to mark it failed and kill associated containers.\nValue must be a positive integer.\n+optional" + }, + "dnsPolicy": { + "type": "string", + "title": "Set DNS policy for the pod.\nDefaults to \"ClusterFirst\".\nValid values are 'ClusterFirstWithHostNet', 'ClusterFirst', 'Default' or 'None'.\nDNS parameters given in DNSConfig will be merged with the policy selected with DNSPolicy.\nTo have DNS options set along with hostNetwork, you have to specify DNS policy\nexplicitly to 'ClusterFirstWithHostNet'.\n+optional" + }, + "nodeSelector": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "NodeSelector is a selector which must be true for the pod to fit on a node.\nSelector which must match a node's labels for the pod to be scheduled on that node.\nMore info: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/\n+optional" + }, + "serviceAccountName": { + "type": "string", + "title": "ServiceAccountName is the name of the ServiceAccount to use to run this pod.\nMore info: https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/\n+optional" + }, + "serviceAccount": { + "type": "string", + "title": "DeprecatedServiceAccount is a depreciated alias for ServiceAccountName.\nDeprecated: Use serviceAccountName instead.\n+k8s:conversion-gen=false\n+optional" + }, + "automountServiceAccountToken": { + "type": "boolean", + "title": "AutomountServiceAccountToken indicates whether a service account token should be automatically mounted.\n+optional" + }, + "nodeName": { + "type": "string", + "title": "NodeName is a request to schedule this pod onto a specific node. If it is non-empty,\nthe scheduler simply schedules this pod onto that node, assuming that it fits resource\nrequirements.\n+optional" + }, + "hostNetwork": { + "type": "boolean", + "title": "Host networking requested for this pod. Use the host's network namespace.\nIf this option is set, the ports that will be used must be specified.\nDefault to false.\n+k8s:conversion-gen=false\n+optional" + }, + "hostPID": { + "type": "boolean", + "title": "Use the host's pid namespace.\nOptional: Default to false.\n+k8s:conversion-gen=false\n+optional" + }, + "hostIPC": { + "type": "boolean", + "title": "Use the host's ipc namespace.\nOptional: Default to false.\n+k8s:conversion-gen=false\n+optional" + }, + "shareProcessNamespace": { + "type": "boolean", + "title": "Share a single process namespace between all of the containers in a pod.\nWhen this is set containers will be able to view and signal processes from other containers\nin the same pod, and the first process in each container will not be assigned PID 1.\nHostPID and ShareProcessNamespace cannot both be set.\nOptional: Default to false.\n+k8s:conversion-gen=false\n+optional" + }, + "securityContext": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodSecurityContext", + "title": "SecurityContext holds pod-level security attributes and common container settings.\nOptional: Defaults to empty. See type description for default values of each field.\n+optional" + }, + "imagePullSecrets": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference" + }, + "title": "ImagePullSecrets is an optional list of references to secrets in the same namespace to use for pulling any of the images used by this PodSpec.\nIf specified, these secrets will be passed to individual puller implementations for them to use. For example,\nin the case of docker, only DockerConfig type secrets are honored.\nMore info: https://kubernetes.io/docs/concepts/containers/images#specifying-imagepullsecrets-on-a-pod\n+optional\n+patchMergeKey=name\n+patchStrategy=merge" + }, + "hostname": { + "type": "string", + "title": "Specifies the hostname of the Pod\nIf not specified, the pod's hostname will be set to a system-defined value.\n+optional" + }, + "subdomain": { + "type": "string", + "title": "If specified, the fully qualified Pod hostname will be \"\u003chostname\u003e.\u003csubdomain\u003e.\u003cpod namespace\u003e.svc.\u003ccluster domain\u003e\".\nIf not specified, the pod will not have a domainname at all.\n+optional" + }, + "affinity": { + "$ref": "#/definitions/k8s.io.api.core.v1.Affinity", + "title": "If specified, the pod's scheduling constraints\n+optional" + }, + "schedulerName": { + "type": "string", + "title": "If specified, the pod will be dispatched by specified scheduler.\nIf not specified, the pod will be dispatched by default scheduler.\n+optional" + }, + "tolerations": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.Toleration" + }, + "title": "If specified, the pod's tolerations.\n+optional" + }, + "hostAliases": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.HostAlias" + }, + "title": "HostAliases is an optional list of hosts and IPs that will be injected into the pod's hosts\nfile if specified. This is only valid for non-hostNetwork pods.\n+optional\n+patchMergeKey=ip\n+patchStrategy=merge" + }, + "priorityClassName": { + "type": "string", + "title": "If specified, indicates the pod's priority. \"system-node-critical\" and\n\"system-cluster-critical\" are two special keywords which indicate the\nhighest priorities with the former being the highest priority. Any other\nname must be defined by creating a PriorityClass object with that name.\nIf not specified, the pod priority will be default or zero if there is no\ndefault.\n+optional" + }, + "priority": { + "type": "integer", + "format": "int32", + "title": "The priority value. Various system components use this field to find the\npriority of the pod. When Priority Admission Controller is enabled, it\nprevents users from setting this field. The admission controller populates\nthis field from PriorityClassName.\nThe higher the value, the higher the priority.\n+optional" + }, + "dnsConfig": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodDNSConfig", + "title": "Specifies the DNS parameters of a pod.\nParameters specified here will be merged to the generated DNS\nconfiguration based on DNSPolicy.\n+optional" + }, + "readinessGates": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodReadinessGate" + }, + "title": "If specified, all readiness gates will be evaluated for pod readiness.\nA pod is ready when all its containers are ready AND\nall conditions specified in the readiness gates have status equal to \"True\"\nMore info: https://git.k8s.io/enhancements/keps/sig-network/0007-pod-ready%2B%2B.md\n+optional" + }, + "runtimeClassName": { + "type": "string", + "title": "RuntimeClassName refers to a RuntimeClass object in the node.k8s.io group, which should be used\nto run this pod. If no RuntimeClass resource matches the named class, the pod will not be run.\nIf unset or empty, the \"legacy\" RuntimeClass will be used, which is an implicit class with an\nempty definition that uses the default runtime handler.\nMore info: https://git.k8s.io/enhancements/keps/sig-node/runtime-class.md\nThis is a beta feature as of Kubernetes v1.14.\n+optional" + }, + "enableServiceLinks": { + "type": "boolean", + "title": "EnableServiceLinks indicates whether information about services should be injected into pod's\nenvironment variables, matching the syntax of Docker links.\nOptional: Defaults to true.\n+optional" + }, + "preemptionPolicy": { + "type": "string", + "title": "PreemptionPolicy is the Policy for preempting pods with lower priority.\nOne of Never, PreemptLowerPriority.\nDefaults to PreemptLowerPriority if unset.\nThis field is beta-level, gated by the NonPreemptingPriority feature-gate.\n+optional" + }, + "overhead": { + "type": "object", + "additionalProperties": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.api.resource.Quantity" + }, + "title": "Overhead represents the resource overhead associated with running a pod for a given RuntimeClass.\nThis field will be autopopulated at admission time by the RuntimeClass admission controller. If\nthe RuntimeClass admission controller is enabled, overhead must not be set in Pod create requests.\nThe RuntimeClass admission controller will reject Pod create requests which have the overhead already\nset. If RuntimeClass is configured and selected in the PodSpec, Overhead will be set to the value\ndefined in the corresponding RuntimeClass, otherwise it will remain unset and treated as zero.\nMore info: https://git.k8s.io/enhancements/keps/sig-node/20190226-pod-overhead.md\nThis field is alpha-level as of Kubernetes v1.16, and is only honored by servers that enable the PodOverhead feature.\n+optional" + }, + "topologySpreadConstraints": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.TopologySpreadConstraint" + }, + "title": "TopologySpreadConstraints describes how a group of pods ought to spread across topology\ndomains. Scheduler will schedule pods in a way which abides by the constraints.\nAll topologySpreadConstraints are ANDed.\n+optional\n+patchMergeKey=topologyKey\n+patchStrategy=merge\n+listType=map\n+listMapKey=topologyKey\n+listMapKey=whenUnsatisfiable" + }, + "setHostnameAsFQDN": { + "type": "boolean", + "title": "If true the pod's hostname will be configured as the pod's FQDN, rather than the leaf name (the default).\nIn Linux containers, this means setting the FQDN in the hostname field of the kernel (the nodename field of struct utsname).\nIn Windows containers, this means setting the registry value of hostname for the registry key HKEY_LOCAL_MACHINE\\\\SYSTEM\\\\CurrentControlSet\\\\Services\\\\Tcpip\\\\Parameters to FQDN.\nIf a pod does not have FQDN, this has no effect.\nDefault to false.\n+optional" + } + }, + "description": "PodSpec is a description of a pod." + }, + "k8s.io.api.core.v1.PodTemplateSpec": { + "type": "object", + "properties": { + "metadata": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta", + "title": "Standard object's metadata.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata\n+optional" + }, + "spec": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodSpec", + "title": "Specification of the desired behavior of the pod.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status\n+optional" + } + }, + "title": "PodTemplateSpec describes the data a pod should have when created from a template" + }, + "k8s.io.api.core.v1.PortworxVolumeSource": { + "type": "object", + "properties": { + "volumeID": { + "type": "string", + "title": "VolumeID uniquely identifies a Portworx volume" + }, + "fsType": { + "type": "string", + "description": "FSType represents the filesystem type to mount\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\". Implicitly inferred to be \"ext4\" if unspecified." + }, + "readOnly": { + "type": "boolean", + "title": "Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + } + }, + "description": "PortworxVolumeSource represents a Portworx volume resource." + }, + "k8s.io.api.core.v1.PreferredSchedulingTerm": { + "type": "object", + "properties": { + "weight": { + "type": "integer", + "format": "int32", + "description": "Weight associated with matching the corresponding nodeSelectorTerm, in the range 1-100." + }, + "preference": { + "$ref": "#/definitions/k8s.io.api.core.v1.NodeSelectorTerm", + "description": "A node selector term, associated with the corresponding weight." + } + }, + "description": "An empty preferred scheduling term matches all objects with implicit weight 0\n(i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op)." + }, + "k8s.io.api.core.v1.Probe": { + "type": "object", + "properties": { + "handler": { + "$ref": "#/definitions/k8s.io.api.core.v1.Handler", + "title": "The action taken to determine the health of a container" + }, + "initialDelaySeconds": { + "type": "integer", + "format": "int32", + "title": "Number of seconds after the container has started before liveness probes are initiated.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n+optional" + }, + "timeoutSeconds": { + "type": "integer", + "format": "int32", + "title": "Number of seconds after which the probe times out.\nDefaults to 1 second. Minimum value is 1.\nMore info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n+optional" + }, + "periodSeconds": { + "type": "integer", + "format": "int32", + "title": "How often (in seconds) to perform the probe.\nDefault to 10 seconds. Minimum value is 1.\n+optional" + }, + "successThreshold": { + "type": "integer", + "format": "int32", + "title": "Minimum consecutive successes for the probe to be considered successful after having failed.\nDefaults to 1. Must be 1 for liveness and startup. Minimum value is 1.\n+optional" + }, + "failureThreshold": { + "type": "integer", + "format": "int32", + "title": "Minimum consecutive failures for the probe to be considered failed after having succeeded.\nDefaults to 3. Minimum value is 1.\n+optional" + } + }, + "description": "Probe describes a health check to be performed against a container to determine whether it is\nalive or ready to receive traffic." + }, + "k8s.io.api.core.v1.ProjectedVolumeSource": { + "type": "object", + "properties": { + "sources": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeProjection" + }, + "title": "list of volume projections\n+optional" + }, + "defaultMode": { + "type": "integer", + "format": "int32", + "title": "Mode bits used to set permissions on created files by default.\nMust be an octal value between 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values for mode bits.\nDirectories within the path are not affected by this setting.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + } + }, + "title": "Represents a projected volume source" + }, + "k8s.io.api.core.v1.QuobyteVolumeSource": { + "type": "object", + "properties": { + "registry": { + "type": "string", + "title": "Registry represents a single or multiple Quobyte Registry services\nspecified as a string as host:port pair (multiple entries are separated with commas)\nwhich acts as the central registry for volumes" + }, + "volume": { + "type": "string", + "description": "Volume is a string that references an already created Quobyte volume by name." + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force the Quobyte volume to be mounted with read-only permissions.\nDefaults to false.\n+optional" + }, + "user": { + "type": "string", + "title": "User to map volume access to\nDefaults to serivceaccount user\n+optional" + }, + "group": { + "type": "string", + "title": "Group to map volume access to\nDefault is no group\n+optional" + }, + "tenant": { + "type": "string", + "title": "Tenant owning the given Quobyte volume in the Backend\nUsed with dynamically provisioned Quobyte volumes, value is set by the plugin\n+optional" + } + }, + "description": "Represents a Quobyte mount that lasts the lifetime of a pod.\nQuobyte volumes do not support ownership management or SELinux relabeling." + }, + "k8s.io.api.core.v1.RBDVolumeSource": { + "type": "object", + "properties": { + "monitors": { + "type": "array", + "items": { + "type": "string" + }, + "title": "A collection of Ceph monitors.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it" + }, + "image": { + "type": "string", + "title": "The rados image name.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it" + }, + "fsType": { + "type": "string", + "title": "Filesystem type of the volume that you want to mount.\nTip: Ensure that the filesystem type is supported by the host operating system.\nExamples: \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#rbd\nTODO: how do we prevent errors in the filesystem from compromising the machine\n+optional" + }, + "pool": { + "type": "string", + "title": "The rados pool name.\nDefault is rbd.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it\n+optional" + }, + "user": { + "type": "string", + "title": "The rados user name.\nDefault is admin.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it\n+optional" + }, + "keyring": { + "type": "string", + "title": "Keyring is the path to key ring for RBDUser.\nDefault is /etc/ceph/keyring.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "SecretRef is name of the authentication secret for RBDUser. If provided\noverrides keyring.\nDefault is nil.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "ReadOnly here will force the ReadOnly setting in VolumeMounts.\nDefaults to false.\nMore info: https://examples.k8s.io/volumes/rbd/README.md#how-to-use-it\n+optional" + } + }, + "description": "Represents a Rados Block Device mount that lasts the lifetime of a pod.\nRBD volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.ResourceFieldSelector": { + "type": "object", + "properties": { + "containerName": { + "type": "string", + "title": "Container name: required for volumes, optional for env vars\n+optional" + }, + "resource": { + "type": "string", + "title": "Required: resource to select" + }, + "divisor": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.api.resource.Quantity", + "title": "Specifies the output format of the exposed resources, defaults to \"1\"\n+optional" + } + }, + "title": "ResourceFieldSelector represents container resources (cpu, memory) and their output format" + }, + "k8s.io.api.core.v1.ResourceRequirements": { + "type": "object", + "properties": { + "limits": { + "type": "object", + "additionalProperties": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.api.resource.Quantity" + }, + "title": "Limits describes the maximum amount of compute resources allowed.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/\n+optional" + }, + "requests": { + "type": "object", + "additionalProperties": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.api.resource.Quantity" + }, + "title": "Requests describes the minimum amount of compute resources required.\nIf Requests is omitted for a container, it defaults to Limits if that is explicitly specified,\notherwise to an implementation-defined value.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/\n+optional" + } + }, + "description": "ResourceRequirements describes the compute resource requirements." + }, + "k8s.io.api.core.v1.SELinuxOptions": { + "type": "object", + "properties": { + "user": { + "type": "string", + "title": "User is a SELinux user label that applies to the container.\n+optional" + }, + "role": { + "type": "string", + "title": "Role is a SELinux role label that applies to the container.\n+optional" + }, + "type": { + "type": "string", + "title": "Type is a SELinux type label that applies to the container.\n+optional" + }, + "level": { + "type": "string", + "title": "Level is SELinux level label that applies to the container.\n+optional" + } + }, + "title": "SELinuxOptions are the labels to be applied to the container" + }, + "k8s.io.api.core.v1.ScaleIOVolumeSource": { + "type": "object", + "properties": { + "gateway": { + "type": "string", + "description": "The host address of the ScaleIO API Gateway." + }, + "system": { + "type": "string", + "description": "The name of the storage system as configured in ScaleIO." + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "description": "SecretRef references to the secret for ScaleIO user and other\nsensitive information. If this is not provided, Login operation will fail." + }, + "sslEnabled": { + "type": "boolean", + "title": "Flag to enable/disable SSL communication with Gateway, default false\n+optional" + }, + "protectionDomain": { + "type": "string", + "title": "The name of the ScaleIO Protection Domain for the configured storage.\n+optional" + }, + "storagePool": { + "type": "string", + "title": "The ScaleIO Storage Pool associated with the protection domain.\n+optional" + }, + "storageMode": { + "type": "string", + "title": "Indicates whether the storage for a volume should be ThickProvisioned or ThinProvisioned.\nDefault is ThinProvisioned.\n+optional" + }, + "volumeName": { + "type": "string", + "description": "The name of a volume already created in the ScaleIO system\nthat is associated with this volume source." + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\".\nDefault is \"xfs\".\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + } + }, + "title": "ScaleIOVolumeSource represents a persistent ScaleIO volume" + }, + "k8s.io.api.core.v1.SeccompProfile": { + "type": "object", + "properties": { + "type": { + "type": "string", + "description": "Localhost - a profile defined in a file on the node should be used.\nRuntimeDefault - the container runtime default profile should be used.\nUnconfined - no profile should be applied.\n+unionDiscriminator", + "title": "type indicates which kind of seccomp profile will be applied.\nValid options are:" + }, + "localhostProfile": { + "type": "string", + "title": "localhostProfile indicates a profile defined in a file on the node should be used.\nThe profile must be preconfigured on the node to work.\nMust be a descending path, relative to the kubelet's configured seccomp profile location.\nMust only be set if type is \"Localhost\".\n+optional" + } + }, + "title": "SeccompProfile defines a pod/container's seccomp profile settings.\nOnly one profile source may be set.\n+union" + }, + "k8s.io.api.core.v1.SecretEnvSource": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "description": "The Secret to select from." + }, + "optional": { + "type": "boolean", + "title": "Specify whether the Secret must be defined\n+optional" + } + }, + "description": "SecretEnvSource selects a Secret to populate the environment\nvariables with.\n\nThe contents of the target Secret's Data field will represent the\nkey-value pairs as environment variables." + }, + "k8s.io.api.core.v1.SecretKeySelector": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "description": "The name of the secret in the pod's namespace to select from." + }, + "key": { + "type": "string", + "description": "The key of the secret to select from. Must be a valid secret key." + }, + "optional": { + "type": "boolean", + "title": "Specify whether the Secret or its key must be defined\n+optional" + } + }, + "description": "SecretKeySelector selects a key of a Secret." + }, + "k8s.io.api.core.v1.SecretProjection": { + "type": "object", + "properties": { + "localObjectReference": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference" + }, + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.KeyToPath" + }, + "title": "If unspecified, each key-value pair in the Data field of the referenced\nSecret will be projected into the volume as a file whose name is the\nkey and content is the value. If specified, the listed keys will be\nprojected into the specified paths, and unlisted keys will not be\npresent. If a key is specified which is not present in the Secret,\nthe volume setup will error unless it is marked optional. Paths must be\nrelative and may not contain the '..' path or start with '..'.\n+optional" + }, + "optional": { + "type": "boolean", + "title": "Specify whether the Secret or its key must be defined\n+optional" + } + }, + "description": "Adapts a secret into a projected volume.\n\nThe contents of the target Secret's Data field will be presented in a\nprojected volume as files using the keys in the Data field as the file names.\nNote that this is identical to a secret volume source without the default\nmode." + }, + "k8s.io.api.core.v1.SecretVolumeSource": { + "type": "object", + "properties": { + "secretName": { + "type": "string", + "title": "Name of the secret in the pod's namespace to use.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#secret\n+optional" + }, + "items": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.api.core.v1.KeyToPath" + }, + "title": "If unspecified, each key-value pair in the Data field of the referenced\nSecret will be projected into the volume as a file whose name is the\nkey and content is the value. If specified, the listed keys will be\nprojected into the specified paths, and unlisted keys will not be\npresent. If a key is specified which is not present in the Secret,\nthe volume setup will error unless it is marked optional. Paths must be\nrelative and may not contain the '..' path or start with '..'.\n+optional" + }, + "defaultMode": { + "type": "integer", + "format": "int32", + "title": "Optional: mode bits used to set permissions on created files by default.\nMust be an octal value between 0000 and 0777 or a decimal value between 0 and 511.\nYAML accepts both octal and decimal values, JSON requires decimal values\nfor mode bits. Defaults to 0644.\nDirectories within the path are not affected by this setting.\nThis might be in conflict with other options that affect the file\nmode, like fsGroup, and the result can be other mode bits set.\n+optional" + }, + "optional": { + "type": "boolean", + "title": "Specify whether the Secret or its keys must be defined\n+optional" + } + }, + "description": "Adapts a Secret into a volume.\n\nThe contents of the target Secret's Data field will be presented in a volume\nas files using the keys in the Data field as the file names.\nSecret volumes support ownership management and SELinux relabeling." + }, + "k8s.io.api.core.v1.SecurityContext": { + "type": "object", + "properties": { + "capabilities": { + "$ref": "#/definitions/k8s.io.api.core.v1.Capabilities", + "title": "The capabilities to add/drop when running containers.\nDefaults to the default set of capabilities granted by the container runtime.\n+optional" + }, + "privileged": { + "type": "boolean", + "title": "Run container in privileged mode.\nProcesses in privileged containers are essentially equivalent to root on the host.\nDefaults to false.\n+optional" + }, + "seLinuxOptions": { + "$ref": "#/definitions/k8s.io.api.core.v1.SELinuxOptions", + "title": "The SELinux context to be applied to the container.\nIf unspecified, the container runtime will allocate a random SELinux context for each\ncontainer. May also be set in PodSecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "windowsOptions": { + "$ref": "#/definitions/k8s.io.api.core.v1.WindowsSecurityContextOptions", + "title": "The Windows specific settings applied to all containers.\nIf unspecified, the options from the PodSecurityContext will be used.\nIf set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "runAsUser": { + "type": "string", + "format": "int64", + "title": "The UID to run the entrypoint of the container process.\nDefaults to user specified in image metadata if unspecified.\nMay also be set in PodSecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "runAsGroup": { + "type": "string", + "format": "int64", + "title": "The GID to run the entrypoint of the container process.\nUses runtime default if unset.\nMay also be set in PodSecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "runAsNonRoot": { + "type": "boolean", + "title": "Indicates that the container must run as a non-root user.\nIf true, the Kubelet will validate the image at runtime to ensure that it\ndoes not run as UID 0 (root) and fail to start the container if it does.\nIf unset or false, no such validation will be performed.\nMay also be set in PodSecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + }, + "readOnlyRootFilesystem": { + "type": "boolean", + "title": "Whether this container has a read-only root filesystem.\nDefault is false.\n+optional" + }, + "allowPrivilegeEscalation": { + "type": "boolean", + "title": "AllowPrivilegeEscalation controls whether a process can gain more\nprivileges than its parent process. This bool directly controls if\nthe no_new_privs flag will be set on the container process.\nAllowPrivilegeEscalation is true always when the container is:\n1) run as Privileged\n2) has CAP_SYS_ADMIN\n+optional" + }, + "procMount": { + "type": "string", + "title": "procMount denotes the type of proc mount to use for the containers.\nThe default is DefaultProcMount which uses the container runtime defaults for\nreadonly paths and masked paths.\nThis requires the ProcMountType feature flag to be enabled.\n+optional" + }, + "seccompProfile": { + "$ref": "#/definitions/k8s.io.api.core.v1.SeccompProfile", + "title": "The seccomp options to use by this container. If seccomp options are\nprovided at both the pod \u0026 container level, the container options\noverride the pod options.\n+optional" + } + }, + "description": "SecurityContext holds security configuration that will be applied to a container.\nSome fields are present in both SecurityContext and PodSecurityContext. When both\nare set, the values in SecurityContext take precedence." + }, + "k8s.io.api.core.v1.ServiceAccountTokenProjection": { + "type": "object", + "properties": { + "audience": { + "type": "string", + "title": "Audience is the intended audience of the token. A recipient of a token\nmust identify itself with an identifier specified in the audience of the\ntoken, and otherwise should reject the token. The audience defaults to the\nidentifier of the apiserver.\n+optional" + }, + "expirationSeconds": { + "type": "string", + "format": "int64", + "title": "ExpirationSeconds is the requested duration of validity of the service\naccount token. As the token approaches expiration, the kubelet volume\nplugin will proactively rotate the service account token. The kubelet will\nstart trying to rotate the token if the token is older than 80 percent of\nits time to live or if the token is older than 24 hours.Defaults to 1 hour\nand must be at least 10 minutes.\n+optional" + }, + "path": { + "type": "string", + "description": "Path is the path relative to the mount point of the file to project the\ntoken into." + } + }, + "description": "ServiceAccountTokenProjection represents a projected service account token\nvolume. This projection can be used to insert a service account token into\nthe pods runtime filesystem for use against APIs (Kubernetes API Server or\notherwise)." + }, + "k8s.io.api.core.v1.StorageOSVolumeSource": { + "type": "object", + "properties": { + "volumeName": { + "type": "string", + "description": "VolumeName is the human-readable name of the StorageOS volume. Volume\nnames are only unique within a namespace." + }, + "volumeNamespace": { + "type": "string", + "title": "VolumeNamespace specifies the scope of the volume within StorageOS. If no\nnamespace is specified then the Pod's namespace will be used. This allows the\nKubernetes name scoping to be mirrored within StorageOS for tighter integration.\nSet VolumeName to any name to override the default behaviour.\nSet to \"default\" if you are not using namespaces within StorageOS.\nNamespaces that do not pre-exist within StorageOS will be created.\n+optional" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\n+optional" + }, + "readOnly": { + "type": "boolean", + "title": "Defaults to false (read/write). ReadOnly here will force\nthe ReadOnly setting in VolumeMounts.\n+optional" + }, + "secretRef": { + "$ref": "#/definitions/k8s.io.api.core.v1.LocalObjectReference", + "title": "SecretRef specifies the secret to use for obtaining the StorageOS API\ncredentials. If not specified, default values will be attempted.\n+optional" + } + }, + "description": "Represents a StorageOS persistent volume resource." + }, + "k8s.io.api.core.v1.Sysctl": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name of a property to set" + }, + "value": { + "type": "string", + "title": "Value of a property to set" + } + }, + "title": "Sysctl defines a kernel parameter to be set" + }, + "k8s.io.api.core.v1.TCPSocketAction": { + "type": "object", + "properties": { + "port": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.util.intstr.IntOrString", + "description": "Number or name of the port to access on the container.\nNumber must be in the range 1 to 65535.\nName must be an IANA_SVC_NAME." + }, + "host": { + "type": "string", + "title": "Optional: Host name to connect to, defaults to the pod IP.\n+optional" + } + }, + "title": "TCPSocketAction describes an action based on opening a socket" + }, + "k8s.io.api.core.v1.Toleration": { + "type": "object", + "properties": { + "key": { + "type": "string", + "title": "Key is the taint key that the toleration applies to. Empty means match all taint keys.\nIf the key is empty, operator must be Exists; this combination means to match all values and all keys.\n+optional" + }, + "operator": { + "type": "string", + "title": "Operator represents a key's relationship to the value.\nValid operators are Exists and Equal. Defaults to Equal.\nExists is equivalent to wildcard for value, so that a pod can\ntolerate all taints of a particular category.\n+optional" + }, + "value": { + "type": "string", + "title": "Value is the taint value the toleration matches to.\nIf the operator is Exists, the value should be empty, otherwise just a regular string.\n+optional" + }, + "effect": { + "type": "string", + "title": "Effect indicates the taint effect to match. Empty means match all taint effects.\nWhen specified, allowed values are NoSchedule, PreferNoSchedule and NoExecute.\n+optional" + }, + "tolerationSeconds": { + "type": "string", + "format": "int64", + "title": "TolerationSeconds represents the period of time the toleration (which must be\nof effect NoExecute, otherwise this field is ignored) tolerates the taint. By default,\nit is not set, which means tolerate the taint forever (do not evict). Zero and\nnegative values will be treated as 0 (evict immediately) by the system.\n+optional" + } + }, + "description": "The pod this Toleration is attached to tolerates any taint that matches\nthe triple \u003ckey,value,effect\u003e using the matching operator \u003coperator\u003e." + }, + "k8s.io.api.core.v1.TopologySpreadConstraint": { + "type": "object", + "properties": { + "maxSkew": { + "type": "integer", + "format": "int32", + "description": "MaxSkew describes the degree to which pods may be unevenly distributed.\nWhen `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference\nbetween the number of matching pods in the target topology and the global minimum.\nFor example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same\nlabelSelector spread as 1/1/0:\n+-------+-------+-------+\n| zone1 | zone2 | zone3 |\n+-------+-------+-------+\n| P | P | |\n+-------+-------+-------+\n- if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1;\nscheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2)\nviolate MaxSkew(1).\n- if MaxSkew is 2, incoming pod can be scheduled onto any zone.\nWhen `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence\nto topologies that satisfy it.\nIt's a required field. Default value is 1 and 0 is not allowed." + }, + "topologyKey": { + "type": "string", + "description": "TopologyKey is the key of node labels. Nodes that have a label with this key\nand identical values are considered to be in the same topology.\nWe consider each \u003ckey, value\u003e as a \"bucket\", and try to put balanced number\nof pods into each bucket.\nIt's a required field." + }, + "whenUnsatisfiable": { + "type": "string", + "description": "WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy\nthe spread constraint.\n- DoNotSchedule (default) tells the scheduler not to schedule it.\n- ScheduleAnyway tells the scheduler to schedule the pod in any location,\n but giving higher precedence to topologies that would help reduce the\n skew.\nA constraint is considered \"Unsatisfiable\" for an incoming pod\nif and only if every possible node assigment for that pod would violate\n\"MaxSkew\" on some topology.\nFor example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same\nlabelSelector spread as 3/1/1:\n+-------+-------+-------+\n| zone1 | zone2 | zone3 |\n+-------+-------+-------+\n| P P P | P | P |\n+-------+-------+-------+\nIf WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled\nto zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies\nMaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler\nwon't make it *more* imbalanced.\nIt's a required field." + }, + "labelSelector": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector", + "title": "LabelSelector is used to find matching pods.\nPods that match this label selector are counted to determine the number of pods\nin their corresponding topology domain.\n+optional" + } + }, + "description": "TopologySpreadConstraint specifies how to spread matching pods among the given topology." + }, + "k8s.io.api.core.v1.TypedLocalObjectReference": { + "type": "object", + "properties": { + "apiGroup": { + "type": "string", + "title": "APIGroup is the group for the resource being referenced.\nIf APIGroup is not specified, the specified Kind must be in the core API group.\nFor any other third-party types, APIGroup is required.\n+optional" + }, + "kind": { + "type": "string", + "title": "Kind is the type of resource being referenced" + }, + "name": { + "type": "string", + "title": "Name is the name of resource being referenced" + } + }, + "description": "TypedLocalObjectReference contains enough information to let you locate the\ntyped referenced object inside the same namespace." + }, + "k8s.io.api.core.v1.Volume": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Volume's name.\nMust be a DNS_LABEL and unique within the pod.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names" + }, + "volumeSource": { + "$ref": "#/definitions/k8s.io.api.core.v1.VolumeSource", + "description": "VolumeSource represents the location and type of the mounted volume.\nIf not specified, the Volume is implied to be an EmptyDir.\nThis implied behavior is deprecated and will be removed in a future version." + } + }, + "description": "Volume represents a named volume in a pod that may be accessed by any container in the pod." + }, + "k8s.io.api.core.v1.VolumeDevice": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "name must match the name of a persistentVolumeClaim in the pod" + }, + "devicePath": { + "type": "string", + "description": "devicePath is the path inside of the container that the device will be mapped to." + } + }, + "description": "volumeDevice describes a mapping of a raw block device within a container." + }, + "k8s.io.api.core.v1.VolumeMount": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "This must match the Name of a Volume." + }, + "readOnly": { + "type": "boolean", + "title": "Mounted read-only if true, read-write otherwise (false or unspecified).\nDefaults to false.\n+optional" + }, + "mountPath": { + "type": "string", + "description": "Path within the container at which the volume should be mounted. Must\nnot contain ':'." + }, + "subPath": { + "type": "string", + "title": "Path within the volume from which the container's volume should be mounted.\nDefaults to \"\" (volume's root).\n+optional" + }, + "mountPropagation": { + "type": "string", + "title": "mountPropagation determines how mounts are propagated from the host\nto container and the other way around.\nWhen not set, MountPropagationNone is used.\nThis field is beta in 1.10.\n+optional" + }, + "subPathExpr": { + "type": "string", + "title": "Expanded path within the volume from which the container's volume should be mounted.\nBehaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment.\nDefaults to \"\" (volume's root).\nSubPathExpr and SubPath are mutually exclusive.\n+optional" + } + }, + "description": "VolumeMount describes a mounting of a Volume within a container." + }, + "k8s.io.api.core.v1.VolumeProjection": { + "type": "object", + "properties": { + "secret": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecretProjection", + "title": "information about the secret data to project\n+optional" + }, + "downwardAPI": { + "$ref": "#/definitions/k8s.io.api.core.v1.DownwardAPIProjection", + "title": "information about the downwardAPI data to project\n+optional" + }, + "configMap": { + "$ref": "#/definitions/k8s.io.api.core.v1.ConfigMapProjection", + "title": "information about the configMap data to project\n+optional" + }, + "serviceAccountToken": { + "$ref": "#/definitions/k8s.io.api.core.v1.ServiceAccountTokenProjection", + "title": "information about the serviceAccountToken data to project\n+optional" + } + }, + "title": "Projection that may be projected along with other supported volume types" + }, + "k8s.io.api.core.v1.VolumeSource": { + "type": "object", + "properties": { + "hostPath": { + "$ref": "#/definitions/k8s.io.api.core.v1.HostPathVolumeSource", + "title": "HostPath represents a pre-existing file or directory on the host\nmachine that is directly exposed to the container. This is generally\nused for system agents or other privileged things that are allowed\nto see the host machine. Most containers will NOT need this.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#hostpath\n---\nTODO(jonesdl) We need to restrict who can use host directory mounts and who can/can not\nmount host directories as read/write.\n+optional" + }, + "emptyDir": { + "$ref": "#/definitions/k8s.io.api.core.v1.EmptyDirVolumeSource", + "title": "EmptyDir represents a temporary directory that shares a pod's lifetime.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#emptydir\n+optional" + }, + "gcePersistentDisk": { + "$ref": "#/definitions/k8s.io.api.core.v1.GCEPersistentDiskVolumeSource", + "title": "GCEPersistentDisk represents a GCE Disk resource that is attached to a\nkubelet's host machine and then exposed to the pod.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk\n+optional" + }, + "awsElasticBlockStore": { + "$ref": "#/definitions/k8s.io.api.core.v1.AWSElasticBlockStoreVolumeSource", + "title": "AWSElasticBlockStore represents an AWS Disk resource that is attached to a\nkubelet's host machine and then exposed to the pod.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore\n+optional" + }, + "gitRepo": { + "$ref": "#/definitions/k8s.io.api.core.v1.GitRepoVolumeSource", + "title": "GitRepo represents a git repository at a particular revision.\nDEPRECATED: GitRepo is deprecated. To provision a container with a git repo, mount an\nEmptyDir into an InitContainer that clones the repo using git, then mount the EmptyDir\ninto the Pod's container.\n+optional" + }, + "secret": { + "$ref": "#/definitions/k8s.io.api.core.v1.SecretVolumeSource", + "title": "Secret represents a secret that should populate this volume.\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#secret\n+optional" + }, + "nfs": { + "$ref": "#/definitions/k8s.io.api.core.v1.NFSVolumeSource", + "title": "NFS represents an NFS mount on the host that shares a pod's lifetime\nMore info: https://kubernetes.io/docs/concepts/storage/volumes#nfs\n+optional" + }, + "iscsi": { + "$ref": "#/definitions/k8s.io.api.core.v1.ISCSIVolumeSource", + "title": "ISCSI represents an ISCSI Disk resource that is attached to a\nkubelet's host machine and then exposed to the pod.\nMore info: https://examples.k8s.io/volumes/iscsi/README.md\n+optional" + }, + "glusterfs": { + "$ref": "#/definitions/k8s.io.api.core.v1.GlusterfsVolumeSource", + "title": "Glusterfs represents a Glusterfs mount on the host that shares a pod's lifetime.\nMore info: https://examples.k8s.io/volumes/glusterfs/README.md\n+optional" + }, + "persistentVolumeClaim": { + "$ref": "#/definitions/k8s.io.api.core.v1.PersistentVolumeClaimVolumeSource", + "title": "PersistentVolumeClaimVolumeSource represents a reference to a\nPersistentVolumeClaim in the same namespace.\nMore info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistentvolumeclaims\n+optional" + }, + "rbd": { + "$ref": "#/definitions/k8s.io.api.core.v1.RBDVolumeSource", + "title": "RBD represents a Rados Block Device mount on the host that shares a pod's lifetime.\nMore info: https://examples.k8s.io/volumes/rbd/README.md\n+optional" + }, + "flexVolume": { + "$ref": "#/definitions/k8s.io.api.core.v1.FlexVolumeSource", + "title": "FlexVolume represents a generic volume resource that is\nprovisioned/attached using an exec based plugin.\n+optional" + }, + "cinder": { + "$ref": "#/definitions/k8s.io.api.core.v1.CinderVolumeSource", + "title": "Cinder represents a cinder volume attached and mounted on kubelets host machine.\nMore info: https://examples.k8s.io/mysql-cinder-pd/README.md\n+optional" + }, + "cephfs": { + "$ref": "#/definitions/k8s.io.api.core.v1.CephFSVolumeSource", + "title": "CephFS represents a Ceph FS mount on the host that shares a pod's lifetime\n+optional" + }, + "flocker": { + "$ref": "#/definitions/k8s.io.api.core.v1.FlockerVolumeSource", + "title": "Flocker represents a Flocker volume attached to a kubelet's host machine. This depends on the Flocker control service being running\n+optional" + }, + "downwardAPI": { + "$ref": "#/definitions/k8s.io.api.core.v1.DownwardAPIVolumeSource", + "title": "DownwardAPI represents downward API about the pod that should populate this volume\n+optional" + }, + "fc": { + "$ref": "#/definitions/k8s.io.api.core.v1.FCVolumeSource", + "title": "FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod.\n+optional" + }, + "azureFile": { + "$ref": "#/definitions/k8s.io.api.core.v1.AzureFileVolumeSource", + "title": "AzureFile represents an Azure File Service mount on the host and bind mount to the pod.\n+optional" + }, + "configMap": { + "$ref": "#/definitions/k8s.io.api.core.v1.ConfigMapVolumeSource", + "title": "ConfigMap represents a configMap that should populate this volume\n+optional" + }, + "vsphereVolume": { + "$ref": "#/definitions/k8s.io.api.core.v1.VsphereVirtualDiskVolumeSource", + "title": "VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine\n+optional" + }, + "quobyte": { + "$ref": "#/definitions/k8s.io.api.core.v1.QuobyteVolumeSource", + "title": "Quobyte represents a Quobyte mount on the host that shares a pod's lifetime\n+optional" + }, + "azureDisk": { + "$ref": "#/definitions/k8s.io.api.core.v1.AzureDiskVolumeSource", + "title": "AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod.\n+optional" + }, + "photonPersistentDisk": { + "$ref": "#/definitions/k8s.io.api.core.v1.PhotonPersistentDiskVolumeSource", + "title": "PhotonPersistentDisk represents a PhotonController persistent disk attached and mounted on kubelets host machine" + }, + "projected": { + "$ref": "#/definitions/k8s.io.api.core.v1.ProjectedVolumeSource", + "title": "Items for all in one resources secrets, configmaps, and downward API" + }, + "portworxVolume": { + "$ref": "#/definitions/k8s.io.api.core.v1.PortworxVolumeSource", + "title": "PortworxVolume represents a portworx volume attached and mounted on kubelets host machine\n+optional" + }, + "scaleIO": { + "$ref": "#/definitions/k8s.io.api.core.v1.ScaleIOVolumeSource", + "title": "ScaleIO represents a ScaleIO persistent volume attached and mounted on Kubernetes nodes.\n+optional" + }, + "storageos": { + "$ref": "#/definitions/k8s.io.api.core.v1.StorageOSVolumeSource", + "title": "StorageOS represents a StorageOS volume attached and mounted on Kubernetes nodes.\n+optional" + }, + "csi": { + "$ref": "#/definitions/k8s.io.api.core.v1.CSIVolumeSource", + "title": "CSI (Container Storage Interface) represents ephemeral storage that is handled by certain external CSI drivers (Beta feature).\n+optional" + }, + "ephemeral": { + "$ref": "#/definitions/k8s.io.api.core.v1.EphemeralVolumeSource", + "description": "Ephemeral represents a volume that is handled by a cluster storage driver (Alpha feature).\nThe volume's lifecycle is tied to the pod that defines it - it will be created before the pod starts,\nand deleted when the pod is removed.\n\nUse this if:\na) the volume is only needed while the pod runs,\nb) features of normal volumes like restoring from snapshot or capacity\n tracking are needed,\nc) the storage driver is specified through a storage class, and\nd) the storage driver supports dynamic volume provisioning through\n a PersistentVolumeClaim (see EphemeralVolumeSource for more\n information on the connection between this volume type\n and PersistentVolumeClaim).\n\nUse PersistentVolumeClaim or one of the vendor-specific\nAPIs for volumes that persist for longer than the lifecycle\nof an individual pod.\n\nUse CSI for light-weight local ephemeral volumes if the CSI driver is meant to\nbe used that way - see the documentation of the driver for\nmore information.\n\nA pod can use both types of ephemeral volumes and\npersistent volumes at the same time.\n\n+optional" + } + }, + "description": "Represents the source of a volume to mount.\nOnly one of its members may be specified." + }, + "k8s.io.api.core.v1.VsphereVirtualDiskVolumeSource": { + "type": "object", + "properties": { + "volumePath": { + "type": "string", + "title": "Path that identifies vSphere volume vmdk" + }, + "fsType": { + "type": "string", + "title": "Filesystem type to mount.\nMust be a filesystem type supported by the host operating system.\nEx. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified.\n+optional" + }, + "storagePolicyName": { + "type": "string", + "title": "Storage Policy Based Management (SPBM) profile name.\n+optional" + }, + "storagePolicyID": { + "type": "string", + "title": "Storage Policy Based Management (SPBM) profile ID associated with the StoragePolicyName.\n+optional" + } + }, + "description": "Represents a vSphere volume resource." + }, + "k8s.io.api.core.v1.WeightedPodAffinityTerm": { + "type": "object", + "properties": { + "weight": { + "type": "integer", + "format": "int32", + "description": "weight associated with matching the corresponding podAffinityTerm,\nin the range 1-100." + }, + "podAffinityTerm": { + "$ref": "#/definitions/k8s.io.api.core.v1.PodAffinityTerm", + "description": "Required. A pod affinity term, associated with the corresponding weight." + } + }, + "title": "The weights of all of the matched WeightedPodAffinityTerm fields are added per-node to find the most preferred node(s)" + }, + "k8s.io.api.core.v1.WindowsSecurityContextOptions": { + "type": "object", + "properties": { + "gmsaCredentialSpecName": { + "type": "string", + "title": "GMSACredentialSpecName is the name of the GMSA credential spec to use.\n+optional" + }, + "gmsaCredentialSpec": { + "type": "string", + "title": "GMSACredentialSpec is where the GMSA admission webhook\n(https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the\nGMSA credential spec named by the GMSACredentialSpecName field.\n+optional" + }, + "runAsUserName": { + "type": "string", + "title": "The UserName in Windows to run the entrypoint of the container process.\nDefaults to the user specified in image metadata if unspecified.\nMay also be set in PodSecurityContext. If set in both SecurityContext and\nPodSecurityContext, the value specified in SecurityContext takes precedence.\n+optional" + } + }, + "description": "WindowsSecurityContextOptions contain Windows-specific options and credentials." + }, + "k8s.io.apimachinery.pkg.api.resource.Quantity": { + "type": "object", + "properties": { + "string": { + "type": "string" + } + }, + "description": "Quantity is a fixed-point representation of a number.\nIt provides convenient marshaling/unmarshaling in JSON and YAML,\nin addition to String() and AsInt64() accessors.\n\nThe serialization format is:\n\n\u003cquantity\u003e ::= \u003csignedNumber\u003e\u003csuffix\u003e\n (Note that \u003csuffix\u003e may be empty, from the \"\" case in \u003cdecimalSI\u003e.)\n\u003cdigit\u003e ::= 0 | 1 | ... | 9\n\u003cdigits\u003e ::= \u003cdigit\u003e | \u003cdigit\u003e\u003cdigits\u003e\n\u003cnumber\u003e ::= \u003cdigits\u003e | \u003cdigits\u003e.\u003cdigits\u003e | \u003cdigits\u003e. | .\u003cdigits\u003e\n\u003csign\u003e ::= \"+\" | \"-\"\n\u003csignedNumber\u003e ::= \u003cnumber\u003e | \u003csign\u003e\u003cnumber\u003e\n\u003csuffix\u003e ::= \u003cbinarySI\u003e | \u003cdecimalExponent\u003e | \u003cdecimalSI\u003e\n\u003cbinarySI\u003e ::= Ki | Mi | Gi | Ti | Pi | Ei\n (International System of units; See: http://physics.nist.gov/cuu/Units/binary.html)\n\u003cdecimalSI\u003e ::= m | \"\" | k | M | G | T | P | E\n (Note that 1024 = 1Ki but 1000 = 1k; I didn't choose the capitalization.)\n\u003cdecimalExponent\u003e ::= \"e\" \u003csignedNumber\u003e | \"E\" \u003csignedNumber\u003e\n\nNo matter which of the three exponent forms is used, no quantity may represent\na number greater than 2^63-1 in magnitude, nor may it have more than 3 decimal\nplaces. Numbers larger or more precise will be capped or rounded up.\n(E.g.: 0.1m will rounded up to 1m.)\nThis may be extended in the future if we require larger or smaller quantities.\n\nWhen a Quantity is parsed from a string, it will remember the type of suffix\nit had, and will use the same type again when it is serialized.\n\nBefore serializing, Quantity will be put in \"canonical form\".\nThis means that Exponent/suffix will be adjusted up or down (with a\ncorresponding increase or decrease in Mantissa) such that:\n a. No precision is lost\n b. No fractional digits will be emitted\n c. The exponent (or suffix) is as large as possible.\nThe sign will be omitted unless the number is negative.\n\nExamples:\n 1.5 will be serialized as \"1500m\"\n 1.5Gi will be serialized as \"1536Mi\"\n\nNote that the quantity will NEVER be internally represented by a\nfloating point number. That is the whole point of this exercise.\n\nNon-canonical values will still parse as long as they are well formed,\nbut will be re-emitted in their canonical form. (So always use canonical\nform, or don't diff.)\n\nThis format is intended to make it difficult to use these numbers without\nwriting some sort of special handling code in the hopes that that will\ncause implementors to also use a fixed point implementation.\n\n+protobuf=true\n+protobuf.embed=string\n+protobuf.options.marshal=false\n+protobuf.options.(gogoproto.goproto_stringer)=false\n+k8s:deepcopy-gen=true\n+k8s:openapi-gen=true" + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.FieldsV1": { + "type": "object", + "properties": { + "Raw": { + "type": "string", + "format": "byte", + "description": "Raw is the underlying serialization of this object." + } + }, + "description": "FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format.\n\nEach key is either a '.' representing the field itself, and will always map to an empty set,\nor a string representing a sub-field or item. The string will follow one of these four formats:\n'f:\u003cname\u003e', where \u003cname\u003e is the name of a field in a struct, or key in a map\n'v:\u003cvalue\u003e', where \u003cvalue\u003e is the exact json formatted value of a list item\n'i:\u003cindex\u003e', where \u003cindex\u003e is position of a item in a list\n'k:\u003ckeys\u003e', where \u003ckeys\u003e is a map of a list item's key fields to their unique values\nIf a key maps to an empty Fields value, the field that key represents is part of the set.\n\nThe exact format is defined in sigs.k8s.io/structured-merge-diff\n+protobuf.options.(gogoproto.goproto_stringer)=false" + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector": { + "type": "object", + "properties": { + "matchLabels": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\n+optional" + }, + "matchExpressions": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelectorRequirement" + }, + "title": "matchExpressions is a list of label selector requirements. The requirements are ANDed.\n+optional" + } + }, + "title": "A label selector is a label query over a set of resources. The result of matchLabels and\nmatchExpressions are ANDed. An empty label selector matches all objects. A null\nlabel selector matches no objects.\n+structType=atomic" + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelectorRequirement": { + "type": "object", + "properties": { + "key": { + "type": "string", + "title": "key is the label key that the selector applies to.\n+patchMergeKey=key\n+patchStrategy=merge" + }, + "operator": { + "type": "string", + "description": "operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist." + }, + "values": { + "type": "array", + "items": { + "type": "string" + }, + "title": "values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.\n+optional" + } + }, + "description": "A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values." + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.ManagedFieldsEntry": { + "type": "object", + "properties": { + "manager": { + "type": "string", + "description": "Manager is an identifier of the workflow managing these fields." + }, + "operation": { + "type": "string", + "description": "Operation is the type of operation which lead to this ManagedFieldsEntry being created.\nThe only valid values for this field are 'Apply' and 'Update'." + }, + "apiVersion": { + "type": "string", + "description": "APIVersion defines the version of this resource that this field set\napplies to. The format is \"group/version\" just like the top-level\nAPIVersion field. It is necessary to track the version of a field\nset because it cannot be automatically converted." + }, + "time": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "title": "Time is timestamp of when these fields were set. It should always be empty if Operation is 'Apply'\n+optional" + }, + "fieldsType": { + "type": "string", + "title": "FieldsType is the discriminator for the different fields format and version.\nThere is currently only one possible value: \"FieldsV1\"" + }, + "fieldsV1": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.FieldsV1", + "title": "FieldsV1 holds the first JSON version format as described in the \"FieldsV1\" type.\n+optional" + } + }, + "description": "ManagedFieldsEntry is a workflow-id, a FieldSet and the group version of the resource\nthat the fieldset applies to." + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta": { + "type": "object", + "properties": { + "name": { + "type": "string", + "title": "Name must be unique within a namespace. Is required when creating resources, although\nsome resources may allow a client to request the generation of an appropriate name\nautomatically. Name is primarily intended for creation idempotence and configuration\ndefinition.\nCannot be updated.\nMore info: http://kubernetes.io/docs/user-guide/identifiers#names\n+optional" + }, + "generateName": { + "type": "string", + "description": "GenerateName is an optional prefix, used by the server, to generate a unique\nname ONLY IF the Name field has not been provided.\nIf this field is used, the name returned to the client will be different\nthan the name passed. This value will also be combined with a unique suffix.\nThe provided value has the same validation rules as the Name field,\nand may be truncated by the length of the suffix required to make the value\nunique on the server.\n\nIf this field is specified and the generated name exists, the server will\nNOT return a 409 - instead, it will either return 201 Created or 500 with Reason\nServerTimeout indicating a unique name could not be found in the time allotted, and the client\nshould retry (optionally after the time indicated in the Retry-After header).\n\nApplied only if Name is not specified.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency\n+optional" + }, + "namespace": { + "type": "string", + "description": "Namespace defines the space within which each name must be unique. An empty namespace is\nequivalent to the \"default\" namespace, but \"default\" is the canonical representation.\nNot all objects are required to be scoped to a namespace - the value of this field for\nthose objects will be empty.\n\nMust be a DNS_LABEL.\nCannot be updated.\nMore info: http://kubernetes.io/docs/user-guide/namespaces\n+optional" + }, + "selfLink": { + "type": "string", + "description": "SelfLink is a URL representing this object.\nPopulated by the system.\nRead-only.\n\nDEPRECATED\nKubernetes will stop propagating this field in 1.20 release and the field is planned\nto be removed in 1.21 release.\n+optional" + }, + "uid": { + "type": "string", + "description": "UID is the unique in time and space value for this object. It is typically generated by\nthe server on successful creation of a resource and is not allowed to change on PUT\noperations.\n\nPopulated by the system.\nRead-only.\nMore info: http://kubernetes.io/docs/user-guide/identifiers#uids\n+optional" + }, + "resourceVersion": { + "type": "string", + "description": "An opaque value that represents the internal version of this object that can\nbe used by clients to determine when objects have changed. May be used for optimistic\nconcurrency, change detection, and the watch operation on a resource or set of resources.\nClients must treat these values as opaque and passed unmodified back to the server.\nThey may only be valid for a particular resource or set of resources.\n\nPopulated by the system.\nRead-only.\nValue must be treated as opaque by clients and .\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency\n+optional" + }, + "generation": { + "type": "string", + "format": "int64", + "title": "A sequence number representing a specific generation of the desired state.\nPopulated by the system. Read-only.\n+optional" + }, + "creationTimestamp": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "description": "CreationTimestamp is a timestamp representing the server time when this object was\ncreated. It is not guaranteed to be set in happens-before order across separate operations.\nClients may not set this value. It is represented in RFC3339 form and is in UTC.\n\nPopulated by the system.\nRead-only.\nNull for lists.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata\n+optional" + }, + "deletionTimestamp": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.Time", + "description": "DeletionTimestamp is RFC 3339 date and time at which this resource will be deleted. This\nfield is set by the server when a graceful deletion is requested by the user, and is not\ndirectly settable by a client. The resource is expected to be deleted (no longer visible\nfrom resource lists, and not reachable by name) after the time in this field, once the\nfinalizers list is empty. As long as the finalizers list contains items, deletion is blocked.\nOnce the deletionTimestamp is set, this value may not be unset or be set further into the\nfuture, although it may be shortened or the resource may be deleted prior to this time.\nFor example, a user may request that a pod is deleted in 30 seconds. The Kubelet will react\nby sending a graceful termination signal to the containers in the pod. After that 30 seconds,\nthe Kubelet will send a hard termination signal (SIGKILL) to the container and after cleanup,\nremove the pod from the API. In the presence of network partitions, this object may still\nexist after this timestamp, until an administrator or automated process can determine the\nresource is fully terminated.\nIf not set, graceful deletion of the object has not been requested.\n\nPopulated by the system when a graceful deletion is requested.\nRead-only.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata\n+optional" + }, + "deletionGracePeriodSeconds": { + "type": "string", + "format": "int64", + "title": "Number of seconds allowed for this object to gracefully terminate before\nit will be removed from the system. Only set when deletionTimestamp is also set.\nMay only be shortened.\nRead-only.\n+optional" + }, + "labels": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects. May match selectors of replication controllers\nand services.\nMore info: http://kubernetes.io/docs/user-guide/labels\n+optional" + }, + "annotations": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "title": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: http://kubernetes.io/docs/user-guide/annotations\n+optional" + }, + "ownerReferences": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.OwnerReference" + }, + "title": "List of objects depended by this object. If ALL objects in the list have\nbeen deleted, this object will be garbage collected. If this object is managed by a controller,\nthen an entry in this list will point to this controller, with the controller field set to true.\nThere cannot be more than one managing controller.\n+optional\n+patchMergeKey=uid\n+patchStrategy=merge" + }, + "finalizers": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Must be empty before the object is deleted from the registry. Each entry\nis an identifier for the responsible component that will remove the entry\nfrom the list. If the deletionTimestamp of the object is non-nil, entries\nin this list can only be removed.\nFinalizers may be processed and removed in any order. Order is NOT enforced\nbecause it introduces significant risk of stuck finalizers.\nfinalizers is a shared field, any actor with permission can reorder it.\nIf the finalizer list is processed in order, then this can lead to a situation\nin which the component responsible for the first finalizer in the list is\nwaiting for a signal (field value, external system, or other) produced by a\ncomponent responsible for a finalizer later in the list, resulting in a deadlock.\nWithout enforced ordering finalizers are free to order amongst themselves and\nare not vulnerable to ordering changes in the list.\n+optional\n+patchStrategy=merge" + }, + "clusterName": { + "type": "string", + "title": "The name of the cluster which the object belongs to.\nThis is used to distinguish resources with same name and namespace in different clusters.\nThis field is not set anywhere right now and apiserver is going to ignore it if set in create or update request.\n+optional" + }, + "managedFields": { + "type": "array", + "items": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ManagedFieldsEntry" + }, + "description": "ManagedFields maps workflow-id and version to the set of fields\nthat are managed by that workflow. This is mostly for internal\nhousekeeping, and users typically shouldn't need to set or\nunderstand this field. A workflow can be the user's name, a\ncontroller's name, or the name of a specific apply path like\n\"ci-cd\". The set of fields is always in the version that the\nworkflow used when modifying the object.\n\n+optional" + } + }, + "description": "ObjectMeta is metadata that all persisted resources must have, which includes all objects\nusers must create." + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.OwnerReference": { + "type": "object", + "properties": { + "apiVersion": { + "type": "string", + "description": "API version of the referent." + }, + "kind": { + "type": "string", + "title": "Kind of the referent.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds" + }, + "name": { + "type": "string", + "title": "Name of the referent.\nMore info: http://kubernetes.io/docs/user-guide/identifiers#names" + }, + "uid": { + "type": "string", + "title": "UID of the referent.\nMore info: http://kubernetes.io/docs/user-guide/identifiers#uids" + }, + "controller": { + "type": "boolean", + "title": "If true, this reference points to the managing controller.\n+optional" + }, + "blockOwnerDeletion": { + "type": "boolean", + "title": "If true, AND if the owner has the \"foregroundDeletion\" finalizer, then\nthe owner cannot be deleted from the key-value store until this\nreference is removed.\nDefaults to false.\nTo set this field, a user needs \"delete\" permission of the owner,\notherwise 422 (Unprocessable Entity) will be returned.\n+optional" + } + }, + "description": "OwnerReference contains enough information to let you identify an owning\nobject. An owning object must be in the same namespace as the dependent, or\nbe cluster-scoped, so there is no namespace field." + }, + "k8s.io.apimachinery.pkg.apis.meta.v1.Time": { + "type": "object", + "properties": { + "seconds": { + "type": "string", + "format": "int64", + "description": "Represents seconds of UTC time since Unix epoch\n1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to\n9999-12-31T23:59:59Z inclusive." + }, + "nanos": { + "type": "integer", + "format": "int32", + "description": "Non-negative fractions of a second at nanosecond resolution. Negative\nsecond values with fractions must still have non-negative nanos values\nthat count forward in time. Must be from 0 to 999,999,999\ninclusive. This field may be limited in precision depending on context." + } + }, + "description": "Time is a wrapper around time.Time which supports correct\nmarshaling to YAML and JSON. Wrappers are provided for many\nof the factory methods that the time package offers.\n\n+protobuf.options.marshal=false\n+protobuf.as=Timestamp\n+protobuf.options.(gogoproto.goproto_stringer)=false" + }, + "k8s.io.apimachinery.pkg.util.intstr.IntOrString": { + "type": "object", + "properties": { + "type": { + "type": "string", + "format": "int64" + }, + "intVal": { + "type": "integer", + "format": "int32" + }, + "strVal": { + "type": "string" + } + }, + "description": "+protobuf=true\n+protobuf.options.(gogoproto.goproto_stringer)=false\n+k8s:openapi-gen=true", + "title": "IntOrString is a type that can hold an int32 or a string. When used in\nJSON or YAML marshalling and unmarshalling, it produces or consumes the\ninner type. This allows you to have, for example, a JSON field that can\naccept a name or number.\nTODO: Rename to Int32OrString" + }, + "rollout.AbortRolloutRequest": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.AnalysisRunInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "icon": { + "type": "string" + }, + "revision": { + "type": "integer", + "format": "int32" + }, + "status": { + "type": "string" + }, + "successful": { + "type": "integer", + "format": "int32" + }, + "failed": { + "type": "integer", + "format": "int32" + }, + "inconclusive": { + "type": "integer", + "format": "int32" + }, + "error": { + "type": "integer", + "format": "int32" + }, + "jobs": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.JobInfo" + } + } + } + }, + "rollout.ContainerInfo": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "image": { + "type": "string" + } + } + }, + "rollout.ExperimentInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "icon": { + "type": "string" + }, + "revision": { + "type": "integer", + "format": "int32" + }, + "status": { + "type": "string" + }, + "message": { + "type": "string" + }, + "replicaSets": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.ReplicaSetInfo" + } + }, + "analysisRuns": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.AnalysisRunInfo" + } + } + } + }, + "rollout.JobInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "status": { + "type": "string" + }, + "icon": { + "type": "string" + } + } + }, + "rollout.NamespaceInfo": { + "type": "object", + "properties": { + "namespace": { + "type": "string" + } + } + }, + "rollout.PodInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "status": { + "type": "string" + }, + "icon": { + "type": "string" + }, + "ready": { + "type": "string" + }, + "restarts": { + "type": "integer", + "format": "int32" + } + } + }, + "rollout.PromoteRolloutRequest": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.ReplicaSetInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "status": { + "type": "string" + }, + "icon": { + "type": "string" + }, + "revision": { + "type": "integer", + "format": "int32" + }, + "stable": { + "type": "boolean" + }, + "canary": { + "type": "boolean" + }, + "active": { + "type": "boolean" + }, + "preview": { + "type": "boolean" + }, + "replicas": { + "type": "integer", + "format": "int32" + }, + "available": { + "type": "integer", + "format": "int32" + }, + "template": { + "type": "string" + }, + "scaleDownDeadline": { + "type": "string" + }, + "images": { + "type": "array", + "items": { + "type": "string" + } + }, + "pods": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.PodInfo" + } + } + } + }, + "rollout.RestartRolloutRequest": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.RetryRolloutRequest": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.RolloutInfo": { + "type": "object", + "properties": { + "objectMeta": { + "$ref": "#/definitions/k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta" + }, + "status": { + "type": "string" + }, + "message": { + "type": "string" + }, + "icon": { + "type": "string" + }, + "strategy": { + "type": "string" + }, + "step": { + "type": "string" + }, + "setWeight": { + "type": "string" + }, + "actualWeight": { + "type": "string" + }, + "ready": { + "type": "integer", + "format": "int32" + }, + "current": { + "type": "integer", + "format": "int32" + }, + "desired": { + "type": "integer", + "format": "int32" + }, + "updated": { + "type": "integer", + "format": "int32" + }, + "available": { + "type": "integer", + "format": "int32" + }, + "restartedAt": { + "type": "string" + }, + "generation": { + "type": "string" + }, + "replicaSets": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.ReplicaSetInfo" + } + }, + "experiments": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.ExperimentInfo" + } + }, + "analysisRuns": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.AnalysisRunInfo" + } + }, + "containers": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.ContainerInfo" + } + }, + "steps": { + "type": "array", + "items": { + "$ref": "#/definitions/github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStep" + } + } + } + }, + "rollout.RolloutInfoList": { + "type": "object", + "properties": { + "rollouts": { + "type": "array", + "items": { + "$ref": "#/definitions/rollout.RolloutInfo" + } + } + } + }, + "rollout.RolloutWatchEvent": { + "type": "object", + "properties": { + "type": { + "type": "string" + }, + "rolloutInfo": { + "$ref": "#/definitions/rollout.RolloutInfo" + } + } + }, + "rollout.SetImageRequest": { + "type": "object", + "properties": { + "rollout": { + "type": "string" + }, + "container": { + "type": "string" + }, + "image": { + "type": "string" + }, + "tag": { + "type": "string" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.UndoRolloutRequest": { + "type": "object", + "properties": { + "rollout": { + "type": "string" + }, + "revision": { + "type": "string", + "format": "int64" + }, + "namespace": { + "type": "string" + } + } + }, + "rollout.VersionInfo": { + "type": "object", + "properties": { + "rolloutsVersion": { + "type": "string" + } + } + } + } +} diff --git a/pkg/apis/rollouts/v1alpha1/analysis_types.go b/pkg/apis/rollouts/v1alpha1/analysis_types.go index 876362ae41..7144824155 100644 --- a/pkg/apis/rollouts/v1alpha1/analysis_types.go +++ b/pkg/apis/rollouts/v1alpha1/analysis_types.go @@ -16,17 +16,17 @@ import ( // +kubebuilder:resource:path=clusteranalysistemplates,shortName=cat type ClusterAnalysisTemplate struct { metav1.TypeMeta `json:",inline"` - metav1.ObjectMeta `json:"metadata,omitempty"` + metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - Spec AnalysisTemplateSpec `json:"spec"` + Spec AnalysisTemplateSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` } // AnalysisTemplateList is a list of AnalysisTemplate resources // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object type ClusterAnalysisTemplateList struct { metav1.TypeMeta `json:",inline"` - metav1.ListMeta `json:"metadata"` - Items []ClusterAnalysisTemplate `json:"items"` + metav1.ListMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` + Items []ClusterAnalysisTemplate `json:"items" protobuf:"bytes,2,rep,name=items"` } // AnalysisTemplate holds the template for performing canary analysis @@ -35,17 +35,17 @@ type ClusterAnalysisTemplateList struct { // +kubebuilder:resource:path=analysistemplates,shortName=at type AnalysisTemplate struct { metav1.TypeMeta `json:",inline"` - metav1.ObjectMeta `json:"metadata,omitempty"` + metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - Spec AnalysisTemplateSpec `json:"spec"` + Spec AnalysisTemplateSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` } // AnalysisTemplateList is a list of AnalysisTemplate resources // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object type AnalysisTemplateList struct { metav1.TypeMeta `json:",inline"` - metav1.ListMeta `json:"metadata"` - Items []AnalysisTemplate `json:"items"` + metav1.ListMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` + Items []AnalysisTemplate `json:"items" protobuf:"bytes,2,rep,name=items"` } // AnalysisTemplateSpec is the specification for a AnalysisTemplate resource @@ -53,12 +53,12 @@ type AnalysisTemplateSpec struct { // Metrics contains the list of metrics to query as part of an analysis run // +patchMergeKey=name // +patchStrategy=merge - Metrics []Metric `json:"metrics" patchStrategy:"merge" patchMergeKey:"name"` + Metrics []Metric `json:"metrics" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,1,rep,name=metrics"` // Args are the list of arguments to the template // +patchMergeKey=name // +patchStrategy=merge // +optional - Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=args"` } // DurationString is a string representing a duration (e.g. 30s, 5m, 1h) @@ -72,38 +72,38 @@ func (d DurationString) Duration() (time.Duration, error) { // Metric defines a metric in which to perform analysis type Metric struct { // Name is the name of the metric - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Interval defines an interval string (e.g. 30s, 5m, 1h) between each measurement. // If omitted, will perform a single measurement - Interval DurationString `json:"interval,omitempty"` + Interval DurationString `json:"interval,omitempty" protobuf:"bytes,2,opt,name=interval,casttype=DurationString"` // InitialDelay how long the AnalysisRun should wait before starting this metric - InitialDelay DurationString `json:"initialDelay,omitempty"` + InitialDelay DurationString `json:"initialDelay,omitempty" protobuf:"bytes,3,opt,name=initialDelay,casttype=DurationString"` // Count is the number of times to run the measurement. If both interval and count are omitted, // the effective count is 1. If only interval is specified, metric runs indefinitely. // If count > 1, interval must be specified. - Count *intstrutil.IntOrString `json:"count,omitempty"` + Count *intstrutil.IntOrString `json:"count,omitempty" protobuf:"bytes,4,opt,name=count"` // SuccessCondition is an expression which determines if a measurement is considered successful // Expression is a goevaluate expression. The keyword `result` is a variable reference to the // value of measurement. Results can be both structured data or primitive. // Examples: // result > 10 // (result.requests_made * result.requests_succeeded / 100) >= 90 - SuccessCondition string `json:"successCondition,omitempty"` + SuccessCondition string `json:"successCondition,omitempty" protobuf:"bytes,5,opt,name=successCondition"` // FailureCondition is an expression which determines if a measurement is considered failed // If both success and failure conditions are specified, and the measurement does not fall into // either condition, the measurement is considered Inconclusive - FailureCondition string `json:"failureCondition,omitempty"` + FailureCondition string `json:"failureCondition,omitempty" protobuf:"bytes,6,opt,name=failureCondition"` // FailureLimit is the maximum number of times the measurement is allowed to fail, before the // entire metric is considered Failed (default: 0) - FailureLimit *intstrutil.IntOrString `json:"failureLimit,omitempty"` + FailureLimit *intstrutil.IntOrString `json:"failureLimit,omitempty" protobuf:"bytes,7,opt,name=failureLimit"` // InconclusiveLimit is the maximum number of times the measurement is allowed to measure // Inconclusive, before the entire metric is considered Inconclusive (default: 0) - InconclusiveLimit *intstrutil.IntOrString `json:"inconclusiveLimit,omitempty"` + InconclusiveLimit *intstrutil.IntOrString `json:"inconclusiveLimit,omitempty" protobuf:"bytes,8,opt,name=inconclusiveLimit"` // ConsecutiveErrorLimit is the maximum number of times the measurement is allowed to error in // succession, before the metric is considered error (default: 4) - ConsecutiveErrorLimit *intstrutil.IntOrString `json:"consecutiveErrorLimit,omitempty"` + ConsecutiveErrorLimit *intstrutil.IntOrString `json:"consecutiveErrorLimit,omitempty" protobuf:"bytes,9,opt,name=consecutiveErrorLimit"` // Provider configuration to the external system to use to verify the analysis - Provider MetricProvider `json:"provider"` + Provider MetricProvider `json:"provider" protobuf:"bytes,10,opt,name=provider"` } // EffectiveCount is the effective count based on whether or not count/interval is specified @@ -126,19 +126,19 @@ func (m *Metric) EffectiveCount() *intstrutil.IntOrString { // Only one of the fields in this struct should be non-nil type MetricProvider struct { // Prometheus specifies the prometheus metric to query - Prometheus *PrometheusMetric `json:"prometheus,omitempty"` + Prometheus *PrometheusMetric `json:"prometheus,omitempty" protobuf:"bytes,1,opt,name=prometheus"` // Kayenta specifies a Kayenta metric - Kayenta *KayentaMetric `json:"kayenta,omitempty"` + Kayenta *KayentaMetric `json:"kayenta,omitempty" protobuf:"bytes,2,opt,name=kayenta"` // Web specifies a generic HTTP web metric - Web *WebMetric `json:"web,omitempty"` + Web *WebMetric `json:"web,omitempty" protobuf:"bytes,3,opt,name=web"` // Datadog specifies a datadog metric to query - Datadog *DatadogMetric `json:"datadog,omitempty"` + Datadog *DatadogMetric `json:"datadog,omitempty" protobuf:"bytes,4,opt,name=datadog"` // Wavefront specifies the wavefront metric to query - Wavefront *WavefrontMetric `json:"wavefront,omitempty"` + Wavefront *WavefrontMetric `json:"wavefront,omitempty" protobuf:"bytes,5,opt,name=wavefront"` // NewRelic specifies the newrelic metric to query - NewRelic *NewRelicMetric `json:"newRelic,omitempty"` + NewRelic *NewRelicMetric `json:"newRelic,omitempty" protobuf:"bytes,6,opt,name=newRelic"` // Job specifies the job metric run - Job *JobMetric `json:"job,omitempty"` + Job *JobMetric `json:"job,omitempty" protobuf:"bytes,7,opt,name=job"` } // AnalysisPhase is the overall phase of an AnalysisRun, MetricResult, or Measurement @@ -166,31 +166,31 @@ func (as AnalysisPhase) Completed() bool { // PrometheusMetric defines the prometheus query to perform canary analysis type PrometheusMetric struct { // Address is the HTTP address and port of the prometheus server - Address string `json:"address,omitempty"` + Address string `json:"address,omitempty" protobuf:"bytes,1,opt,name=address"` // Query is a raw prometheus query to perform - Query string `json:"query,omitempty"` + Query string `json:"query,omitempty" protobuf:"bytes,2,opt,name=query"` } // WavefrontMetric defines the wavefront query to perform canary analysis type WavefrontMetric struct { // Address is the HTTP address and port of the wavefront server - Address string `json:"address,omitempty"` + Address string `json:"address,omitempty" protobuf:"bytes,1,opt,name=address"` // Query is a raw wavefront query to perform - Query string `json:"query,omitempty"` + Query string `json:"query,omitempty" protobuf:"bytes,2,opt,name=query"` } // NewRelicMetric defines the newrelic query to perform canary analysis type NewRelicMetric struct { // Profile is the name of the secret holding NR account configuration - Profile string `json:"profile,omitempty"` + Profile string `json:"profile,omitempty" protobuf:"bytes,1,opt,name=profile"` // Query is a raw newrelic NRQL query to perform - Query string `json:"query"` + Query string `json:"query" protobuf:"bytes,2,opt,name=query"` } // JobMetric defines a job to run which acts as a metric type JobMetric struct { - Metadata metav1.ObjectMeta `json:"metadata,omitempty"` - Spec batchv1.JobSpec `json:"spec"` + Metadata metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + Spec batchv1.JobSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` } // AnalysisRun is an instantiation of an AnalysisTemplate @@ -200,17 +200,17 @@ type JobMetric struct { // +kubebuilder:printcolumn:name="Status",type="string",JSONPath=".status.phase",description="AnalysisRun status" type AnalysisRun struct { metav1.TypeMeta `json:",inline"` - metav1.ObjectMeta `json:"metadata,omitempty"` - Spec AnalysisRunSpec `json:"spec"` - Status AnalysisRunStatus `json:"status,omitempty"` + metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + Spec AnalysisRunSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` + Status AnalysisRunStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // AnalysisRunList is a list of AnalysisTemplate resources // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object type AnalysisRunList struct { metav1.TypeMeta `json:",inline"` - metav1.ListMeta `json:"metadata"` - Items []AnalysisRun `json:"items"` + metav1.ListMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` + Items []AnalysisRun `json:"items" protobuf:"bytes,2,rep,name=items"` } // AnalysisRunSpec is the spec for a AnalysisRun resource @@ -218,159 +218,159 @@ type AnalysisRunSpec struct { // Metrics contains the list of metrics to query as part of an analysis run // +patchMergeKey=name // +patchStrategy=merge - Metrics []Metric `json:"metrics" patchStrategy:"merge" patchMergeKey:"name"` + Metrics []Metric `json:"metrics" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,1,rep,name=metrics"` // Args are the list of arguments used in this run // +optional // +patchMergeKey=name // +patchStrategy=merge - Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=args"` // Terminate is used to prematurely stop the run (e.g. rollout completed and analysis is no longer desired) - Terminate bool `json:"terminate,omitempty"` + Terminate bool `json:"terminate,omitempty" protobuf:"varint,3,opt,name=terminate"` } // Argument is an argument to an AnalysisRun type Argument struct { // Name is the name of the argument - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Value is the value of the argument // +optional - Value *string `json:"value,omitempty"` + Value *string `json:"value,omitempty" protobuf:"bytes,2,opt,name=value"` // ValueFrom is a reference to where a secret is stored. This field is one of the fields with valueFrom // +optional - ValueFrom *ValueFrom `json:"valueFrom,omitempty"` + ValueFrom *ValueFrom `json:"valueFrom,omitempty" protobuf:"bytes,3,opt,name=valueFrom"` } type ValueFrom struct { // Secret is a reference to where a secret is stored. This field is one of the fields with valueFrom // +optional - SecretKeyRef *SecretKeyRef `json:"secretKeyRef,omitempty"` + SecretKeyRef *SecretKeyRef `json:"secretKeyRef,omitempty" protobuf:"bytes,1,opt,name=secretKeyRef"` //FieldRef is a reference to the fields in metadata which we are referencing. This field is one of the fields with //valueFrom // +optional - FieldRef *FieldRef `json:"fieldRef,omitempty"` + FieldRef *FieldRef `json:"fieldRef,omitempty" protobuf:"bytes,2,opt,name=fieldRef"` } type SecretKeyRef struct { // Name is the name of the secret - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Key is the key of the secret to select from. - Key string `json:"key"` + Key string `json:"key" protobuf:"bytes,2,opt,name=key"` } // AnalysisRunStatus is the status for a AnalysisRun resource type AnalysisRunStatus struct { // Phase is the status of the analysis run - Phase AnalysisPhase `json:"phase"` + Phase AnalysisPhase `json:"phase" protobuf:"bytes,1,opt,name=phase,casttype=AnalysisPhase"` // Message is a message explaining current status - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` // MetricResults contains the metrics collected during the run - MetricResults []MetricResult `json:"metricResults,omitempty"` + MetricResults []MetricResult `json:"metricResults,omitempty" protobuf:"bytes,3,rep,name=metricResults"` // StartedAt indicates when the analysisRun first started - StartedAt *metav1.Time `json:"startedAt,omitempty"` + StartedAt *metav1.Time `json:"startedAt,omitempty" protobuf:"bytes,4,opt,name=startedAt"` } // MetricResult contain a list of the most recent measurements for a single metric along with // counters on how often the measurement type MetricResult struct { // Name is the name of the metric - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Phase is the overall aggregate status of the metric - Phase AnalysisPhase `json:"phase"` + Phase AnalysisPhase `json:"phase" protobuf:"bytes,2,opt,name=phase,casttype=AnalysisPhase"` // Measurements holds the most recent measurements collected for the metric - Measurements []Measurement `json:"measurements,omitempty"` + Measurements []Measurement `json:"measurements,omitempty" protobuf:"bytes,3,rep,name=measurements"` // Message contains a message describing current condition (e.g. error messages) - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,4,opt,name=message"` // Count is the number of times the metric was measured without Error // This is equal to the sum of Successful, Failed, Inconclusive - Count int32 `json:"count,omitempty"` + Count int32 `json:"count,omitempty" protobuf:"varint,5,opt,name=count"` // Successful is the number of times the metric was measured Successful - Successful int32 `json:"successful,omitempty"` + Successful int32 `json:"successful,omitempty" protobuf:"varint,6,opt,name=successful"` // Failed is the number of times the metric was measured Failed - Failed int32 `json:"failed,omitempty"` + Failed int32 `json:"failed,omitempty" protobuf:"varint,7,opt,name=failed"` // Inconclusive is the number of times the metric was measured Inconclusive - Inconclusive int32 `json:"inconclusive,omitempty"` + Inconclusive int32 `json:"inconclusive,omitempty" protobuf:"varint,8,opt,name=inconclusive"` // Error is the number of times an error was encountered during measurement - Error int32 `json:"error,omitempty"` + Error int32 `json:"error,omitempty" protobuf:"varint,9,opt,name=error"` // ConsecutiveError is the number of times an error was encountered during measurement in succession // Resets to zero when non-errors are encountered - ConsecutiveError int32 `json:"consecutiveError,omitempty"` + ConsecutiveError int32 `json:"consecutiveError,omitempty" protobuf:"varint,10,opt,name=consecutiveError"` } // Measurement is a point in time result value of a single metric, and the time it was measured type Measurement struct { // Phase is the status of this single measurement - Phase AnalysisPhase `json:"phase"` + Phase AnalysisPhase `json:"phase" protobuf:"bytes,1,opt,name=phase,casttype=AnalysisPhase"` // Message contains a message describing current condition (e.g. error messages) - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` // StartedAt is the timestamp in which this measurement started to be measured - StartedAt *metav1.Time `json:"startedAt,omitempty"` + StartedAt *metav1.Time `json:"startedAt,omitempty" protobuf:"bytes,3,opt,name=startedAt"` // FinishedAt is the timestamp in which this measurement completed and value was collected - FinishedAt *metav1.Time `json:"finishedAt,omitempty"` + FinishedAt *metav1.Time `json:"finishedAt,omitempty" protobuf:"bytes,4,opt,name=finishedAt"` // Value is the measured value of the metric - Value string `json:"value,omitempty"` + Value string `json:"value,omitempty" protobuf:"bytes,5,opt,name=value"` // Metadata stores additional metadata about this metric result, used by the different providers // (e.g. kayenta run ID, job name) - Metadata map[string]string `json:"metadata,omitempty"` + Metadata map[string]string `json:"metadata,omitempty" protobuf:"bytes,6,rep,name=metadata"` // ResumeAt is the timestamp when the analysisRun should try to resume the measurement - ResumeAt *metav1.Time `json:"resumeAt,omitempty"` + ResumeAt *metav1.Time `json:"resumeAt,omitempty" protobuf:"bytes,7,opt,name=resumeAt"` } type KayentaMetric struct { - Address string `json:"address"` + Address string `json:"address" protobuf:"bytes,1,opt,name=address"` - Application string `json:"application"` + Application string `json:"application" protobuf:"bytes,2,opt,name=application"` - CanaryConfigName string `json:"canaryConfigName"` + CanaryConfigName string `json:"canaryConfigName" protobuf:"bytes,3,opt,name=canaryConfigName"` - MetricsAccountName string `json:"metricsAccountName"` - ConfigurationAccountName string `json:"configurationAccountName"` - StorageAccountName string `json:"storageAccountName"` + MetricsAccountName string `json:"metricsAccountName" protobuf:"bytes,4,opt,name=metricsAccountName"` + ConfigurationAccountName string `json:"configurationAccountName" protobuf:"bytes,5,opt,name=configurationAccountName"` + StorageAccountName string `json:"storageAccountName" protobuf:"bytes,6,opt,name=storageAccountName"` - Threshold KayentaThreshold `json:"threshold"` + Threshold KayentaThreshold `json:"threshold" protobuf:"bytes,7,opt,name=threshold"` - Scopes []KayentaScope `json:"scopes"` + Scopes []KayentaScope `json:"scopes" protobuf:"bytes,8,rep,name=scopes"` } type KayentaThreshold struct { - Pass int `json:"pass"` - Marginal int `json:"marginal"` + Pass int64 `json:"pass" protobuf:"varint,1,opt,name=pass"` + Marginal int64 `json:"marginal" protobuf:"varint,2,opt,name=marginal"` } type KayentaScope struct { - Name string `json:"name"` - ControlScope ScopeDetail `json:"controlScope"` - ExperimentScope ScopeDetail `json:"experimentScope"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` + ControlScope ScopeDetail `json:"controlScope" protobuf:"bytes,2,opt,name=controlScope"` + ExperimentScope ScopeDetail `json:"experimentScope" protobuf:"bytes,3,opt,name=experimentScope"` } type ScopeDetail struct { - Scope string `json:"scope"` - Region string `json:"region"` - Step int `json:"step"` - Start string `json:"start"` - End string `json:"end"` + Scope string `json:"scope" protobuf:"bytes,1,opt,name=scope"` + Region string `json:"region" protobuf:"bytes,2,opt,name=region"` + Step int64 `json:"step" protobuf:"varint,3,opt,name=step"` + Start string `json:"start" protobuf:"bytes,4,opt,name=start"` + End string `json:"end" protobuf:"bytes,5,opt,name=end"` } type WebMetric struct { // URL is the address of the web metric - URL string `json:"url"` + URL string `json:"url" protobuf:"bytes,1,opt,name=url"` // +patchMergeKey=key // +patchStrategy=merge // Headers are optional HTTP headers to use in the request - Headers []WebMetricHeader `json:"headers,omitempty" patchStrategy:"merge" patchMergeKey:"key"` + Headers []WebMetricHeader `json:"headers,omitempty" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,2,rep,name=headers"` // TimeoutSeconds is the timeout for the request in seconds (default: 10) - TimeoutSeconds int `json:"timeoutSeconds,omitempty"` + TimeoutSeconds int64 `json:"timeoutSeconds,omitempty" protobuf:"varint,3,opt,name=timeoutSeconds"` // JSONPath is a JSON Path to use as the result variable (default: "{$}") - JSONPath string `json:"jsonPath,omitempty"` + JSONPath string `json:"jsonPath,omitempty" protobuf:"bytes,4,opt,name=jsonPath"` // Insecure skips host TLS verification - Insecure bool `json:"insecure,omitempty"` + Insecure bool `json:"insecure,omitempty" protobuf:"varint,5,opt,name=insecure"` } type WebMetricHeader struct { - Key string `json:"key"` - Value string `json:"value"` + Key string `json:"key" protobuf:"bytes,1,opt,name=key"` + Value string `json:"value" protobuf:"bytes,2,opt,name=value"` } type DatadogMetric struct { - Interval DurationString `json:"interval,omitempty"` - Query string `json:"query"` + Interval DurationString `json:"interval,omitempty" protobuf:"bytes,1,opt,name=interval,casttype=DurationString"` + Query string `json:"query" protobuf:"bytes,2,opt,name=query"` } diff --git a/pkg/apis/rollouts/v1alpha1/experiment_types.go b/pkg/apis/rollouts/v1alpha1/experiment_types.go index 27e1492da0..17fb642742 100644 --- a/pkg/apis/rollouts/v1alpha1/experiment_types.go +++ b/pkg/apis/rollouts/v1alpha1/experiment_types.go @@ -18,10 +18,10 @@ const ( // +kubebuilder:printcolumn:name="Status",type="string",JSONPath=".status.phase",description="Experiment status" type Experiment struct { metav1.TypeMeta `json:",inline"` - metav1.ObjectMeta `json:"metadata,omitempty"` + metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - Spec ExperimentSpec `json:"spec"` - Status ExperimentStatus `json:"status,omitempty"` + Spec ExperimentSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` + Status ExperimentStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // ExperimentSpec is the spec for a Experiment resource @@ -29,44 +29,44 @@ type ExperimentSpec struct { // Templates are a list of PodSpecs that define the ReplicaSets that should be run during an experiment. // +patchMergeKey=name // +patchStrategy=merge - Templates []TemplateSpec `json:"templates" patchStrategy:"merge" patchMergeKey:"name"` + Templates []TemplateSpec `json:"templates" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,1,rep,name=templates"` // Duration the amount of time for the experiment to run as a duration string (e.g. 30s, 5m, 1h). // If omitted, the experiment will run indefinitely, stopped either via termination, or a failed analysis run. // +optional - Duration DurationString `json:"duration,omitempty"` + Duration DurationString `json:"duration,omitempty" protobuf:"bytes,2,opt,name=duration,casttype=DurationString"` // ProgressDeadlineSeconds The maximum time in seconds for a experiment to // make progress before it is considered to be failed. Argo Rollouts will // continue to process failed experiments and a condition with a // ProgressDeadlineExceeded reason will be surfaced in the experiment status. // Defaults to 600s. // +optional - ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty"` + ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty" protobuf:"varint,3,opt,name=progressDeadlineSeconds"` // Terminate is used to prematurely stop the experiment - Terminate bool `json:"terminate,omitempty"` + Terminate bool `json:"terminate,omitempty" protobuf:"varint,4,opt,name=terminate"` // Analyses references AnalysisTemplates to run during the experiment // +patchMergeKey=name // +patchStrategy=merge - Analyses []ExperimentAnalysisTemplateRef `json:"analyses,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Analyses []ExperimentAnalysisTemplateRef `json:"analyses,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,5,rep,name=analyses"` } type TemplateSpec struct { // Name of the template used to identity replicaset running for this experiment - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Number of desired pods. This is a pointer to distinguish between explicit // zero and not specified. Defaults to 1. // +optional - Replicas *int32 `json:"replicas,omitempty"` + Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) // +optional - MinReadySeconds int32 `json:"minReadySeconds,omitempty"` + MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,3,opt,name=minReadySeconds"` // Label selector for pods. Existing ReplicaSets whose pods are // selected by this will be the ones affected by this experiment. // It must match the pod template's labels. Each selector must be unique to the other selectors in the other templates - Selector *metav1.LabelSelector `json:"selector"` + Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,4,opt,name=selector"` // Template describes the pods that will be created. - Template corev1.PodTemplateSpec `json:"template"` + Template corev1.PodTemplateSpec `json:"template" protobuf:"bytes,5,opt,name=template"` } type TemplateStatusCode string @@ -90,50 +90,50 @@ func (ts TemplateStatusCode) Completed() bool { // TemplateStatus is the status of a specific template of an Experiment type TemplateStatus struct { // Name of the template used to identity which hash to compare to the hash - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Total number of non-terminated pods targeted by this experiment (their labels match the selector). - Replicas int32 `json:"replicas"` + Replicas int32 `json:"replicas" protobuf:"varint,2,opt,name=replicas"` // Total number of non-terminated pods targeted by this experiment that have the desired template spec. - UpdatedReplicas int32 `json:"updatedReplicas"` + UpdatedReplicas int32 `json:"updatedReplicas" protobuf:"varint,3,opt,name=updatedReplicas"` // Total number of ready pods targeted by this experiment. - ReadyReplicas int32 `json:"readyReplicas"` + ReadyReplicas int32 `json:"readyReplicas" protobuf:"varint,4,opt,name=readyReplicas"` // Total number of available pods (ready for at least minReadySeconds) targeted by this experiment. - AvailableReplicas int32 `json:"availableReplicas"` + AvailableReplicas int32 `json:"availableReplicas" protobuf:"varint,5,opt,name=availableReplicas"` // CollisionCount count of hash collisions for the Experiment. The Experiment controller uses this // field as a collision avoidance mechanism when it needs to create the name for the // newest ReplicaSet. // +optional - CollisionCount *int32 `json:"collisionCount,omitempty"` + CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,6,opt,name=collisionCount"` // Phase is the status of the ReplicaSet associated with the template - Status TemplateStatusCode `json:"status,omitempty"` + Status TemplateStatusCode `json:"status,omitempty" protobuf:"bytes,7,opt,name=status,casttype=TemplateStatusCode"` // Message is a message explaining the current status - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,8,opt,name=message"` // LastTransitionTime is the last time the replicaset transitioned, which resets the countdown // on the ProgressDeadlineSeconds check. - LastTransitionTime *metav1.Time `json:"lastTransitionTime,omitempty"` + LastTransitionTime *metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,9,opt,name=lastTransitionTime"` } // ExperimentStatus is the status for a Experiment resource type ExperimentStatus struct { // Phase is the status of the experiment. Takes into consideration ReplicaSet degradations and // AnalysisRun statuses - Phase AnalysisPhase `json:"phase,omitempty"` + Phase AnalysisPhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=AnalysisPhase"` // Message is an explanation for the current status // +optional - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` // TemplateStatuses holds the ReplicaSet related statuses for individual templates // +optional - TemplateStatuses []TemplateStatus `json:"templateStatuses,omitempty"` + TemplateStatuses []TemplateStatus `json:"templateStatuses,omitempty" protobuf:"bytes,3,rep,name=templateStatuses"` // AvailableAt the time when all the templates become healthy and the experiment should start tracking the time to // run for the duration of specificed in the spec. // +optional - AvailableAt *metav1.Time `json:"availableAt,omitempty"` + AvailableAt *metav1.Time `json:"availableAt,omitempty" protobuf:"bytes,4,opt,name=availableAt"` // Conditions a list of conditions a experiment can have. // +optional - Conditions []ExperimentCondition `json:"conditions,omitempty"` + Conditions []ExperimentCondition `json:"conditions,omitempty" protobuf:"bytes,5,rep,name=conditions"` // AnalysisRuns tracks the status of AnalysisRuns associated with this Experiment // +optional - AnalysisRuns []ExperimentAnalysisRunStatus `json:"analysisRuns,omitempty"` + AnalysisRuns []ExperimentAnalysisRunStatus `json:"analysisRuns,omitempty" protobuf:"bytes,6,rep,name=analysisRuns"` } // ExperimentConditionType defines the conditions of Experiment @@ -163,17 +163,17 @@ const ( // ExperimentCondition describes the state of a experiment at a certain point. type ExperimentCondition struct { // Type of deployment condition. - Type ExperimentConditionType `json:"type"` + Type ExperimentConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=ExperimentConditionType"` // Phase of the condition, one of True, False, Unknown. - Status corev1.ConditionStatus `json:"status"` + Status corev1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` // The last time this condition was updated. - LastUpdateTime metav1.Time `json:"lastUpdateTime"` + LastUpdateTime metav1.Time `json:"lastUpdateTime" protobuf:"bytes,3,opt,name=lastUpdateTime"` // Last time the condition transitioned from one status to another. - LastTransitionTime metav1.Time `json:"lastTransitionTime"` + LastTransitionTime metav1.Time `json:"lastTransitionTime" protobuf:"bytes,4,opt,name=lastTransitionTime"` // The reason for the condition's last transition. - Reason string `json:"reason"` + Reason string `json:"reason" protobuf:"bytes,5,opt,name=reason"` // A human readable message indicating details about the transition. - Message string `json:"message"` + Message string `json:"message" protobuf:"bytes,6,opt,name=message"` } // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object @@ -181,35 +181,35 @@ type ExperimentCondition struct { // ExperimentList is a list of Experiment resources type ExperimentList struct { metav1.TypeMeta `json:",inline"` - metav1.ListMeta `json:"metadata"` + metav1.ListMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` - Items []Experiment `json:"items"` + Items []Experiment `json:"items" protobuf:"bytes,2,rep,name=items"` } type ExperimentAnalysisTemplateRef struct { // Name is the name of the analysis - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // TemplateName reference of the AnalysisTemplate name used by the Experiment to create the run - TemplateName string `json:"templateName"` + TemplateName string `json:"templateName" protobuf:"bytes,2,opt,name=templateName"` // Whether to look for the templateName at cluster scope or namespace scope // +optional - ClusterScope bool `json:"clusterScope,omitempty"` + ClusterScope bool `json:"clusterScope,omitempty" protobuf:"varint,3,opt,name=clusterScope"` // Args are the arguments that will be added to the AnalysisRuns // +optional // +patchMergeKey=name // +patchStrategy=merge - Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Args []Argument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,4,rep,name=args"` // RequiredForCompletion blocks the Experiment from completing until the analysis has completed - RequiredForCompletion bool `json:"requiredForCompletion,omitempty"` + RequiredForCompletion bool `json:"requiredForCompletion,omitempty" protobuf:"varint,5,opt,name=requiredForCompletion"` } type ExperimentAnalysisRunStatus struct { // Name is the name of the analysis - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // AnalysisRun is the name of the AnalysisRun - AnalysisRun string `json:"analysisRun"` + AnalysisRun string `json:"analysisRun" protobuf:"bytes,2,opt,name=analysisRun"` // Phase is the status of the AnalysisRun - Phase AnalysisPhase `json:"phase"` + Phase AnalysisPhase `json:"phase" protobuf:"bytes,3,opt,name=phase,casttype=AnalysisPhase"` // Message is a message explaining the current status - Message string `json:"message,omitempty"` + Message string `json:"message,omitempty" protobuf:"bytes,4,opt,name=message"` } diff --git a/pkg/apis/rollouts/v1alpha1/generated.pb.go b/pkg/apis/rollouts/v1alpha1/generated.pb.go new file mode 100644 index 0000000000..dbffc5c501 --- /dev/null +++ b/pkg/apis/rollouts/v1alpha1/generated.pb.go @@ -0,0 +1,21869 @@ +/* +Copyright 2021 The Kubernetes sample-controller 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. +*/ + +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1/generated.proto + +package v1alpha1 + +import ( + fmt "fmt" + + io "io" + + proto "github.com/gogo/protobuf/proto" + github_com_gogo_protobuf_sortkeys "github.com/gogo/protobuf/sortkeys" + k8s_io_api_core_v1 "k8s.io/api/core/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + + math "math" + math_bits "math/bits" + reflect "reflect" + strings "strings" + + intstr "k8s.io/apimachinery/pkg/util/intstr" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +func (m *ALBTrafficRouting) Reset() { *m = ALBTrafficRouting{} } +func (*ALBTrafficRouting) ProtoMessage() {} +func (*ALBTrafficRouting) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{0} +} +func (m *ALBTrafficRouting) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ALBTrafficRouting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ALBTrafficRouting) XXX_Merge(src proto.Message) { + xxx_messageInfo_ALBTrafficRouting.Merge(m, src) +} +func (m *ALBTrafficRouting) XXX_Size() int { + return m.Size() +} +func (m *ALBTrafficRouting) XXX_DiscardUnknown() { + xxx_messageInfo_ALBTrafficRouting.DiscardUnknown(m) +} + +var xxx_messageInfo_ALBTrafficRouting proto.InternalMessageInfo + +func (m *AnalysisRun) Reset() { *m = AnalysisRun{} } +func (*AnalysisRun) ProtoMessage() {} +func (*AnalysisRun) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{1} +} +func (m *AnalysisRun) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRun) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisRun) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRun.Merge(m, src) +} +func (m *AnalysisRun) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRun) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRun.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRun proto.InternalMessageInfo + +func (m *AnalysisRunArgument) Reset() { *m = AnalysisRunArgument{} } +func (*AnalysisRunArgument) ProtoMessage() {} +func (*AnalysisRunArgument) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{2} +} +func (m *AnalysisRunArgument) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRunArgument) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisRunArgument) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRunArgument.Merge(m, src) +} +func (m *AnalysisRunArgument) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRunArgument) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRunArgument.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRunArgument proto.InternalMessageInfo + +func (m *AnalysisRunList) Reset() { *m = AnalysisRunList{} } +func (*AnalysisRunList) ProtoMessage() {} +func (*AnalysisRunList) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{3} +} +func (m *AnalysisRunList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRunList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisRunList) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRunList.Merge(m, src) +} +func (m *AnalysisRunList) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRunList) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRunList.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRunList proto.InternalMessageInfo + +func (m *AnalysisRunSpec) Reset() { *m = AnalysisRunSpec{} } +func (*AnalysisRunSpec) ProtoMessage() {} +func (*AnalysisRunSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{4} +} +func (m *AnalysisRunSpec) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRunSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisRunSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRunSpec.Merge(m, src) +} +func (m *AnalysisRunSpec) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRunSpec) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRunSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRunSpec proto.InternalMessageInfo + +func (m *AnalysisRunStatus) Reset() { *m = AnalysisRunStatus{} } +func (*AnalysisRunStatus) ProtoMessage() {} +func (*AnalysisRunStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{5} +} +func (m *AnalysisRunStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisRunStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisRunStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisRunStatus.Merge(m, src) +} +func (m *AnalysisRunStatus) XXX_Size() int { + return m.Size() +} +func (m *AnalysisRunStatus) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisRunStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisRunStatus proto.InternalMessageInfo + +func (m *AnalysisTemplate) Reset() { *m = AnalysisTemplate{} } +func (*AnalysisTemplate) ProtoMessage() {} +func (*AnalysisTemplate) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{6} +} +func (m *AnalysisTemplate) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisTemplate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisTemplate) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisTemplate.Merge(m, src) +} +func (m *AnalysisTemplate) XXX_Size() int { + return m.Size() +} +func (m *AnalysisTemplate) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisTemplate.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisTemplate proto.InternalMessageInfo + +func (m *AnalysisTemplateList) Reset() { *m = AnalysisTemplateList{} } +func (*AnalysisTemplateList) ProtoMessage() {} +func (*AnalysisTemplateList) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{7} +} +func (m *AnalysisTemplateList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisTemplateList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisTemplateList) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisTemplateList.Merge(m, src) +} +func (m *AnalysisTemplateList) XXX_Size() int { + return m.Size() +} +func (m *AnalysisTemplateList) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisTemplateList.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisTemplateList proto.InternalMessageInfo + +func (m *AnalysisTemplateSpec) Reset() { *m = AnalysisTemplateSpec{} } +func (*AnalysisTemplateSpec) ProtoMessage() {} +func (*AnalysisTemplateSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{8} +} +func (m *AnalysisTemplateSpec) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AnalysisTemplateSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AnalysisTemplateSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_AnalysisTemplateSpec.Merge(m, src) +} +func (m *AnalysisTemplateSpec) XXX_Size() int { + return m.Size() +} +func (m *AnalysisTemplateSpec) XXX_DiscardUnknown() { + xxx_messageInfo_AnalysisTemplateSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_AnalysisTemplateSpec proto.InternalMessageInfo + +func (m *AntiAffinity) Reset() { *m = AntiAffinity{} } +func (*AntiAffinity) ProtoMessage() {} +func (*AntiAffinity) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{9} +} +func (m *AntiAffinity) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *AntiAffinity) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *AntiAffinity) XXX_Merge(src proto.Message) { + xxx_messageInfo_AntiAffinity.Merge(m, src) +} +func (m *AntiAffinity) XXX_Size() int { + return m.Size() +} +func (m *AntiAffinity) XXX_DiscardUnknown() { + xxx_messageInfo_AntiAffinity.DiscardUnknown(m) +} + +var xxx_messageInfo_AntiAffinity proto.InternalMessageInfo + +func (m *Argument) Reset() { *m = Argument{} } +func (*Argument) ProtoMessage() {} +func (*Argument) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{10} +} +func (m *Argument) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Argument) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *Argument) XXX_Merge(src proto.Message) { + xxx_messageInfo_Argument.Merge(m, src) +} +func (m *Argument) XXX_Size() int { + return m.Size() +} +func (m *Argument) XXX_DiscardUnknown() { + xxx_messageInfo_Argument.DiscardUnknown(m) +} + +var xxx_messageInfo_Argument proto.InternalMessageInfo + +func (m *ArgumentValueFrom) Reset() { *m = ArgumentValueFrom{} } +func (*ArgumentValueFrom) ProtoMessage() {} +func (*ArgumentValueFrom) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{11} +} +func (m *ArgumentValueFrom) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ArgumentValueFrom) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ArgumentValueFrom) XXX_Merge(src proto.Message) { + xxx_messageInfo_ArgumentValueFrom.Merge(m, src) +} +func (m *ArgumentValueFrom) XXX_Size() int { + return m.Size() +} +func (m *ArgumentValueFrom) XXX_DiscardUnknown() { + xxx_messageInfo_ArgumentValueFrom.DiscardUnknown(m) +} + +var xxx_messageInfo_ArgumentValueFrom proto.InternalMessageInfo + +func (m *BlueGreenStatus) Reset() { *m = BlueGreenStatus{} } +func (*BlueGreenStatus) ProtoMessage() {} +func (*BlueGreenStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{12} +} +func (m *BlueGreenStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *BlueGreenStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *BlueGreenStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_BlueGreenStatus.Merge(m, src) +} +func (m *BlueGreenStatus) XXX_Size() int { + return m.Size() +} +func (m *BlueGreenStatus) XXX_DiscardUnknown() { + xxx_messageInfo_BlueGreenStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_BlueGreenStatus proto.InternalMessageInfo + +func (m *BlueGreenStrategy) Reset() { *m = BlueGreenStrategy{} } +func (*BlueGreenStrategy) ProtoMessage() {} +func (*BlueGreenStrategy) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{13} +} +func (m *BlueGreenStrategy) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *BlueGreenStrategy) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *BlueGreenStrategy) XXX_Merge(src proto.Message) { + xxx_messageInfo_BlueGreenStrategy.Merge(m, src) +} +func (m *BlueGreenStrategy) XXX_Size() int { + return m.Size() +} +func (m *BlueGreenStrategy) XXX_DiscardUnknown() { + xxx_messageInfo_BlueGreenStrategy.DiscardUnknown(m) +} + +var xxx_messageInfo_BlueGreenStrategy proto.InternalMessageInfo + +func (m *CanaryStatus) Reset() { *m = CanaryStatus{} } +func (*CanaryStatus) ProtoMessage() {} +func (*CanaryStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{14} +} +func (m *CanaryStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *CanaryStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *CanaryStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_CanaryStatus.Merge(m, src) +} +func (m *CanaryStatus) XXX_Size() int { + return m.Size() +} +func (m *CanaryStatus) XXX_DiscardUnknown() { + xxx_messageInfo_CanaryStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_CanaryStatus proto.InternalMessageInfo + +func (m *CanaryStep) Reset() { *m = CanaryStep{} } +func (*CanaryStep) ProtoMessage() {} +func (*CanaryStep) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{15} +} +func (m *CanaryStep) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *CanaryStep) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *CanaryStep) XXX_Merge(src proto.Message) { + xxx_messageInfo_CanaryStep.Merge(m, src) +} +func (m *CanaryStep) XXX_Size() int { + return m.Size() +} +func (m *CanaryStep) XXX_DiscardUnknown() { + xxx_messageInfo_CanaryStep.DiscardUnknown(m) +} + +var xxx_messageInfo_CanaryStep proto.InternalMessageInfo + +func (m *CanaryStrategy) Reset() { *m = CanaryStrategy{} } +func (*CanaryStrategy) ProtoMessage() {} +func (*CanaryStrategy) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{16} +} +func (m *CanaryStrategy) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *CanaryStrategy) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *CanaryStrategy) XXX_Merge(src proto.Message) { + xxx_messageInfo_CanaryStrategy.Merge(m, src) +} +func (m *CanaryStrategy) XXX_Size() int { + return m.Size() +} +func (m *CanaryStrategy) XXX_DiscardUnknown() { + xxx_messageInfo_CanaryStrategy.DiscardUnknown(m) +} + +var xxx_messageInfo_CanaryStrategy proto.InternalMessageInfo + +func (m *ClusterAnalysisTemplate) Reset() { *m = ClusterAnalysisTemplate{} } +func (*ClusterAnalysisTemplate) ProtoMessage() {} +func (*ClusterAnalysisTemplate) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{17} +} +func (m *ClusterAnalysisTemplate) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ClusterAnalysisTemplate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ClusterAnalysisTemplate) XXX_Merge(src proto.Message) { + xxx_messageInfo_ClusterAnalysisTemplate.Merge(m, src) +} +func (m *ClusterAnalysisTemplate) XXX_Size() int { + return m.Size() +} +func (m *ClusterAnalysisTemplate) XXX_DiscardUnknown() { + xxx_messageInfo_ClusterAnalysisTemplate.DiscardUnknown(m) +} + +var xxx_messageInfo_ClusterAnalysisTemplate proto.InternalMessageInfo + +func (m *ClusterAnalysisTemplateList) Reset() { *m = ClusterAnalysisTemplateList{} } +func (*ClusterAnalysisTemplateList) ProtoMessage() {} +func (*ClusterAnalysisTemplateList) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{18} +} +func (m *ClusterAnalysisTemplateList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ClusterAnalysisTemplateList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ClusterAnalysisTemplateList) XXX_Merge(src proto.Message) { + xxx_messageInfo_ClusterAnalysisTemplateList.Merge(m, src) +} +func (m *ClusterAnalysisTemplateList) XXX_Size() int { + return m.Size() +} +func (m *ClusterAnalysisTemplateList) XXX_DiscardUnknown() { + xxx_messageInfo_ClusterAnalysisTemplateList.DiscardUnknown(m) +} + +var xxx_messageInfo_ClusterAnalysisTemplateList proto.InternalMessageInfo + +func (m *DatadogMetric) Reset() { *m = DatadogMetric{} } +func (*DatadogMetric) ProtoMessage() {} +func (*DatadogMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{19} +} +func (m *DatadogMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *DatadogMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *DatadogMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_DatadogMetric.Merge(m, src) +} +func (m *DatadogMetric) XXX_Size() int { + return m.Size() +} +func (m *DatadogMetric) XXX_DiscardUnknown() { + xxx_messageInfo_DatadogMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_DatadogMetric proto.InternalMessageInfo + +func (m *Experiment) Reset() { *m = Experiment{} } +func (*Experiment) ProtoMessage() {} +func (*Experiment) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{20} +} +func (m *Experiment) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Experiment) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *Experiment) XXX_Merge(src proto.Message) { + xxx_messageInfo_Experiment.Merge(m, src) +} +func (m *Experiment) XXX_Size() int { + return m.Size() +} +func (m *Experiment) XXX_DiscardUnknown() { + xxx_messageInfo_Experiment.DiscardUnknown(m) +} + +var xxx_messageInfo_Experiment proto.InternalMessageInfo + +func (m *ExperimentAnalysisRunStatus) Reset() { *m = ExperimentAnalysisRunStatus{} } +func (*ExperimentAnalysisRunStatus) ProtoMessage() {} +func (*ExperimentAnalysisRunStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{21} +} +func (m *ExperimentAnalysisRunStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentAnalysisRunStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentAnalysisRunStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentAnalysisRunStatus.Merge(m, src) +} +func (m *ExperimentAnalysisRunStatus) XXX_Size() int { + return m.Size() +} +func (m *ExperimentAnalysisRunStatus) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentAnalysisRunStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentAnalysisRunStatus proto.InternalMessageInfo + +func (m *ExperimentAnalysisTemplateRef) Reset() { *m = ExperimentAnalysisTemplateRef{} } +func (*ExperimentAnalysisTemplateRef) ProtoMessage() {} +func (*ExperimentAnalysisTemplateRef) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{22} +} +func (m *ExperimentAnalysisTemplateRef) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentAnalysisTemplateRef) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentAnalysisTemplateRef) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentAnalysisTemplateRef.Merge(m, src) +} +func (m *ExperimentAnalysisTemplateRef) XXX_Size() int { + return m.Size() +} +func (m *ExperimentAnalysisTemplateRef) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentAnalysisTemplateRef.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentAnalysisTemplateRef proto.InternalMessageInfo + +func (m *ExperimentCondition) Reset() { *m = ExperimentCondition{} } +func (*ExperimentCondition) ProtoMessage() {} +func (*ExperimentCondition) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{23} +} +func (m *ExperimentCondition) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentCondition) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentCondition) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentCondition.Merge(m, src) +} +func (m *ExperimentCondition) XXX_Size() int { + return m.Size() +} +func (m *ExperimentCondition) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentCondition.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentCondition proto.InternalMessageInfo + +func (m *ExperimentList) Reset() { *m = ExperimentList{} } +func (*ExperimentList) ProtoMessage() {} +func (*ExperimentList) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{24} +} +func (m *ExperimentList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentList) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentList.Merge(m, src) +} +func (m *ExperimentList) XXX_Size() int { + return m.Size() +} +func (m *ExperimentList) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentList.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentList proto.InternalMessageInfo + +func (m *ExperimentSpec) Reset() { *m = ExperimentSpec{} } +func (*ExperimentSpec) ProtoMessage() {} +func (*ExperimentSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{25} +} +func (m *ExperimentSpec) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentSpec.Merge(m, src) +} +func (m *ExperimentSpec) XXX_Size() int { + return m.Size() +} +func (m *ExperimentSpec) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentSpec proto.InternalMessageInfo + +func (m *ExperimentStatus) Reset() { *m = ExperimentStatus{} } +func (*ExperimentStatus) ProtoMessage() {} +func (*ExperimentStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{26} +} +func (m *ExperimentStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ExperimentStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ExperimentStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_ExperimentStatus.Merge(m, src) +} +func (m *ExperimentStatus) XXX_Size() int { + return m.Size() +} +func (m *ExperimentStatus) XXX_DiscardUnknown() { + xxx_messageInfo_ExperimentStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_ExperimentStatus proto.InternalMessageInfo + +func (m *FieldRef) Reset() { *m = FieldRef{} } +func (*FieldRef) ProtoMessage() {} +func (*FieldRef) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{27} +} +func (m *FieldRef) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *FieldRef) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *FieldRef) XXX_Merge(src proto.Message) { + xxx_messageInfo_FieldRef.Merge(m, src) +} +func (m *FieldRef) XXX_Size() int { + return m.Size() +} +func (m *FieldRef) XXX_DiscardUnknown() { + xxx_messageInfo_FieldRef.DiscardUnknown(m) +} + +var xxx_messageInfo_FieldRef proto.InternalMessageInfo + +func (m *IstioDestinationRule) Reset() { *m = IstioDestinationRule{} } +func (*IstioDestinationRule) ProtoMessage() {} +func (*IstioDestinationRule) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{28} +} +func (m *IstioDestinationRule) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *IstioDestinationRule) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *IstioDestinationRule) XXX_Merge(src proto.Message) { + xxx_messageInfo_IstioDestinationRule.Merge(m, src) +} +func (m *IstioDestinationRule) XXX_Size() int { + return m.Size() +} +func (m *IstioDestinationRule) XXX_DiscardUnknown() { + xxx_messageInfo_IstioDestinationRule.DiscardUnknown(m) +} + +var xxx_messageInfo_IstioDestinationRule proto.InternalMessageInfo + +func (m *IstioTrafficRouting) Reset() { *m = IstioTrafficRouting{} } +func (*IstioTrafficRouting) ProtoMessage() {} +func (*IstioTrafficRouting) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{29} +} +func (m *IstioTrafficRouting) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *IstioTrafficRouting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *IstioTrafficRouting) XXX_Merge(src proto.Message) { + xxx_messageInfo_IstioTrafficRouting.Merge(m, src) +} +func (m *IstioTrafficRouting) XXX_Size() int { + return m.Size() +} +func (m *IstioTrafficRouting) XXX_DiscardUnknown() { + xxx_messageInfo_IstioTrafficRouting.DiscardUnknown(m) +} + +var xxx_messageInfo_IstioTrafficRouting proto.InternalMessageInfo + +func (m *IstioVirtualService) Reset() { *m = IstioVirtualService{} } +func (*IstioVirtualService) ProtoMessage() {} +func (*IstioVirtualService) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{30} +} +func (m *IstioVirtualService) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *IstioVirtualService) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *IstioVirtualService) XXX_Merge(src proto.Message) { + xxx_messageInfo_IstioVirtualService.Merge(m, src) +} +func (m *IstioVirtualService) XXX_Size() int { + return m.Size() +} +func (m *IstioVirtualService) XXX_DiscardUnknown() { + xxx_messageInfo_IstioVirtualService.DiscardUnknown(m) +} + +var xxx_messageInfo_IstioVirtualService proto.InternalMessageInfo + +func (m *JobMetric) Reset() { *m = JobMetric{} } +func (*JobMetric) ProtoMessage() {} +func (*JobMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{31} +} +func (m *JobMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *JobMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *JobMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_JobMetric.Merge(m, src) +} +func (m *JobMetric) XXX_Size() int { + return m.Size() +} +func (m *JobMetric) XXX_DiscardUnknown() { + xxx_messageInfo_JobMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_JobMetric proto.InternalMessageInfo + +func (m *KayentaMetric) Reset() { *m = KayentaMetric{} } +func (*KayentaMetric) ProtoMessage() {} +func (*KayentaMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{32} +} +func (m *KayentaMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *KayentaMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *KayentaMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_KayentaMetric.Merge(m, src) +} +func (m *KayentaMetric) XXX_Size() int { + return m.Size() +} +func (m *KayentaMetric) XXX_DiscardUnknown() { + xxx_messageInfo_KayentaMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_KayentaMetric proto.InternalMessageInfo + +func (m *KayentaScope) Reset() { *m = KayentaScope{} } +func (*KayentaScope) ProtoMessage() {} +func (*KayentaScope) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{33} +} +func (m *KayentaScope) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *KayentaScope) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *KayentaScope) XXX_Merge(src proto.Message) { + xxx_messageInfo_KayentaScope.Merge(m, src) +} +func (m *KayentaScope) XXX_Size() int { + return m.Size() +} +func (m *KayentaScope) XXX_DiscardUnknown() { + xxx_messageInfo_KayentaScope.DiscardUnknown(m) +} + +var xxx_messageInfo_KayentaScope proto.InternalMessageInfo + +func (m *KayentaThreshold) Reset() { *m = KayentaThreshold{} } +func (*KayentaThreshold) ProtoMessage() {} +func (*KayentaThreshold) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{34} +} +func (m *KayentaThreshold) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *KayentaThreshold) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *KayentaThreshold) XXX_Merge(src proto.Message) { + xxx_messageInfo_KayentaThreshold.Merge(m, src) +} +func (m *KayentaThreshold) XXX_Size() int { + return m.Size() +} +func (m *KayentaThreshold) XXX_DiscardUnknown() { + xxx_messageInfo_KayentaThreshold.DiscardUnknown(m) +} + +var xxx_messageInfo_KayentaThreshold proto.InternalMessageInfo + +func (m *Measurement) Reset() { *m = Measurement{} } +func (*Measurement) ProtoMessage() {} +func (*Measurement) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{35} +} +func (m *Measurement) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Measurement) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *Measurement) XXX_Merge(src proto.Message) { + xxx_messageInfo_Measurement.Merge(m, src) +} +func (m *Measurement) XXX_Size() int { + return m.Size() +} +func (m *Measurement) XXX_DiscardUnknown() { + xxx_messageInfo_Measurement.DiscardUnknown(m) +} + +var xxx_messageInfo_Measurement proto.InternalMessageInfo + +func (m *Metric) Reset() { *m = Metric{} } +func (*Metric) ProtoMessage() {} +func (*Metric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{36} +} +func (m *Metric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Metric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *Metric) XXX_Merge(src proto.Message) { + xxx_messageInfo_Metric.Merge(m, src) +} +func (m *Metric) XXX_Size() int { + return m.Size() +} +func (m *Metric) XXX_DiscardUnknown() { + xxx_messageInfo_Metric.DiscardUnknown(m) +} + +var xxx_messageInfo_Metric proto.InternalMessageInfo + +func (m *MetricProvider) Reset() { *m = MetricProvider{} } +func (*MetricProvider) ProtoMessage() {} +func (*MetricProvider) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{37} +} +func (m *MetricProvider) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MetricProvider) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *MetricProvider) XXX_Merge(src proto.Message) { + xxx_messageInfo_MetricProvider.Merge(m, src) +} +func (m *MetricProvider) XXX_Size() int { + return m.Size() +} +func (m *MetricProvider) XXX_DiscardUnknown() { + xxx_messageInfo_MetricProvider.DiscardUnknown(m) +} + +var xxx_messageInfo_MetricProvider proto.InternalMessageInfo + +func (m *MetricResult) Reset() { *m = MetricResult{} } +func (*MetricResult) ProtoMessage() {} +func (*MetricResult) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{38} +} +func (m *MetricResult) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MetricResult) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *MetricResult) XXX_Merge(src proto.Message) { + xxx_messageInfo_MetricResult.Merge(m, src) +} +func (m *MetricResult) XXX_Size() int { + return m.Size() +} +func (m *MetricResult) XXX_DiscardUnknown() { + xxx_messageInfo_MetricResult.DiscardUnknown(m) +} + +var xxx_messageInfo_MetricResult proto.InternalMessageInfo + +func (m *NewRelicMetric) Reset() { *m = NewRelicMetric{} } +func (*NewRelicMetric) ProtoMessage() {} +func (*NewRelicMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{39} +} +func (m *NewRelicMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *NewRelicMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *NewRelicMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_NewRelicMetric.Merge(m, src) +} +func (m *NewRelicMetric) XXX_Size() int { + return m.Size() +} +func (m *NewRelicMetric) XXX_DiscardUnknown() { + xxx_messageInfo_NewRelicMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_NewRelicMetric proto.InternalMessageInfo + +func (m *NginxTrafficRouting) Reset() { *m = NginxTrafficRouting{} } +func (*NginxTrafficRouting) ProtoMessage() {} +func (*NginxTrafficRouting) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{40} +} +func (m *NginxTrafficRouting) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *NginxTrafficRouting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *NginxTrafficRouting) XXX_Merge(src proto.Message) { + xxx_messageInfo_NginxTrafficRouting.Merge(m, src) +} +func (m *NginxTrafficRouting) XXX_Size() int { + return m.Size() +} +func (m *NginxTrafficRouting) XXX_DiscardUnknown() { + xxx_messageInfo_NginxTrafficRouting.DiscardUnknown(m) +} + +var xxx_messageInfo_NginxTrafficRouting proto.InternalMessageInfo + +func (m *PauseCondition) Reset() { *m = PauseCondition{} } +func (*PauseCondition) ProtoMessage() {} +func (*PauseCondition) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{41} +} +func (m *PauseCondition) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PauseCondition) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *PauseCondition) XXX_Merge(src proto.Message) { + xxx_messageInfo_PauseCondition.Merge(m, src) +} +func (m *PauseCondition) XXX_Size() int { + return m.Size() +} +func (m *PauseCondition) XXX_DiscardUnknown() { + xxx_messageInfo_PauseCondition.DiscardUnknown(m) +} + +var xxx_messageInfo_PauseCondition proto.InternalMessageInfo + +func (m *PodTemplateMetadata) Reset() { *m = PodTemplateMetadata{} } +func (*PodTemplateMetadata) ProtoMessage() {} +func (*PodTemplateMetadata) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{42} +} +func (m *PodTemplateMetadata) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PodTemplateMetadata) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *PodTemplateMetadata) XXX_Merge(src proto.Message) { + xxx_messageInfo_PodTemplateMetadata.Merge(m, src) +} +func (m *PodTemplateMetadata) XXX_Size() int { + return m.Size() +} +func (m *PodTemplateMetadata) XXX_DiscardUnknown() { + xxx_messageInfo_PodTemplateMetadata.DiscardUnknown(m) +} + +var xxx_messageInfo_PodTemplateMetadata proto.InternalMessageInfo + +func (m *PreferredDuringSchedulingIgnoredDuringExecution) Reset() { + *m = PreferredDuringSchedulingIgnoredDuringExecution{} +} +func (*PreferredDuringSchedulingIgnoredDuringExecution) ProtoMessage() {} +func (*PreferredDuringSchedulingIgnoredDuringExecution) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{43} +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) XXX_Merge(src proto.Message) { + xxx_messageInfo_PreferredDuringSchedulingIgnoredDuringExecution.Merge(m, src) +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) XXX_Size() int { + return m.Size() +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) XXX_DiscardUnknown() { + xxx_messageInfo_PreferredDuringSchedulingIgnoredDuringExecution.DiscardUnknown(m) +} + +var xxx_messageInfo_PreferredDuringSchedulingIgnoredDuringExecution proto.InternalMessageInfo + +func (m *PrometheusMetric) Reset() { *m = PrometheusMetric{} } +func (*PrometheusMetric) ProtoMessage() {} +func (*PrometheusMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{44} +} +func (m *PrometheusMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PrometheusMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *PrometheusMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_PrometheusMetric.Merge(m, src) +} +func (m *PrometheusMetric) XXX_Size() int { + return m.Size() +} +func (m *PrometheusMetric) XXX_DiscardUnknown() { + xxx_messageInfo_PrometheusMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_PrometheusMetric proto.InternalMessageInfo + +func (m *RequiredDuringSchedulingIgnoredDuringExecution) Reset() { + *m = RequiredDuringSchedulingIgnoredDuringExecution{} +} +func (*RequiredDuringSchedulingIgnoredDuringExecution) ProtoMessage() {} +func (*RequiredDuringSchedulingIgnoredDuringExecution) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{45} +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) XXX_Merge(src proto.Message) { + xxx_messageInfo_RequiredDuringSchedulingIgnoredDuringExecution.Merge(m, src) +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) XXX_Size() int { + return m.Size() +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) XXX_DiscardUnknown() { + xxx_messageInfo_RequiredDuringSchedulingIgnoredDuringExecution.DiscardUnknown(m) +} + +var xxx_messageInfo_RequiredDuringSchedulingIgnoredDuringExecution proto.InternalMessageInfo + +func (m *Rollout) Reset() { *m = Rollout{} } +func (*Rollout) ProtoMessage() {} +func (*Rollout) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{46} +} +func (m *Rollout) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Rollout) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *Rollout) XXX_Merge(src proto.Message) { + xxx_messageInfo_Rollout.Merge(m, src) +} +func (m *Rollout) XXX_Size() int { + return m.Size() +} +func (m *Rollout) XXX_DiscardUnknown() { + xxx_messageInfo_Rollout.DiscardUnknown(m) +} + +var xxx_messageInfo_Rollout proto.InternalMessageInfo + +func (m *RolloutAnalysis) Reset() { *m = RolloutAnalysis{} } +func (*RolloutAnalysis) ProtoMessage() {} +func (*RolloutAnalysis) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{47} +} +func (m *RolloutAnalysis) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutAnalysis) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutAnalysis) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutAnalysis.Merge(m, src) +} +func (m *RolloutAnalysis) XXX_Size() int { + return m.Size() +} +func (m *RolloutAnalysis) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutAnalysis.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutAnalysis proto.InternalMessageInfo + +func (m *RolloutAnalysisBackground) Reset() { *m = RolloutAnalysisBackground{} } +func (*RolloutAnalysisBackground) ProtoMessage() {} +func (*RolloutAnalysisBackground) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{48} +} +func (m *RolloutAnalysisBackground) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutAnalysisBackground) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutAnalysisBackground) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutAnalysisBackground.Merge(m, src) +} +func (m *RolloutAnalysisBackground) XXX_Size() int { + return m.Size() +} +func (m *RolloutAnalysisBackground) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutAnalysisBackground.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutAnalysisBackground proto.InternalMessageInfo + +func (m *RolloutAnalysisRunStatus) Reset() { *m = RolloutAnalysisRunStatus{} } +func (*RolloutAnalysisRunStatus) ProtoMessage() {} +func (*RolloutAnalysisRunStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{49} +} +func (m *RolloutAnalysisRunStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutAnalysisRunStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutAnalysisRunStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutAnalysisRunStatus.Merge(m, src) +} +func (m *RolloutAnalysisRunStatus) XXX_Size() int { + return m.Size() +} +func (m *RolloutAnalysisRunStatus) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutAnalysisRunStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutAnalysisRunStatus proto.InternalMessageInfo + +func (m *RolloutAnalysisTemplate) Reset() { *m = RolloutAnalysisTemplate{} } +func (*RolloutAnalysisTemplate) ProtoMessage() {} +func (*RolloutAnalysisTemplate) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{50} +} +func (m *RolloutAnalysisTemplate) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutAnalysisTemplate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutAnalysisTemplate) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutAnalysisTemplate.Merge(m, src) +} +func (m *RolloutAnalysisTemplate) XXX_Size() int { + return m.Size() +} +func (m *RolloutAnalysisTemplate) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutAnalysisTemplate.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutAnalysisTemplate proto.InternalMessageInfo + +func (m *RolloutCondition) Reset() { *m = RolloutCondition{} } +func (*RolloutCondition) ProtoMessage() {} +func (*RolloutCondition) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{51} +} +func (m *RolloutCondition) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutCondition) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutCondition) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutCondition.Merge(m, src) +} +func (m *RolloutCondition) XXX_Size() int { + return m.Size() +} +func (m *RolloutCondition) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutCondition.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutCondition proto.InternalMessageInfo + +func (m *RolloutExperimentStep) Reset() { *m = RolloutExperimentStep{} } +func (*RolloutExperimentStep) ProtoMessage() {} +func (*RolloutExperimentStep) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{52} +} +func (m *RolloutExperimentStep) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutExperimentStep) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutExperimentStep) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutExperimentStep.Merge(m, src) +} +func (m *RolloutExperimentStep) XXX_Size() int { + return m.Size() +} +func (m *RolloutExperimentStep) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutExperimentStep.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutExperimentStep proto.InternalMessageInfo + +func (m *RolloutExperimentStepAnalysisTemplateRef) Reset() { + *m = RolloutExperimentStepAnalysisTemplateRef{} +} +func (*RolloutExperimentStepAnalysisTemplateRef) ProtoMessage() {} +func (*RolloutExperimentStepAnalysisTemplateRef) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{53} +} +func (m *RolloutExperimentStepAnalysisTemplateRef) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutExperimentStepAnalysisTemplateRef) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutExperimentStepAnalysisTemplateRef) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutExperimentStepAnalysisTemplateRef.Merge(m, src) +} +func (m *RolloutExperimentStepAnalysisTemplateRef) XXX_Size() int { + return m.Size() +} +func (m *RolloutExperimentStepAnalysisTemplateRef) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutExperimentStepAnalysisTemplateRef.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutExperimentStepAnalysisTemplateRef proto.InternalMessageInfo + +func (m *RolloutExperimentTemplate) Reset() { *m = RolloutExperimentTemplate{} } +func (*RolloutExperimentTemplate) ProtoMessage() {} +func (*RolloutExperimentTemplate) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{54} +} +func (m *RolloutExperimentTemplate) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutExperimentTemplate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutExperimentTemplate) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutExperimentTemplate.Merge(m, src) +} +func (m *RolloutExperimentTemplate) XXX_Size() int { + return m.Size() +} +func (m *RolloutExperimentTemplate) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutExperimentTemplate.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutExperimentTemplate proto.InternalMessageInfo + +func (m *RolloutList) Reset() { *m = RolloutList{} } +func (*RolloutList) ProtoMessage() {} +func (*RolloutList) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{55} +} +func (m *RolloutList) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutList) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutList.Merge(m, src) +} +func (m *RolloutList) XXX_Size() int { + return m.Size() +} +func (m *RolloutList) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutList.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutList proto.InternalMessageInfo + +func (m *RolloutPause) Reset() { *m = RolloutPause{} } +func (*RolloutPause) ProtoMessage() {} +func (*RolloutPause) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{56} +} +func (m *RolloutPause) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutPause) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutPause) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutPause.Merge(m, src) +} +func (m *RolloutPause) XXX_Size() int { + return m.Size() +} +func (m *RolloutPause) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutPause.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutPause proto.InternalMessageInfo + +func (m *RolloutSpec) Reset() { *m = RolloutSpec{} } +func (*RolloutSpec) ProtoMessage() {} +func (*RolloutSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{57} +} +func (m *RolloutSpec) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutSpec.Merge(m, src) +} +func (m *RolloutSpec) XXX_Size() int { + return m.Size() +} +func (m *RolloutSpec) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutSpec proto.InternalMessageInfo + +func (m *RolloutStatus) Reset() { *m = RolloutStatus{} } +func (*RolloutStatus) ProtoMessage() {} +func (*RolloutStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{58} +} +func (m *RolloutStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutStatus.Merge(m, src) +} +func (m *RolloutStatus) XXX_Size() int { + return m.Size() +} +func (m *RolloutStatus) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutStatus proto.InternalMessageInfo + +func (m *RolloutStrategy) Reset() { *m = RolloutStrategy{} } +func (*RolloutStrategy) ProtoMessage() {} +func (*RolloutStrategy) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{59} +} +func (m *RolloutStrategy) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutStrategy) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutStrategy) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutStrategy.Merge(m, src) +} +func (m *RolloutStrategy) XXX_Size() int { + return m.Size() +} +func (m *RolloutStrategy) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutStrategy.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutStrategy proto.InternalMessageInfo + +func (m *RolloutTrafficRouting) Reset() { *m = RolloutTrafficRouting{} } +func (*RolloutTrafficRouting) ProtoMessage() {} +func (*RolloutTrafficRouting) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{60} +} +func (m *RolloutTrafficRouting) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *RolloutTrafficRouting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *RolloutTrafficRouting) XXX_Merge(src proto.Message) { + xxx_messageInfo_RolloutTrafficRouting.Merge(m, src) +} +func (m *RolloutTrafficRouting) XXX_Size() int { + return m.Size() +} +func (m *RolloutTrafficRouting) XXX_DiscardUnknown() { + xxx_messageInfo_RolloutTrafficRouting.DiscardUnknown(m) +} + +var xxx_messageInfo_RolloutTrafficRouting proto.InternalMessageInfo + +func (m *SMITrafficRouting) Reset() { *m = SMITrafficRouting{} } +func (*SMITrafficRouting) ProtoMessage() {} +func (*SMITrafficRouting) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{61} +} +func (m *SMITrafficRouting) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *SMITrafficRouting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *SMITrafficRouting) XXX_Merge(src proto.Message) { + xxx_messageInfo_SMITrafficRouting.Merge(m, src) +} +func (m *SMITrafficRouting) XXX_Size() int { + return m.Size() +} +func (m *SMITrafficRouting) XXX_DiscardUnknown() { + xxx_messageInfo_SMITrafficRouting.DiscardUnknown(m) +} + +var xxx_messageInfo_SMITrafficRouting proto.InternalMessageInfo + +func (m *ScopeDetail) Reset() { *m = ScopeDetail{} } +func (*ScopeDetail) ProtoMessage() {} +func (*ScopeDetail) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{62} +} +func (m *ScopeDetail) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ScopeDetail) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ScopeDetail) XXX_Merge(src proto.Message) { + xxx_messageInfo_ScopeDetail.Merge(m, src) +} +func (m *ScopeDetail) XXX_Size() int { + return m.Size() +} +func (m *ScopeDetail) XXX_DiscardUnknown() { + xxx_messageInfo_ScopeDetail.DiscardUnknown(m) +} + +var xxx_messageInfo_ScopeDetail proto.InternalMessageInfo + +func (m *SecretKeyRef) Reset() { *m = SecretKeyRef{} } +func (*SecretKeyRef) ProtoMessage() {} +func (*SecretKeyRef) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{63} +} +func (m *SecretKeyRef) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *SecretKeyRef) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *SecretKeyRef) XXX_Merge(src proto.Message) { + xxx_messageInfo_SecretKeyRef.Merge(m, src) +} +func (m *SecretKeyRef) XXX_Size() int { + return m.Size() +} +func (m *SecretKeyRef) XXX_DiscardUnknown() { + xxx_messageInfo_SecretKeyRef.DiscardUnknown(m) +} + +var xxx_messageInfo_SecretKeyRef proto.InternalMessageInfo + +func (m *SetCanaryScale) Reset() { *m = SetCanaryScale{} } +func (*SetCanaryScale) ProtoMessage() {} +func (*SetCanaryScale) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{64} +} +func (m *SetCanaryScale) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *SetCanaryScale) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *SetCanaryScale) XXX_Merge(src proto.Message) { + xxx_messageInfo_SetCanaryScale.Merge(m, src) +} +func (m *SetCanaryScale) XXX_Size() int { + return m.Size() +} +func (m *SetCanaryScale) XXX_DiscardUnknown() { + xxx_messageInfo_SetCanaryScale.DiscardUnknown(m) +} + +var xxx_messageInfo_SetCanaryScale proto.InternalMessageInfo + +func (m *TemplateSpec) Reset() { *m = TemplateSpec{} } +func (*TemplateSpec) ProtoMessage() {} +func (*TemplateSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{65} +} +func (m *TemplateSpec) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TemplateSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TemplateSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_TemplateSpec.Merge(m, src) +} +func (m *TemplateSpec) XXX_Size() int { + return m.Size() +} +func (m *TemplateSpec) XXX_DiscardUnknown() { + xxx_messageInfo_TemplateSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_TemplateSpec proto.InternalMessageInfo + +func (m *TemplateStatus) Reset() { *m = TemplateStatus{} } +func (*TemplateStatus) ProtoMessage() {} +func (*TemplateStatus) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{66} +} +func (m *TemplateStatus) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TemplateStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TemplateStatus) XXX_Merge(src proto.Message) { + xxx_messageInfo_TemplateStatus.Merge(m, src) +} +func (m *TemplateStatus) XXX_Size() int { + return m.Size() +} +func (m *TemplateStatus) XXX_DiscardUnknown() { + xxx_messageInfo_TemplateStatus.DiscardUnknown(m) +} + +var xxx_messageInfo_TemplateStatus proto.InternalMessageInfo + +func (m *ValueFrom) Reset() { *m = ValueFrom{} } +func (*ValueFrom) ProtoMessage() {} +func (*ValueFrom) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{67} +} +func (m *ValueFrom) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ValueFrom) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *ValueFrom) XXX_Merge(src proto.Message) { + xxx_messageInfo_ValueFrom.Merge(m, src) +} +func (m *ValueFrom) XXX_Size() int { + return m.Size() +} +func (m *ValueFrom) XXX_DiscardUnknown() { + xxx_messageInfo_ValueFrom.DiscardUnknown(m) +} + +var xxx_messageInfo_ValueFrom proto.InternalMessageInfo + +func (m *WavefrontMetric) Reset() { *m = WavefrontMetric{} } +func (*WavefrontMetric) ProtoMessage() {} +func (*WavefrontMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{68} +} +func (m *WavefrontMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *WavefrontMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *WavefrontMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_WavefrontMetric.Merge(m, src) +} +func (m *WavefrontMetric) XXX_Size() int { + return m.Size() +} +func (m *WavefrontMetric) XXX_DiscardUnknown() { + xxx_messageInfo_WavefrontMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_WavefrontMetric proto.InternalMessageInfo + +func (m *WebMetric) Reset() { *m = WebMetric{} } +func (*WebMetric) ProtoMessage() {} +func (*WebMetric) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{69} +} +func (m *WebMetric) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *WebMetric) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *WebMetric) XXX_Merge(src proto.Message) { + xxx_messageInfo_WebMetric.Merge(m, src) +} +func (m *WebMetric) XXX_Size() int { + return m.Size() +} +func (m *WebMetric) XXX_DiscardUnknown() { + xxx_messageInfo_WebMetric.DiscardUnknown(m) +} + +var xxx_messageInfo_WebMetric proto.InternalMessageInfo + +func (m *WebMetricHeader) Reset() { *m = WebMetricHeader{} } +func (*WebMetricHeader) ProtoMessage() {} +func (*WebMetricHeader) Descriptor() ([]byte, []int) { + return fileDescriptor_e0e705f843545fab, []int{70} +} +func (m *WebMetricHeader) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *WebMetricHeader) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *WebMetricHeader) XXX_Merge(src proto.Message) { + xxx_messageInfo_WebMetricHeader.Merge(m, src) +} +func (m *WebMetricHeader) XXX_Size() int { + return m.Size() +} +func (m *WebMetricHeader) XXX_DiscardUnknown() { + xxx_messageInfo_WebMetricHeader.DiscardUnknown(m) +} + +var xxx_messageInfo_WebMetricHeader proto.InternalMessageInfo + +func init() { + proto.RegisterType((*ALBTrafficRouting)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ALBTrafficRouting") + proto.RegisterType((*AnalysisRun)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRun") + proto.RegisterType((*AnalysisRunArgument)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunArgument") + proto.RegisterType((*AnalysisRunList)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunList") + proto.RegisterType((*AnalysisRunSpec)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunSpec") + proto.RegisterType((*AnalysisRunStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisRunStatus") + proto.RegisterType((*AnalysisTemplate)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisTemplate") + proto.RegisterType((*AnalysisTemplateList)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisTemplateList") + proto.RegisterType((*AnalysisTemplateSpec)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AnalysisTemplateSpec") + proto.RegisterType((*AntiAffinity)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.AntiAffinity") + proto.RegisterType((*Argument)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Argument") + proto.RegisterType((*ArgumentValueFrom)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ArgumentValueFrom") + proto.RegisterType((*BlueGreenStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStatus") + proto.RegisterType((*BlueGreenStrategy)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.BlueGreenStrategy") + proto.RegisterType((*CanaryStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStatus") + proto.RegisterType((*CanaryStep)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStep") + proto.RegisterType((*CanaryStrategy)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.CanaryStrategy") + proto.RegisterType((*ClusterAnalysisTemplate)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ClusterAnalysisTemplate") + proto.RegisterType((*ClusterAnalysisTemplateList)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ClusterAnalysisTemplateList") + proto.RegisterType((*DatadogMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.DatadogMetric") + proto.RegisterType((*Experiment)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Experiment") + proto.RegisterType((*ExperimentAnalysisRunStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentAnalysisRunStatus") + proto.RegisterType((*ExperimentAnalysisTemplateRef)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentAnalysisTemplateRef") + proto.RegisterType((*ExperimentCondition)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentCondition") + proto.RegisterType((*ExperimentList)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentList") + proto.RegisterType((*ExperimentSpec)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentSpec") + proto.RegisterType((*ExperimentStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ExperimentStatus") + proto.RegisterType((*FieldRef)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.FieldRef") + proto.RegisterType((*IstioDestinationRule)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioDestinationRule") + proto.RegisterType((*IstioTrafficRouting)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioTrafficRouting") + proto.RegisterType((*IstioVirtualService)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.IstioVirtualService") + proto.RegisterType((*JobMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.JobMetric") + proto.RegisterType((*KayentaMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.KayentaMetric") + proto.RegisterType((*KayentaScope)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.KayentaScope") + proto.RegisterType((*KayentaThreshold)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.KayentaThreshold") + proto.RegisterType((*Measurement)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Measurement") + proto.RegisterMapType((map[string]string)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Measurement.MetadataEntry") + proto.RegisterType((*Metric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Metric") + proto.RegisterType((*MetricProvider)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.MetricProvider") + proto.RegisterType((*MetricResult)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.MetricResult") + proto.RegisterType((*NewRelicMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.NewRelicMetric") + proto.RegisterType((*NginxTrafficRouting)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.NginxTrafficRouting") + proto.RegisterMapType((map[string]string)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.NginxTrafficRouting.AdditionalIngressAnnotationsEntry") + proto.RegisterType((*PauseCondition)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PauseCondition") + proto.RegisterType((*PodTemplateMetadata)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata") + proto.RegisterMapType((map[string]string)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata.AnnotationsEntry") + proto.RegisterMapType((map[string]string)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PodTemplateMetadata.LabelsEntry") + proto.RegisterType((*PreferredDuringSchedulingIgnoredDuringExecution)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PreferredDuringSchedulingIgnoredDuringExecution") + proto.RegisterType((*PrometheusMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.PrometheusMetric") + proto.RegisterType((*RequiredDuringSchedulingIgnoredDuringExecution)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RequiredDuringSchedulingIgnoredDuringExecution") + proto.RegisterType((*Rollout)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.Rollout") + proto.RegisterType((*RolloutAnalysis)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysis") + proto.RegisterType((*RolloutAnalysisBackground)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisBackground") + proto.RegisterType((*RolloutAnalysisRunStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisRunStatus") + proto.RegisterType((*RolloutAnalysisTemplate)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutAnalysisTemplate") + proto.RegisterType((*RolloutCondition)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutCondition") + proto.RegisterType((*RolloutExperimentStep)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStep") + proto.RegisterType((*RolloutExperimentStepAnalysisTemplateRef)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentStepAnalysisTemplateRef") + proto.RegisterType((*RolloutExperimentTemplate)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutExperimentTemplate") + proto.RegisterType((*RolloutList)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutList") + proto.RegisterType((*RolloutPause)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutPause") + proto.RegisterType((*RolloutSpec)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutSpec") + proto.RegisterType((*RolloutStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStatus") + proto.RegisterType((*RolloutStrategy)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutStrategy") + proto.RegisterType((*RolloutTrafficRouting)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.RolloutTrafficRouting") + proto.RegisterType((*SMITrafficRouting)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SMITrafficRouting") + proto.RegisterType((*ScopeDetail)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ScopeDetail") + proto.RegisterType((*SecretKeyRef)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SecretKeyRef") + proto.RegisterType((*SetCanaryScale)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.SetCanaryScale") + proto.RegisterType((*TemplateSpec)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.TemplateSpec") + proto.RegisterType((*TemplateStatus)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.TemplateStatus") + proto.RegisterType((*ValueFrom)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.ValueFrom") + proto.RegisterType((*WavefrontMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.WavefrontMetric") + proto.RegisterType((*WebMetric)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.WebMetric") + proto.RegisterType((*WebMetricHeader)(nil), "github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1.WebMetricHeader") +} + +func init() { + proto.RegisterFile("github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1/generated.proto", fileDescriptor_e0e705f843545fab) +} + +var fileDescriptor_e0e705f843545fab = []byte{ + // 5462 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x7d, 0x5d, 0x8c, 0x24, 0xd7, + 0x55, 0xb0, 0xab, 0x7b, 0x7a, 0xa6, 0xe7, 0xf4, 0xfc, 0xde, 0x9d, 0xcd, 0x76, 0xd6, 0xbb, 0xd3, + 0x9b, 0x72, 0xe4, 0xcf, 0xf9, 0x48, 0x7a, 0xe2, 0xb5, 0x0d, 0x26, 0x8e, 0x2c, 0xba, 0x67, 0x77, + 0xbd, 0x33, 0x9e, 0xd9, 0x9d, 0xbd, 0x3d, 0xeb, 0x55, 0xfc, 0x03, 0xa9, 0xe9, 0xbe, 0xd3, 0x53, + 0xbb, 0xd5, 0x55, 0x9d, 0xaa, 0xea, 0xd9, 0x1d, 0x27, 0x4a, 0xec, 0x44, 0x26, 0x06, 0x25, 0xb2, + 0xf9, 0x79, 0x41, 0x08, 0x84, 0x10, 0x0f, 0x08, 0x5e, 0x78, 0xc8, 0x0b, 0x12, 0x11, 0x51, 0x00, + 0xc9, 0x3c, 0x40, 0xc2, 0x0b, 0x0e, 0x48, 0x69, 0x70, 0x07, 0x09, 0xc1, 0x0b, 0x0a, 0x8a, 0x84, + 0xb2, 0xe2, 0x01, 0xdd, 0x9f, 0xba, 0x55, 0xb7, 0xaa, 0x66, 0xa6, 0x7b, 0xbb, 0x66, 0x89, 0x80, + 0xb7, 0xe9, 0x73, 0xce, 0x3d, 0xe7, 0xfe, 0x9c, 0x7b, 0xce, 0xb9, 0xf7, 0x9c, 0x5b, 0x03, 0x1b, + 0x6d, 0xd3, 0xdf, 0xeb, 0xed, 0x54, 0x9b, 0x4e, 0x67, 0xc5, 0x70, 0xdb, 0x4e, 0xd7, 0x75, 0x6e, + 0xb3, 0x3f, 0x3e, 0xe1, 0x3a, 0x96, 0xe5, 0xf4, 0x7c, 0x6f, 0xa5, 0x7b, 0xa7, 0xbd, 0x62, 0x74, + 0x4d, 0x6f, 0x45, 0x42, 0xf6, 0x9f, 0x34, 0xac, 0xee, 0x9e, 0xf1, 0xe4, 0x4a, 0x9b, 0xd8, 0xc4, + 0x35, 0x7c, 0xd2, 0xaa, 0x76, 0x5d, 0xc7, 0x77, 0xd0, 0xa7, 0x43, 0x6e, 0xd5, 0x80, 0x1b, 0xfb, + 0xe3, 0x17, 0x82, 0xb6, 0xd5, 0xee, 0x9d, 0x76, 0x95, 0x72, 0xab, 0x4a, 0x48, 0xc0, 0xed, 0xec, + 0x27, 0x22, 0x7d, 0x69, 0x3b, 0x6d, 0x67, 0x85, 0x31, 0xdd, 0xe9, 0xed, 0xb2, 0x5f, 0xec, 0x07, + 0xfb, 0x8b, 0x0b, 0x3b, 0xfb, 0xd8, 0x9d, 0x67, 0xbd, 0xaa, 0xe9, 0xd0, 0xbe, 0xad, 0xec, 0x18, + 0x7e, 0x73, 0x6f, 0x65, 0x3f, 0xd1, 0xa3, 0xb3, 0x7a, 0x84, 0xa8, 0xe9, 0xb8, 0x24, 0x8d, 0xe6, + 0xe9, 0x90, 0xa6, 0x63, 0x34, 0xf7, 0x4c, 0x9b, 0xb8, 0x07, 0xe1, 0xa8, 0x3b, 0xc4, 0x37, 0xd2, + 0x5a, 0xad, 0x1c, 0xd6, 0xca, 0xed, 0xd9, 0xbe, 0xd9, 0x21, 0x89, 0x06, 0x3f, 0x7d, 0x5c, 0x03, + 0xaf, 0xb9, 0x47, 0x3a, 0x46, 0xa2, 0xdd, 0x53, 0x87, 0xb5, 0xeb, 0xf9, 0xa6, 0xb5, 0x62, 0xda, + 0xbe, 0xe7, 0xbb, 0xf1, 0x46, 0xfa, 0xbf, 0x6b, 0xb0, 0x58, 0xdb, 0xa8, 0x6f, 0xbb, 0xc6, 0xee, + 0xae, 0xd9, 0xc4, 0x4e, 0xcf, 0x37, 0xed, 0x36, 0xfa, 0x18, 0x4c, 0x99, 0x76, 0xdb, 0x25, 0x9e, + 0x57, 0xd6, 0x2e, 0x68, 0x4f, 0x4c, 0xd7, 0xe7, 0xdf, 0xeb, 0x57, 0x1e, 0x19, 0xf4, 0x2b, 0x53, + 0x6b, 0x1c, 0x8c, 0x03, 0x3c, 0x7a, 0x06, 0x4a, 0x1e, 0x71, 0xf7, 0xcd, 0x26, 0xd9, 0x72, 0x5c, + 0xbf, 0x9c, 0xbb, 0xa0, 0x3d, 0x51, 0xa8, 0x9f, 0x12, 0xe4, 0xa5, 0x46, 0x88, 0xc2, 0x51, 0x3a, + 0xda, 0xcc, 0x75, 0x1c, 0x5f, 0xe0, 0xcb, 0x79, 0x26, 0x45, 0x36, 0xc3, 0x21, 0x0a, 0x47, 0xe9, + 0xd0, 0x25, 0x58, 0x30, 0x6c, 0xdb, 0xf1, 0x0d, 0xdf, 0x74, 0xec, 0x2d, 0x97, 0xec, 0x9a, 0xf7, + 0xca, 0x13, 0xac, 0x6d, 0x59, 0xb4, 0x5d, 0xa8, 0xc5, 0xf0, 0x38, 0xd1, 0x42, 0xff, 0xbb, 0x1c, + 0x94, 0x6a, 0xb6, 0x61, 0x1d, 0x78, 0xa6, 0x87, 0x7b, 0x36, 0xfa, 0x2c, 0x14, 0xe9, 0xea, 0xb5, + 0x0c, 0xdf, 0x60, 0xe3, 0x2d, 0x5d, 0xfc, 0x64, 0x95, 0x4f, 0x66, 0x35, 0x3a, 0x99, 0xa1, 0x4e, + 0x52, 0xea, 0xea, 0xfe, 0x93, 0xd5, 0xeb, 0x3b, 0xb7, 0x49, 0xd3, 0xdf, 0x24, 0xbe, 0x51, 0x47, + 0x42, 0x3e, 0x84, 0x30, 0x2c, 0xb9, 0x22, 0x07, 0x26, 0xbc, 0x2e, 0x69, 0xb2, 0xe9, 0x29, 0x5d, + 0xdc, 0xac, 0x8e, 0xa3, 0xff, 0xd5, 0x48, 0xd7, 0x1b, 0x5d, 0xd2, 0xac, 0xcf, 0x08, 0xd1, 0x13, + 0xf4, 0x17, 0x66, 0x82, 0xd0, 0x5d, 0x98, 0xf4, 0x7c, 0xc3, 0xef, 0x79, 0x6c, 0x6a, 0x4b, 0x17, + 0xaf, 0x67, 0x27, 0x92, 0xb1, 0xad, 0xcf, 0x09, 0xa1, 0x93, 0xfc, 0x37, 0x16, 0xe2, 0xf4, 0xbf, + 0xd7, 0xe0, 0x54, 0x84, 0xba, 0xe6, 0xb6, 0x7b, 0x1d, 0x62, 0xfb, 0xe8, 0x02, 0x4c, 0xd8, 0x46, + 0x87, 0x08, 0x7d, 0x92, 0x5d, 0xbe, 0x66, 0x74, 0x08, 0x66, 0x18, 0xf4, 0x18, 0x14, 0xf6, 0x0d, + 0xab, 0x47, 0xd8, 0x24, 0x4d, 0xd7, 0x67, 0x05, 0x49, 0xe1, 0x25, 0x0a, 0xc4, 0x1c, 0x87, 0xbe, + 0x00, 0xd3, 0xec, 0x8f, 0x2b, 0xae, 0xd3, 0xc9, 0x68, 0x68, 0xa2, 0x87, 0x2f, 0x05, 0x6c, 0xeb, + 0xb3, 0x83, 0x7e, 0x65, 0x5a, 0xfe, 0xc4, 0xa1, 0x40, 0xfd, 0x1f, 0x34, 0x98, 0x8f, 0x0c, 0x6e, + 0xc3, 0xf4, 0x7c, 0xf4, 0x6a, 0x42, 0x79, 0xaa, 0xc3, 0x29, 0x0f, 0x6d, 0xcd, 0x54, 0x67, 0x41, + 0x8c, 0xb4, 0x18, 0x40, 0x22, 0x8a, 0x63, 0x43, 0xc1, 0xf4, 0x49, 0xc7, 0x2b, 0xe7, 0x2e, 0xe4, + 0x9f, 0x28, 0x5d, 0x5c, 0xcb, 0x6c, 0x19, 0xc3, 0xf9, 0x5d, 0xa3, 0xfc, 0x31, 0x17, 0xa3, 0xff, + 0x56, 0x4e, 0x19, 0x21, 0xd5, 0x28, 0xe4, 0xc0, 0x54, 0x87, 0xf8, 0xae, 0xd9, 0xa4, 0xd6, 0x80, + 0xf6, 0xe2, 0xd2, 0x78, 0xbd, 0xd8, 0x64, 0xcc, 0x42, 0x9b, 0xc2, 0x7f, 0x7b, 0x38, 0x90, 0x82, + 0xf6, 0x60, 0xc2, 0x70, 0xdb, 0xc1, 0x98, 0xaf, 0x64, 0xb3, 0xbe, 0xa1, 0xce, 0xd5, 0xdc, 0xb6, + 0x87, 0x99, 0x04, 0xb4, 0x02, 0xd3, 0x3e, 0x71, 0x3b, 0xa6, 0x6d, 0xf8, 0xdc, 0x08, 0x15, 0xeb, + 0x8b, 0x82, 0x6c, 0x7a, 0x3b, 0x40, 0xe0, 0x90, 0x46, 0x7f, 0x3f, 0x07, 0x8b, 0x89, 0xcd, 0x80, + 0x9e, 0x86, 0x42, 0x77, 0xcf, 0xf0, 0x02, 0xed, 0x5e, 0x0e, 0xa6, 0x76, 0x8b, 0x02, 0xef, 0xf7, + 0x2b, 0xb3, 0x41, 0x13, 0x06, 0xc0, 0x9c, 0x98, 0x5a, 0xd9, 0x0e, 0xf1, 0x3c, 0xa3, 0x1d, 0xa8, + 0x7c, 0x64, 0x46, 0x18, 0x18, 0x07, 0x78, 0xf4, 0x55, 0x0d, 0x66, 0xf9, 0xec, 0x60, 0xe2, 0xf5, + 0x2c, 0x9f, 0x6e, 0x6b, 0x3a, 0x37, 0xeb, 0x59, 0xac, 0x04, 0x67, 0x59, 0x3f, 0x2d, 0xa4, 0xcf, + 0x46, 0xa1, 0x1e, 0x56, 0xe5, 0xa2, 0x5b, 0x30, 0xed, 0xf9, 0x86, 0xeb, 0x93, 0x56, 0xcd, 0x67, + 0xa6, 0xb7, 0x74, 0xf1, 0xff, 0x0f, 0xa7, 0xef, 0xdb, 0x66, 0x87, 0xf0, 0xbd, 0xd5, 0x08, 0x18, + 0xe0, 0x90, 0x97, 0xfe, 0xaf, 0x1a, 0x2c, 0x04, 0xd3, 0xb4, 0x4d, 0x3a, 0x5d, 0xcb, 0xf0, 0xc9, + 0x43, 0xb0, 0xcc, 0xbe, 0x62, 0x99, 0x71, 0x36, 0xfb, 0x2b, 0xe8, 0xff, 0x61, 0xe6, 0x59, 0xff, + 0x17, 0x0d, 0x96, 0xe2, 0xc4, 0x0f, 0xc1, 0x9a, 0x78, 0xaa, 0x35, 0xb9, 0x96, 0xed, 0x68, 0x0f, + 0x31, 0x29, 0x3f, 0x4c, 0x19, 0xeb, 0xff, 0x70, 0xbb, 0xa2, 0xff, 0xfe, 0x04, 0xcc, 0xd4, 0x6c, + 0xdf, 0xac, 0xed, 0xee, 0x9a, 0xb6, 0xe9, 0x1f, 0xa0, 0xaf, 0xe5, 0x60, 0xa5, 0xeb, 0x92, 0x5d, + 0xe2, 0xba, 0xa4, 0x75, 0xa9, 0xe7, 0x9a, 0x76, 0xbb, 0xd1, 0xdc, 0x23, 0xad, 0x9e, 0x65, 0xda, + 0xed, 0xb5, 0xb6, 0xed, 0x48, 0xf0, 0xe5, 0x7b, 0xa4, 0xd9, 0xa3, 0xc1, 0x8a, 0x58, 0xff, 0xce, + 0x78, 0xdd, 0xdc, 0x1a, 0x4d, 0x68, 0xfd, 0xa9, 0x41, 0xbf, 0xb2, 0x32, 0x62, 0x23, 0x3c, 0xea, + 0xd0, 0xd0, 0xdb, 0x39, 0xa8, 0xba, 0xe4, 0x73, 0x3d, 0x73, 0xf8, 0xd9, 0xe0, 0x1b, 0xd4, 0x1a, + 0x6f, 0x36, 0xf0, 0x48, 0x32, 0xeb, 0x17, 0x07, 0xfd, 0xca, 0x88, 0x6d, 0xf0, 0x88, 0xe3, 0xd2, + 0xff, 0x4c, 0x83, 0xe2, 0x08, 0x51, 0x52, 0x45, 0x8d, 0x92, 0xa6, 0x13, 0x11, 0x92, 0x9f, 0x8c, + 0x90, 0x5e, 0x18, 0x6f, 0xd2, 0x86, 0x89, 0x8c, 0xfe, 0x8d, 0x9e, 0x23, 0xe2, 0x91, 0x14, 0xda, + 0x83, 0xa5, 0xae, 0xd3, 0x0a, 0x36, 0xfd, 0x55, 0xc3, 0xdb, 0x63, 0x38, 0x31, 0xbc, 0xa7, 0x07, + 0xfd, 0xca, 0xd2, 0x56, 0x0a, 0xfe, 0x7e, 0xbf, 0x52, 0x96, 0x4c, 0x62, 0x04, 0x38, 0x95, 0x23, + 0xea, 0x42, 0x71, 0xd7, 0x24, 0x56, 0x0b, 0x93, 0x5d, 0xa1, 0x29, 0x63, 0x6e, 0xef, 0x2b, 0x82, + 0x5b, 0x7d, 0x86, 0xda, 0xd2, 0xe0, 0x17, 0x96, 0x52, 0xf4, 0x1f, 0x4f, 0xc0, 0x7c, 0xdd, 0xea, + 0x91, 0x17, 0x5c, 0x42, 0x82, 0x38, 0xa0, 0x06, 0xf3, 0x5d, 0x97, 0xec, 0x9b, 0xe4, 0x6e, 0x83, + 0x58, 0xa4, 0xe9, 0x3b, 0xae, 0x18, 0xea, 0x19, 0xb1, 0x92, 0xf3, 0x5b, 0x2a, 0x1a, 0xc7, 0xe9, + 0xd1, 0xf3, 0x30, 0x67, 0x34, 0x7d, 0x73, 0x9f, 0x48, 0x0e, 0x7c, 0xa1, 0x3f, 0x24, 0x38, 0xcc, + 0xd5, 0x14, 0x2c, 0x8e, 0x51, 0xa3, 0x57, 0xa1, 0xec, 0x35, 0x0d, 0x8b, 0xdc, 0xec, 0x0a, 0x51, + 0xab, 0x7b, 0xa4, 0x79, 0x67, 0xcb, 0x31, 0x6d, 0x5f, 0x04, 0x38, 0x17, 0x04, 0xa7, 0x72, 0xe3, + 0x10, 0x3a, 0x7c, 0x28, 0x07, 0xf4, 0xa7, 0x1a, 0x9c, 0xef, 0xba, 0x64, 0xcb, 0x75, 0x3a, 0x0e, + 0xd5, 0xde, 0x44, 0x28, 0x24, 0x42, 0x82, 0x97, 0xc6, 0xdc, 0xa6, 0x1c, 0x92, 0x3c, 0x75, 0x7c, + 0x64, 0xd0, 0xaf, 0x9c, 0xdf, 0x3a, 0xaa, 0x03, 0xf8, 0xe8, 0xfe, 0xa1, 0x6f, 0x6b, 0xb0, 0xdc, + 0x75, 0x3c, 0xff, 0x88, 0x21, 0x14, 0x4e, 0x74, 0x08, 0xfa, 0xa0, 0x5f, 0x59, 0xde, 0x3a, 0xb2, + 0x07, 0xf8, 0x98, 0x1e, 0xea, 0x5f, 0x2e, 0xc1, 0x62, 0x44, 0xf7, 0xe8, 0x81, 0xbe, 0x7d, 0x80, + 0x9e, 0x83, 0xd9, 0x40, 0x19, 0xf8, 0xa9, 0x9a, 0xeb, 0x9e, 0x8c, 0xeb, 0x6a, 0x51, 0x24, 0x56, + 0x69, 0xa9, 0xde, 0x49, 0x55, 0xe4, 0xad, 0x63, 0x7a, 0xb7, 0xa5, 0x60, 0x71, 0x8c, 0x1a, 0xad, + 0xc1, 0x29, 0x01, 0xc1, 0xa4, 0x6b, 0x99, 0x4d, 0x63, 0xd5, 0xe9, 0x09, 0x95, 0x2b, 0xd4, 0xcf, + 0x0c, 0xfa, 0x95, 0x53, 0x5b, 0x49, 0x34, 0x4e, 0x6b, 0x83, 0x36, 0x60, 0xc9, 0xe8, 0xf9, 0x8e, + 0x1c, 0xff, 0x65, 0xdb, 0xd8, 0xb1, 0x48, 0x8b, 0xa9, 0x56, 0xb1, 0x5e, 0xa6, 0x56, 0xa3, 0x96, + 0x82, 0xc7, 0xa9, 0xad, 0xd0, 0x56, 0x8c, 0x5b, 0x83, 0x34, 0x1d, 0xbb, 0xc5, 0x57, 0xb9, 0x50, + 0x3f, 0x27, 0x86, 0xa7, 0x72, 0x14, 0x34, 0x38, 0xb5, 0x25, 0xb2, 0x60, 0xae, 0x63, 0xdc, 0xbb, + 0x69, 0x1b, 0xfb, 0x86, 0x69, 0x51, 0x21, 0xe5, 0xc9, 0x63, 0x42, 0xd3, 0x9e, 0x6f, 0x5a, 0x55, + 0x7e, 0x03, 0x53, 0x5d, 0xb3, 0xfd, 0xeb, 0x6e, 0xc3, 0xa7, 0x4e, 0xa0, 0x8e, 0xe8, 0xc4, 0x6e, + 0x2a, 0xbc, 0x70, 0x8c, 0x37, 0xba, 0x0e, 0xa7, 0xd9, 0x76, 0xbc, 0xe4, 0xdc, 0xb5, 0x2f, 0x11, + 0xcb, 0x38, 0x08, 0x06, 0x30, 0xc5, 0x06, 0xf0, 0xe1, 0x41, 0xbf, 0x72, 0xba, 0x91, 0x46, 0x80, + 0xd3, 0xdb, 0x21, 0x03, 0x1e, 0x55, 0x11, 0x98, 0xec, 0x9b, 0x9e, 0xe9, 0xd8, 0x1b, 0x66, 0xc7, + 0xf4, 0xcb, 0x45, 0xc6, 0xb6, 0x32, 0xe8, 0x57, 0x1e, 0x6d, 0x1c, 0x4e, 0x86, 0x8f, 0xe2, 0x81, + 0x7e, 0x53, 0x83, 0xa5, 0xb4, 0x6d, 0x58, 0x9e, 0xce, 0xe2, 0xfe, 0x23, 0xb6, 0xb5, 0xb8, 0x46, + 0xa4, 0x1a, 0x85, 0xd4, 0x4e, 0xa0, 0x37, 0x34, 0x98, 0x31, 0x22, 0xc1, 0x59, 0x19, 0x58, 0xaf, + 0xd6, 0xc7, 0x8d, 0x86, 0x43, 0x8e, 0xf5, 0x85, 0x41, 0xbf, 0xa2, 0x04, 0x80, 0x58, 0x91, 0x88, + 0x7e, 0x5b, 0x83, 0xd3, 0xa9, 0x7b, 0xbc, 0x5c, 0x3a, 0x89, 0x19, 0x62, 0x4a, 0x92, 0x6e, 0x73, + 0xd2, 0xbb, 0x81, 0xde, 0xd5, 0xa4, 0x2b, 0xdb, 0x0c, 0xce, 0x23, 0x33, 0xac, 0x6b, 0x37, 0xc6, + 0x8c, 0x47, 0x43, 0xef, 0x1d, 0x30, 0xae, 0x9f, 0x8a, 0x78, 0xc6, 0x00, 0x88, 0xe3, 0xe2, 0xd1, + 0xd7, 0xb5, 0xc0, 0x35, 0xca, 0x1e, 0xcd, 0x9e, 0x54, 0x8f, 0x50, 0xe8, 0x69, 0x65, 0x87, 0x62, + 0xc2, 0xf5, 0x7f, 0xce, 0xc3, 0xcc, 0xaa, 0x61, 0x1b, 0xee, 0x81, 0x70, 0x2d, 0x7f, 0xa2, 0xc1, + 0xb9, 0x66, 0xcf, 0x75, 0x89, 0xed, 0x37, 0x7c, 0xd2, 0x4d, 0x3a, 0x16, 0xed, 0x44, 0x1d, 0xcb, + 0x85, 0x41, 0xbf, 0x72, 0x6e, 0xf5, 0x08, 0xf9, 0xf8, 0xc8, 0xde, 0xa1, 0xbf, 0xd6, 0x40, 0x17, + 0x04, 0x75, 0xa3, 0x79, 0xa7, 0xed, 0x3a, 0x3d, 0xbb, 0x95, 0x1c, 0x44, 0xee, 0x44, 0x07, 0xf1, + 0xf8, 0xa0, 0x5f, 0xd1, 0x57, 0x8f, 0xed, 0x05, 0x1e, 0xa2, 0xa7, 0xe8, 0x05, 0x58, 0x14, 0x54, + 0x97, 0xef, 0x75, 0x89, 0x6b, 0xd2, 0xd8, 0x54, 0xdc, 0x34, 0x7f, 0x58, 0x98, 0xfd, 0xc5, 0xd5, + 0x38, 0x01, 0x4e, 0xb6, 0xd1, 0xff, 0x68, 0x02, 0x20, 0x58, 0x69, 0xd2, 0x45, 0x3f, 0x05, 0xd3, + 0x1e, 0xf1, 0x6f, 0x11, 0xb3, 0xbd, 0xe7, 0xb3, 0x35, 0x2d, 0x88, 0x6b, 0x8d, 0x00, 0x88, 0x43, + 0x3c, 0xba, 0x03, 0x85, 0xae, 0xd1, 0xf3, 0x88, 0x98, 0xb7, 0xf5, 0x4c, 0xe6, 0x6d, 0x8b, 0x72, + 0xe4, 0xb1, 0x3f, 0xfb, 0x13, 0x73, 0x19, 0xe8, 0x2b, 0x1a, 0x00, 0x51, 0xc7, 0x5a, 0xba, 0xd8, + 0xc8, 0x44, 0x64, 0x38, 0x1d, 0x74, 0x0e, 0xea, 0x73, 0x83, 0x7e, 0x05, 0x22, 0xb3, 0x16, 0x11, + 0x8b, 0xee, 0x42, 0xd1, 0x08, 0xcc, 0xd9, 0xc4, 0x49, 0x98, 0x33, 0x16, 0x92, 0xcb, 0xf5, 0x96, + 0xc2, 0xd0, 0xdb, 0x1a, 0xcc, 0x79, 0xc4, 0x17, 0x4b, 0x45, 0xfd, 0x93, 0x88, 0xe5, 0x36, 0xc6, + 0x93, 0xdf, 0x50, 0x78, 0x72, 0xe3, 0xa0, 0xc2, 0x70, 0x4c, 0xae, 0xfe, 0x9f, 0x45, 0x98, 0x0b, + 0x54, 0x26, 0x0c, 0xcf, 0x9a, 0x1c, 0x92, 0x1e, 0x9e, 0xad, 0x46, 0x91, 0x58, 0xa5, 0xa5, 0x8d, + 0x3d, 0x9f, 0xc6, 0x03, 0x6a, 0x74, 0x26, 0x1b, 0x37, 0xa2, 0x48, 0xac, 0xd2, 0xa2, 0x0e, 0x14, + 0x3c, 0x9f, 0x74, 0x83, 0x4b, 0xc3, 0xab, 0xe3, 0xcd, 0x46, 0xb8, 0x13, 0xc2, 0x0b, 0x1f, 0xfa, + 0xcb, 0xc3, 0x5c, 0x0a, 0x7a, 0x47, 0x83, 0x39, 0x5f, 0x49, 0x28, 0x09, 0x35, 0xc8, 0x46, 0x13, + 0xd5, 0x5c, 0x15, 0x5f, 0x0d, 0x15, 0x86, 0x63, 0xe2, 0x53, 0x22, 0xb6, 0xc2, 0x09, 0x46, 0x6c, + 0x2f, 0x43, 0xb1, 0x63, 0xdc, 0x6b, 0xf4, 0xdc, 0xf6, 0x83, 0x47, 0x86, 0x4c, 0xc5, 0x37, 0x05, + 0x17, 0x2c, 0xf9, 0xa1, 0x37, 0xb5, 0xc8, 0xe6, 0x9a, 0x62, 0xcc, 0x6f, 0x65, 0xbb, 0xb9, 0xa4, + 0x41, 0x3d, 0x74, 0x9b, 0x25, 0xe2, 0xa7, 0xe2, 0x43, 0x8f, 0x9f, 0x68, 0x2c, 0xc0, 0x37, 0x88, + 0x8c, 0x05, 0xa6, 0x4f, 0x34, 0x16, 0x58, 0x55, 0x84, 0xe1, 0x98, 0x70, 0xd6, 0x1f, 0xbe, 0xe7, + 0x64, 0x7f, 0xe0, 0x44, 0xfb, 0xd3, 0x50, 0x84, 0xe1, 0x98, 0x70, 0xfd, 0x87, 0x1a, 0x9c, 0x59, + 0xb5, 0x7a, 0x9e, 0x4f, 0xdc, 0xff, 0x35, 0x77, 0xea, 0xff, 0xa1, 0xc1, 0xa3, 0x87, 0x8c, 0xf9, + 0x21, 0x5c, 0xad, 0xbf, 0xae, 0x5e, 0xad, 0xdf, 0x1c, 0xd3, 0xc6, 0xa6, 0x8f, 0xe3, 0x90, 0x1b, + 0x76, 0x1f, 0x66, 0x2f, 0x19, 0xbe, 0xd1, 0x72, 0xda, 0xfc, 0xca, 0x1b, 0x3d, 0x0f, 0x45, 0xd3, + 0xf6, 0x89, 0xbb, 0x6f, 0x58, 0xc2, 0xcb, 0xe8, 0x41, 0xd7, 0xd7, 0x04, 0xfc, 0x7e, 0xbf, 0x32, + 0x77, 0xa9, 0xe7, 0xb2, 0xb4, 0x38, 0xb7, 0x39, 0x58, 0xb6, 0x41, 0x8f, 0x41, 0xe1, 0x73, 0x3d, + 0xe2, 0x1e, 0xc4, 0x53, 0xb1, 0x37, 0x28, 0x10, 0x73, 0x9c, 0xfe, 0xb7, 0x39, 0x88, 0x44, 0x00, + 0x0f, 0x41, 0xad, 0x6c, 0x45, 0xad, 0xc6, 0xf4, 0xe9, 0x91, 0x78, 0xe6, 0xb0, 0x1c, 0xfa, 0x7e, + 0x2c, 0x87, 0x7e, 0x2d, 0x33, 0x89, 0x47, 0xa7, 0xd0, 0xdf, 0xd7, 0xe0, 0xd1, 0x90, 0x38, 0x19, + 0xd7, 0x1e, 0x7f, 0x49, 0xfc, 0x0c, 0x94, 0x8c, 0xb0, 0x99, 0x58, 0x45, 0x59, 0x5d, 0x11, 0xe1, + 0x88, 0xa3, 0x74, 0x61, 0x1a, 0x33, 0xff, 0x80, 0x69, 0xcc, 0x89, 0xa3, 0xd3, 0x98, 0xfa, 0x8f, + 0x72, 0x70, 0x3e, 0x39, 0xb2, 0x40, 0xbb, 0x31, 0xd9, 0x1d, 0x62, 0x6c, 0xcf, 0xc2, 0x8c, 0x2f, + 0x1a, 0x50, 0xa8, 0x18, 0xdc, 0x92, 0xa0, 0x9c, 0xd9, 0x8e, 0xe0, 0xb0, 0x42, 0x49, 0x5b, 0x36, + 0xf9, 0xbe, 0x6a, 0x34, 0x9d, 0x6e, 0x90, 0xef, 0x95, 0x2d, 0x57, 0x23, 0x38, 0xac, 0x50, 0xca, + 0xc4, 0xd1, 0xc4, 0x89, 0x27, 0xa4, 0x1b, 0x70, 0x3a, 0xc8, 0x1f, 0x5c, 0x71, 0xdc, 0x55, 0xa7, + 0xd3, 0xb5, 0x08, 0x4b, 0x7f, 0x14, 0x58, 0x67, 0xcf, 0x8b, 0x26, 0xa7, 0x71, 0x1a, 0x11, 0x4e, + 0x6f, 0xab, 0xbf, 0x9f, 0x87, 0x53, 0xe1, 0xb4, 0xaf, 0x3a, 0x76, 0xcb, 0x64, 0x59, 0x98, 0xe7, + 0x60, 0xc2, 0x3f, 0xe8, 0x06, 0x93, 0xfd, 0xff, 0x82, 0xee, 0x6c, 0x1f, 0x74, 0xe9, 0x6a, 0x9f, + 0x49, 0x69, 0x42, 0x51, 0x98, 0x35, 0x42, 0x1b, 0x72, 0x77, 0xf0, 0x15, 0x78, 0x5a, 0xd5, 0xe6, + 0xfb, 0xfd, 0x4a, 0x4a, 0x4d, 0x55, 0x55, 0x72, 0x52, 0x75, 0x1e, 0xdd, 0x86, 0x39, 0xcb, 0xf0, + 0xfc, 0x9b, 0xdd, 0x96, 0xe1, 0x93, 0x6d, 0xb3, 0x43, 0xc4, 0x9e, 0x1b, 0x25, 0xb7, 0x2c, 0xaf, + 0x2a, 0x37, 0x14, 0x4e, 0x38, 0xc6, 0x19, 0xed, 0x03, 0xa2, 0x90, 0x6d, 0xd7, 0xb0, 0x3d, 0x3e, + 0x2a, 0x2a, 0x6f, 0xf4, 0x5c, 0xf6, 0x59, 0x21, 0x0f, 0x6d, 0x24, 0xb8, 0xe1, 0x14, 0x09, 0xe8, + 0x71, 0x98, 0x74, 0x89, 0xe1, 0x89, 0xc5, 0x9c, 0x0e, 0xf7, 0x3f, 0x66, 0x50, 0x2c, 0xb0, 0xd1, + 0x0d, 0x35, 0x79, 0xcc, 0x86, 0xfa, 0xbe, 0x06, 0x73, 0xe1, 0x32, 0x3d, 0x04, 0x37, 0xd7, 0x51, + 0xdd, 0xdc, 0xd5, 0xac, 0x4c, 0xe2, 0x21, 0x9e, 0xed, 0x83, 0x7c, 0x74, 0x7c, 0x2c, 0x6b, 0xfc, + 0x79, 0x98, 0x0e, 0x76, 0x75, 0x90, 0x37, 0x1e, 0x33, 0xf2, 0x54, 0x22, 0x8b, 0x48, 0xf9, 0x87, + 0x10, 0x82, 0x43, 0x79, 0xd4, 0xb1, 0xb6, 0x84, 0xd3, 0x14, 0x6a, 0x2f, 0x1d, 0x6b, 0xe0, 0x4c, + 0xd3, 0x1c, 0x6b, 0xd0, 0x06, 0xdd, 0x84, 0x33, 0x5d, 0xd7, 0x61, 0x95, 0x73, 0x97, 0x88, 0xd1, + 0xb2, 0x4c, 0x9b, 0x04, 0xd7, 0xb9, 0xfc, 0xa6, 0xfc, 0xd1, 0x41, 0xbf, 0x72, 0x66, 0x2b, 0x9d, + 0x04, 0x1f, 0xd6, 0x56, 0x2d, 0x63, 0x99, 0x38, 0xbe, 0x8c, 0x05, 0xfd, 0x92, 0x3c, 0x46, 0x10, + 0xaf, 0x5c, 0x60, 0x93, 0xf8, 0x4a, 0x56, 0x4b, 0x99, 0x62, 0xd6, 0x43, 0x95, 0xaa, 0x09, 0xa1, + 0x58, 0x8a, 0xd7, 0xdf, 0x2a, 0xc0, 0x42, 0xdc, 0x37, 0x9e, 0x7c, 0x45, 0xcd, 0xaf, 0x6a, 0xb0, + 0x10, 0xac, 0x2b, 0x97, 0x49, 0x82, 0xf3, 0xf1, 0x46, 0x46, 0xea, 0xc4, 0xbd, 0xbc, 0x2c, 0x4c, + 0xdc, 0x8e, 0x49, 0xc3, 0x09, 0xf9, 0xe8, 0x35, 0x28, 0xc9, 0x63, 0xe4, 0x03, 0x95, 0xd7, 0xcc, + 0x33, 0xff, 0x1e, 0xb2, 0xc0, 0x51, 0x7e, 0xe8, 0x2d, 0x0d, 0xa0, 0x19, 0x18, 0xe0, 0x60, 0xdd, + 0x6f, 0x64, 0xb5, 0xee, 0xd2, 0xb4, 0x87, 0x61, 0x9c, 0x04, 0x79, 0x38, 0x22, 0x18, 0xfd, 0x1a, + 0x3b, 0x40, 0xca, 0xb8, 0xc3, 0x2b, 0x4f, 0xb2, 0x9e, 0x7c, 0x26, 0x6b, 0x0d, 0x0c, 0xaf, 0x15, + 0xa5, 0x93, 0x8f, 0xa0, 0x3c, 0xac, 0x74, 0x42, 0x7f, 0x0e, 0x64, 0x9a, 0x97, 0x6e, 0x28, 0x96, + 0xe8, 0xdd, 0x32, 0xfc, 0x3d, 0xa1, 0x82, 0x72, 0x43, 0x5d, 0x09, 0x10, 0x38, 0xa4, 0xd1, 0xff, + 0x5c, 0x83, 0xa5, 0x35, 0xcf, 0x37, 0x9d, 0x4b, 0xc4, 0xf3, 0xe9, 0x1e, 0xa3, 0xee, 0xb8, 0x67, + 0x91, 0x21, 0x02, 0x9a, 0x4b, 0xb0, 0x20, 0xee, 0x7a, 0x7a, 0x3b, 0x1e, 0xf1, 0x23, 0x41, 0x8d, + 0x54, 0x9d, 0xd5, 0x18, 0x1e, 0x27, 0x5a, 0x50, 0x2e, 0xe2, 0xd2, 0x27, 0xe4, 0x92, 0x57, 0xb9, + 0x34, 0x62, 0x78, 0x9c, 0x68, 0xa1, 0x7f, 0x33, 0x07, 0xa7, 0xd8, 0x30, 0x62, 0x05, 0xc1, 0xbf, + 0xa2, 0xc1, 0xdc, 0xbe, 0xe9, 0xfa, 0x3d, 0xc3, 0x8a, 0xde, 0x5e, 0x8d, 0xad, 0x3d, 0x4c, 0xd6, + 0x4b, 0x0a, 0xe3, 0xd0, 0x8d, 0xab, 0x70, 0x1c, 0xeb, 0x00, 0xed, 0xd3, 0x7c, 0x4b, 0x9d, 0xed, + 0x6c, 0x4e, 0x9c, 0x69, 0xeb, 0xc8, 0x73, 0x14, 0x31, 0x20, 0x8e, 0xcb, 0xd7, 0x5f, 0x11, 0xd3, + 0xa7, 0x76, 0x7d, 0x08, 0x25, 0xd0, 0x61, 0xd2, 0x75, 0x7a, 0xd4, 0xa5, 0x51, 0xc7, 0x3a, 0x5d, + 0x07, 0x16, 0x17, 0x30, 0x08, 0x16, 0x18, 0xfd, 0x0f, 0x35, 0x98, 0x5e, 0x77, 0x76, 0xc4, 0x19, + 0xef, 0xe7, 0x33, 0x38, 0x6f, 0x49, 0xb3, 0x2c, 0x2f, 0x12, 0x42, 0x4f, 0xff, 0xbc, 0x72, 0xda, + 0x3a, 0x17, 0xe1, 0x5d, 0x65, 0x55, 0xf4, 0x94, 0xd5, 0xba, 0xb3, 0x73, 0xe8, 0x71, 0xfc, 0x77, + 0x0b, 0x30, 0xfb, 0xa2, 0x71, 0x40, 0x6c, 0xdf, 0x10, 0x3d, 0xfe, 0x18, 0x4c, 0x19, 0xad, 0x56, + 0x5a, 0x55, 0x79, 0x8d, 0x83, 0x71, 0x80, 0x67, 0x07, 0x98, 0x2e, 0x4b, 0x09, 0x47, 0x5c, 0x6d, + 0x78, 0x80, 0x09, 0x51, 0x38, 0x4a, 0x17, 0x6e, 0xa5, 0x55, 0xc7, 0xde, 0x35, 0xdb, 0x69, 0x9b, + 0x60, 0x35, 0x86, 0xc7, 0x89, 0x16, 0x68, 0x1d, 0x90, 0xa8, 0x18, 0xab, 0x35, 0x9b, 0x4e, 0xcf, + 0xe6, 0x9b, 0x89, 0x9f, 0x6d, 0x64, 0xcc, 0xb7, 0x99, 0xa0, 0xc0, 0x29, 0xad, 0xd0, 0xab, 0x50, + 0x6e, 0x32, 0xce, 0x22, 0x02, 0x88, 0x72, 0xe4, 0x51, 0xa0, 0x2c, 0xc7, 0x58, 0x3d, 0x84, 0x0e, + 0x1f, 0xca, 0x81, 0xf6, 0xd4, 0xf3, 0x1d, 0xd7, 0x68, 0x93, 0x28, 0xdf, 0x49, 0xb5, 0xa7, 0x8d, + 0x04, 0x05, 0x4e, 0x69, 0x85, 0xbe, 0x04, 0xd3, 0xfe, 0x9e, 0x4b, 0xbc, 0x3d, 0xc7, 0x6a, 0x89, + 0x9b, 0xc5, 0x31, 0x0f, 0xbc, 0x62, 0xf5, 0xb7, 0x03, 0xae, 0x91, 0x98, 0x24, 0x00, 0xe1, 0x50, + 0x26, 0x72, 0x61, 0xd2, 0xa3, 0xa7, 0x2d, 0xaf, 0x5c, 0xcc, 0x22, 0xaa, 0x13, 0xd2, 0xd9, 0x01, + 0x2e, 0x72, 0xd4, 0x66, 0x12, 0xb0, 0x90, 0xa4, 0xff, 0x45, 0x0e, 0x66, 0xa2, 0x84, 0x43, 0xec, + 0xd4, 0xaf, 0x68, 0x30, 0xd3, 0x74, 0x6c, 0xdf, 0x75, 0x2c, 0x7e, 0x8c, 0xe4, 0x1b, 0x64, 0xcc, + 0xca, 0x6c, 0xc6, 0xea, 0x12, 0xf1, 0x0d, 0xd3, 0x8a, 0x9c, 0x48, 0x23, 0x62, 0xb0, 0x22, 0x14, + 0x7d, 0x4d, 0x83, 0xf9, 0x30, 0xe5, 0x12, 0x9e, 0x67, 0x33, 0xed, 0x88, 0xac, 0x5a, 0xba, 0xac, + 0x4a, 0xc2, 0x71, 0xd1, 0xfa, 0x0e, 0x2c, 0xc4, 0x57, 0x9b, 0x4e, 0x65, 0xd7, 0x10, 0x7b, 0x3d, + 0x1f, 0x4e, 0xe5, 0x96, 0xe1, 0x79, 0x98, 0x61, 0xd0, 0xc7, 0xa1, 0xd8, 0x31, 0xdc, 0xb6, 0x69, + 0x1b, 0x16, 0x9b, 0xc5, 0x7c, 0xc4, 0x20, 0x09, 0x38, 0x96, 0x14, 0xfa, 0x0f, 0x26, 0xa0, 0xb4, + 0x49, 0x0c, 0xaf, 0xe7, 0x12, 0x76, 0xe1, 0x74, 0xe2, 0x21, 0xa2, 0x52, 0xea, 0x9c, 0xcf, 0xae, + 0xd4, 0x19, 0xbd, 0x0c, 0xb0, 0x6b, 0xda, 0xa6, 0xb7, 0xf7, 0x80, 0x45, 0xd4, 0x2c, 0xf9, 0x76, + 0x45, 0x72, 0xc0, 0x11, 0x6e, 0xe1, 0x2b, 0x8a, 0xc2, 0x11, 0xaf, 0x28, 0xde, 0xd2, 0x22, 0xce, + 0x83, 0x07, 0x5f, 0xb7, 0xc6, 0xad, 0xbd, 0x95, 0x0b, 0x53, 0x0d, 0x9c, 0xc9, 0x65, 0xdb, 0x77, + 0x0f, 0x8e, 0xf4, 0x31, 0xdb, 0x50, 0x74, 0x89, 0xd7, 0xeb, 0xd0, 0x60, 0x77, 0x6a, 0xe4, 0x69, + 0x60, 0xf9, 0x09, 0x2c, 0xda, 0x63, 0xc9, 0xe9, 0xec, 0x73, 0x30, 0xab, 0x74, 0x01, 0x2d, 0x40, + 0xfe, 0x0e, 0x39, 0xe0, 0x7a, 0x82, 0xe9, 0x9f, 0x68, 0x49, 0xa9, 0xa2, 0x14, 0xd3, 0xf2, 0xa9, + 0xdc, 0xb3, 0x9a, 0xfe, 0xa3, 0x49, 0x98, 0x14, 0xfe, 0xea, 0x78, 0x5b, 0x10, 0xbd, 0x67, 0xcd, + 0x3d, 0xc0, 0x3d, 0xeb, 0x3a, 0xcc, 0x98, 0xb6, 0xe9, 0x9b, 0x86, 0xc5, 0x8a, 0x68, 0x84, 0xaf, + 0x7a, 0x3c, 0xd8, 0xff, 0x6b, 0x11, 0x5c, 0x0a, 0x1f, 0xa5, 0x2d, 0xba, 0x01, 0x05, 0x66, 0xcc, + 0x85, 0x3e, 0x8d, 0x9e, 0x72, 0x62, 0xe9, 0x64, 0x5e, 0x96, 0xc5, 0x39, 0xb1, 0x98, 0xb2, 0xd7, + 0x6c, 0x12, 0xcf, 0x93, 0x81, 0xbc, 0x50, 0xab, 0x30, 0xa6, 0x8c, 0xe1, 0x71, 0xa2, 0x05, 0xe5, + 0xb2, 0x6b, 0x98, 0x56, 0xcf, 0x25, 0x21, 0x97, 0x49, 0x95, 0xcb, 0x95, 0x18, 0x1e, 0x27, 0x5a, + 0xa0, 0x5d, 0x98, 0x11, 0x30, 0x5e, 0xa6, 0x34, 0xf5, 0x80, 0xa3, 0x64, 0x99, 0xa5, 0x2b, 0x11, + 0x4e, 0x58, 0xe1, 0x8b, 0x7a, 0xb0, 0x68, 0xda, 0x4d, 0xc7, 0x6e, 0x5a, 0x3d, 0xcf, 0xdc, 0x27, + 0x61, 0x4d, 0xd4, 0x83, 0x08, 0x3b, 0x3d, 0xe8, 0x57, 0x16, 0xd7, 0xe2, 0xec, 0x70, 0x52, 0x02, + 0x7a, 0x53, 0x83, 0xd3, 0x4d, 0xc7, 0xf6, 0x58, 0x55, 0xf0, 0x3e, 0xb9, 0xec, 0xba, 0x8e, 0xcb, + 0x65, 0x4f, 0x3f, 0xa0, 0x6c, 0x56, 0xf3, 0xb3, 0x9a, 0xc6, 0x12, 0xa7, 0x4b, 0x42, 0xaf, 0x43, + 0xb1, 0xeb, 0x3a, 0xfb, 0x66, 0x8b, 0xb8, 0x22, 0x7b, 0xb5, 0x91, 0x45, 0x41, 0xfe, 0x96, 0xe0, + 0x19, 0x5a, 0x82, 0x00, 0x82, 0xa5, 0x3c, 0xfd, 0x1b, 0x93, 0x30, 0xa7, 0x92, 0xa3, 0x2f, 0x02, + 0x74, 0x5d, 0xa7, 0x43, 0xfc, 0x3d, 0x22, 0x6b, 0x67, 0xae, 0x8d, 0x5b, 0x0c, 0x1f, 0xf0, 0x13, + 0x6f, 0x05, 0x98, 0x25, 0x0d, 0xa1, 0x38, 0x22, 0x11, 0xb9, 0x30, 0x75, 0x87, 0xfb, 0x34, 0xe1, + 0xe2, 0x5f, 0xcc, 0x24, 0x20, 0x11, 0x92, 0x4b, 0xd4, 0xe5, 0x08, 0x10, 0x0e, 0x04, 0xa1, 0x1d, + 0xc8, 0xdf, 0x25, 0x3b, 0xd9, 0x94, 0x6d, 0xdf, 0x22, 0xe2, 0xa8, 0x50, 0x9f, 0x1a, 0xf4, 0x2b, + 0xf9, 0x5b, 0x64, 0x07, 0x53, 0xe6, 0x74, 0x5c, 0x2d, 0x9e, 0x2d, 0x12, 0xa6, 0x62, 0xcc, 0x71, + 0x29, 0xa9, 0x27, 0x3e, 0x2e, 0x01, 0xc2, 0x81, 0x20, 0xf4, 0x3a, 0x4c, 0xdf, 0x35, 0xf6, 0xc9, + 0xae, 0xeb, 0xd8, 0xbe, 0xc8, 0xbd, 0x8f, 0x59, 0x13, 0x72, 0x2b, 0x60, 0x27, 0xe4, 0x32, 0x6f, + 0x2b, 0x81, 0x38, 0x14, 0x87, 0xf6, 0xa1, 0x68, 0x93, 0xbb, 0x98, 0x58, 0x66, 0x53, 0xa4, 0xe3, + 0xc7, 0x54, 0xeb, 0x6b, 0x82, 0x9b, 0x90, 0xcc, 0xdc, 0x50, 0x00, 0xc3, 0x52, 0x16, 0x5d, 0xcb, + 0xdb, 0xce, 0x8e, 0x30, 0x54, 0x63, 0xae, 0xa5, 0x3c, 0xf6, 0xf1, 0xb5, 0x5c, 0x77, 0x76, 0x30, + 0x65, 0xae, 0x7f, 0x73, 0x02, 0x66, 0xa2, 0xcf, 0xb5, 0x86, 0xf0, 0x59, 0x32, 0x6c, 0xca, 0x8d, + 0x12, 0x36, 0xd1, 0xa8, 0xb7, 0x13, 0xfa, 0xf8, 0xe0, 0xaa, 0x6c, 0x2d, 0xb3, 0xa8, 0x21, 0x8c, + 0x7a, 0x23, 0x40, 0x0f, 0x2b, 0x42, 0x47, 0x48, 0x35, 0xd1, 0x38, 0x88, 0xbb, 0x43, 0x5e, 0xe7, + 0x2b, 0xe3, 0x20, 0xc5, 0xc1, 0x5d, 0x04, 0x10, 0xee, 0x6a, 0xb7, 0x67, 0x31, 0xe5, 0x28, 0x84, + 0x97, 0x57, 0x0d, 0x89, 0xc1, 0x11, 0x2a, 0xf4, 0x38, 0x4c, 0x52, 0x87, 0x41, 0x5a, 0xa2, 0x00, + 0x57, 0x1e, 0x2d, 0xae, 0x30, 0x28, 0x16, 0x58, 0xf4, 0x2c, 0xf5, 0xed, 0xa1, 0x99, 0x17, 0x75, + 0xb5, 0x4b, 0xa1, 0x6f, 0x0f, 0x71, 0x58, 0xa1, 0xa4, 0x5d, 0x27, 0xd4, 0x2a, 0x33, 0xd3, 0x1f, + 0xe9, 0x3a, 0x33, 0xd5, 0x98, 0xe3, 0xd8, 0x51, 0x37, 0x66, 0xc5, 0x99, 0xd1, 0x2e, 0x44, 0x8e, + 0xba, 0x31, 0x3c, 0x4e, 0xb4, 0xd0, 0x3f, 0x0b, 0x73, 0xaa, 0x36, 0xd3, 0x29, 0xee, 0xba, 0xce, + 0xae, 0x69, 0x91, 0xf8, 0x21, 0x7d, 0x8b, 0x83, 0x71, 0x80, 0x1f, 0x2e, 0x4b, 0xfc, 0x97, 0x79, + 0x38, 0x75, 0xad, 0x6d, 0xda, 0xf7, 0x62, 0x37, 0x4a, 0x69, 0x2f, 0xb9, 0xb5, 0x51, 0x5f, 0x72, + 0x87, 0x65, 0x51, 0xe2, 0x5d, 0x7a, 0x7a, 0x59, 0x54, 0xf0, 0x68, 0x5d, 0xa5, 0x45, 0xdf, 0xd7, + 0xe0, 0x9c, 0xd1, 0xe2, 0xf1, 0x85, 0x61, 0x09, 0x68, 0x28, 0x34, 0xd0, 0x71, 0x6f, 0x4c, 0x6b, + 0x91, 0x1c, 0x7c, 0xb5, 0x76, 0x84, 0x54, 0x1e, 0x35, 0x7f, 0x54, 0x8c, 0xe0, 0xdc, 0x51, 0xa4, + 0xf8, 0xc8, 0xee, 0x9f, 0xbd, 0x0e, 0x1f, 0x39, 0x56, 0xd0, 0x48, 0xb1, 0xf1, 0xef, 0x69, 0x30, + 0xc7, 0xea, 0x0d, 0xc3, 0xb0, 0xec, 0x19, 0x99, 0xd3, 0xe2, 0x8b, 0x77, 0x5e, 0xcd, 0x69, 0xdd, + 0xef, 0x57, 0x4a, 0xbc, 0x42, 0x51, 0x4d, 0x71, 0xbd, 0x22, 0x8e, 0x56, 0x2c, 0xf3, 0x96, 0x1b, + 0x39, 0xf2, 0x97, 0x17, 0x09, 0x8d, 0x80, 0x09, 0x0e, 0xf9, 0xe9, 0xdf, 0xc8, 0xc3, 0xa9, 0x94, + 0xc2, 0x19, 0x7a, 0xea, 0x99, 0xb4, 0x8c, 0x1d, 0x62, 0x05, 0x79, 0xa3, 0xd7, 0x32, 0x2f, 0xce, + 0xa9, 0x6e, 0x30, 0xfe, 0x7c, 0x0d, 0xa5, 0x65, 0xe0, 0x40, 0x2c, 0x84, 0xa3, 0xdf, 0xd0, 0xa0, + 0x64, 0x44, 0xd4, 0x8c, 0xa7, 0xd2, 0x76, 0xb2, 0xef, 0x4c, 0x42, 0xab, 0x22, 0x25, 0x00, 0xa1, + 0x12, 0x45, 0xfb, 0x72, 0xf6, 0x67, 0xa1, 0x14, 0x19, 0xc2, 0x28, 0xda, 0x71, 0xf6, 0x79, 0x58, + 0x18, 0x4b, 0xbb, 0x3e, 0x03, 0xa3, 0xbe, 0x3b, 0xa4, 0xb6, 0xf8, 0x6e, 0xb4, 0x0c, 0x57, 0xce, + 0xb8, 0xa8, 0xc3, 0x15, 0x58, 0x7d, 0x07, 0x16, 0xe2, 0xa1, 0xdf, 0x28, 0xb7, 0x91, 0x43, 0x19, + 0xba, 0x4f, 0xc2, 0x88, 0x2f, 0x05, 0xf5, 0xbf, 0xca, 0xc1, 0x94, 0xa8, 0xbe, 0x7b, 0x08, 0xd5, + 0x33, 0x77, 0x94, 0xfb, 0xdc, 0xb5, 0x4c, 0x8a, 0x06, 0x0f, 0x2d, 0x9d, 0xf1, 0x62, 0xa5, 0x33, + 0x2f, 0x66, 0x23, 0xee, 0xe8, 0xba, 0x99, 0x77, 0x72, 0x30, 0x1f, 0xab, 0x66, 0x44, 0xbf, 0xa8, + 0x25, 0xd3, 0xc5, 0x37, 0x33, 0x2d, 0x98, 0x94, 0xb5, 0x59, 0x47, 0x67, 0x8e, 0x3d, 0xe5, 0xed, + 0xf1, 0x8d, 0xcc, 0xbe, 0xe3, 0x70, 0xe4, 0x33, 0xe4, 0x7f, 0xd2, 0xe0, 0xc3, 0x87, 0xd6, 0x77, + 0xb2, 0x37, 0x1e, 0xae, 0x8a, 0x15, 0xba, 0x97, 0x71, 0xbd, 0xb6, 0xbc, 0x47, 0x8c, 0x97, 0xfd, + 0xc7, 0xc5, 0xa3, 0xa7, 0x61, 0x86, 0xd9, 0x71, 0xba, 0x7d, 0x7c, 0xd2, 0x15, 0x9f, 0x93, 0x61, + 0x67, 0xf6, 0x46, 0x04, 0x8e, 0x15, 0x2a, 0xfd, 0x77, 0x34, 0x28, 0x1f, 0xf6, 0xa2, 0x60, 0x88, + 0x88, 0xf8, 0x67, 0x62, 0x95, 0x2c, 0x95, 0x44, 0x25, 0x4b, 0x2c, 0x26, 0x0e, 0x8a, 0x56, 0x22, + 0xe1, 0x68, 0xfe, 0x98, 0x42, 0x8d, 0xaf, 0x6b, 0x70, 0xe6, 0x10, 0xc5, 0x49, 0x54, 0x34, 0x69, + 0x0f, 0x5c, 0xd1, 0x94, 0x1b, 0xb6, 0xa2, 0x49, 0xff, 0x9b, 0x3c, 0x2c, 0x88, 0xfe, 0x84, 0xce, + 0xfc, 0x59, 0xa5, 0x1e, 0xe8, 0xa3, 0xb1, 0x7a, 0xa0, 0xa5, 0x38, 0xfd, 0xff, 0x15, 0x03, 0xfd, + 0x64, 0x15, 0x03, 0xfd, 0x38, 0x07, 0xa7, 0x53, 0x5f, 0x6b, 0xa0, 0xb7, 0x53, 0xac, 0xe0, 0xad, + 0x8c, 0x9f, 0x85, 0x0c, 0x69, 0x07, 0xc7, 0xad, 0xa0, 0xf9, 0xf5, 0x68, 0xe5, 0x0a, 0x0f, 0xd0, + 0x77, 0x4f, 0xe0, 0x81, 0xcb, 0xa8, 0x45, 0x2c, 0xbf, 0x9c, 0x87, 0x27, 0x86, 0x65, 0xf4, 0x13, + 0x5a, 0xe4, 0xe8, 0x29, 0x45, 0x8e, 0x0f, 0xc7, 0x43, 0x9d, 0x4c, 0xbd, 0xe3, 0x57, 0xf3, 0xd2, + 0xed, 0x25, 0xf5, 0x73, 0xa8, 0x6b, 0xfd, 0x29, 0x1a, 0xc5, 0x04, 0xdf, 0x12, 0x08, 0x4d, 0xe1, + 0x54, 0x83, 0x83, 0xef, 0xf7, 0x2b, 0x8b, 0xe2, 0xc9, 0x72, 0x83, 0xf8, 0x02, 0x88, 0x83, 0x46, + 0xe8, 0x09, 0x28, 0xba, 0x1c, 0x1b, 0x94, 0x75, 0x89, 0x54, 0x05, 0x87, 0x61, 0x89, 0x45, 0x5f, + 0x8a, 0x84, 0x7d, 0x13, 0x27, 0xf5, 0x60, 0xe0, 0xa8, 0x0c, 0xcc, 0x6b, 0x50, 0xf4, 0x82, 0x0f, + 0x0d, 0xf0, 0x7b, 0xb9, 0xa7, 0x86, 0xac, 0x16, 0xa4, 0xa7, 0x84, 0xe0, 0xab, 0x03, 0x7c, 0x7c, + 0xf2, 0x9b, 0x04, 0x92, 0xa5, 0xfe, 0xbe, 0x06, 0x25, 0xb1, 0x12, 0x0f, 0xa1, 0x38, 0xf1, 0xb6, + 0x5a, 0x9c, 0x78, 0x39, 0x13, 0xbb, 0x70, 0x48, 0x65, 0xe2, 0x6d, 0x98, 0x89, 0x3e, 0xc6, 0x43, + 0x2f, 0x47, 0xec, 0x9a, 0x36, 0xce, 0xa3, 0x9f, 0xc0, 0xf2, 0x85, 0x36, 0x4f, 0xff, 0x4e, 0x41, + 0xce, 0x22, 0x2b, 0x81, 0x8c, 0xea, 0x97, 0x76, 0xa4, 0x7e, 0x45, 0x97, 0x37, 0x97, 0xf9, 0xf2, + 0xa2, 0x1b, 0x50, 0x0c, 0x8c, 0x8f, 0x70, 0xd1, 0x8f, 0x45, 0xeb, 0x44, 0xa8, 0x9f, 0xa7, 0xcc, + 0x22, 0x4a, 0xc9, 0x4e, 0x0c, 0x72, 0x0d, 0xa5, 0x51, 0x94, 0x6c, 0x50, 0x0d, 0xe6, 0x3b, 0xa6, + 0x8d, 0x89, 0xd1, 0x92, 0x0f, 0xdd, 0x27, 0xf8, 0x37, 0x04, 0x82, 0x20, 0x72, 0x53, 0x45, 0xe3, + 0x38, 0x3d, 0xfa, 0x3c, 0x14, 0x3d, 0xf1, 0xe8, 0x2e, 0x9b, 0xbb, 0x66, 0x79, 0xfc, 0xe0, 0x4c, + 0xc3, 0xfe, 0x07, 0x10, 0x2c, 0x05, 0xa2, 0x0d, 0x58, 0x72, 0xc5, 0x5b, 0xf8, 0xab, 0xa6, 0xe7, + 0x3b, 0xee, 0x01, 0x4f, 0xe3, 0xf0, 0xcb, 0x45, 0xf6, 0x54, 0x1d, 0xa7, 0xe0, 0x71, 0x6a, 0x2b, + 0x1a, 0x25, 0xb0, 0x97, 0x9d, 0xfc, 0xb2, 0xb1, 0x18, 0x46, 0x09, 0x4c, 0xe9, 0x5a, 0x58, 0x60, + 0x8f, 0xaa, 0x2b, 0x2d, 0x8e, 0x51, 0x57, 0x7a, 0x0b, 0xa6, 0x5d, 0xc2, 0x42, 0xed, 0x5a, 0x90, + 0x88, 0x1a, 0x39, 0x03, 0x8e, 0x03, 0x06, 0x38, 0xe4, 0xa5, 0xff, 0xf1, 0x0c, 0xcc, 0x2a, 0x87, + 0x3a, 0x7a, 0xc6, 0x36, 0x76, 0x1c, 0x97, 0x9f, 0xe4, 0x8b, 0xe1, 0xa6, 0xab, 0x51, 0x20, 0xe6, + 0x38, 0xf4, 0x8e, 0x06, 0xf3, 0x5d, 0xe5, 0x02, 0x2a, 0xd8, 0xeb, 0x63, 0x5e, 0xe9, 0xab, 0xb7, + 0x5a, 0x91, 0xcf, 0xb5, 0xa8, 0xc2, 0x70, 0x5c, 0x3a, 0x55, 0x57, 0x51, 0x97, 0x61, 0x11, 0x97, + 0x51, 0x0b, 0x8f, 0x2b, 0x59, 0xac, 0xaa, 0x68, 0x1c, 0xa7, 0xa7, 0x93, 0xcc, 0x46, 0x37, 0xce, + 0x17, 0xd5, 0x6a, 0x01, 0x03, 0x1c, 0xf2, 0x42, 0xcf, 0xc3, 0x9c, 0x78, 0xcb, 0xbc, 0xe5, 0xb4, + 0xae, 0x1a, 0xde, 0x9e, 0x08, 0x35, 0x65, 0x68, 0xbc, 0xaa, 0x60, 0x71, 0x8c, 0x9a, 0x8d, 0x2d, + 0x7c, 0x30, 0xce, 0x18, 0x4c, 0xaa, 0x5f, 0xb3, 0x59, 0x55, 0xd1, 0x38, 0x4e, 0x8f, 0x3e, 0x1e, + 0xb1, 0x54, 0xfc, 0xba, 0x5c, 0xee, 0x9d, 0x14, 0x6b, 0x55, 0x83, 0xf9, 0x1e, 0x8b, 0xcc, 0x5b, + 0x01, 0x52, 0x68, 0xaf, 0x14, 0x78, 0x53, 0x45, 0xe3, 0x38, 0x3d, 0x7a, 0x0e, 0x66, 0x5d, 0x6a, + 0x0b, 0x24, 0x03, 0x7e, 0x87, 0x2e, 0x2f, 0x84, 0x71, 0x14, 0x89, 0x55, 0x5a, 0xf4, 0x02, 0x2c, + 0x86, 0xaf, 0x3a, 0x03, 0x06, 0xfc, 0x52, 0x5d, 0x3e, 0x18, 0xaf, 0xc5, 0x09, 0x70, 0xb2, 0x0d, + 0xfa, 0x39, 0x58, 0x88, 0xcc, 0xc4, 0x9a, 0xdd, 0x22, 0xf7, 0xd8, 0x87, 0x1d, 0x0a, 0xf5, 0x25, + 0x76, 0x31, 0x1f, 0xc3, 0xe1, 0x04, 0x35, 0xfa, 0x14, 0xcc, 0x35, 0x1d, 0xcb, 0x62, 0x16, 0x81, + 0x7f, 0x49, 0x65, 0x86, 0x67, 0x27, 0xd8, 0xba, 0x29, 0x18, 0x1c, 0xa3, 0x44, 0xeb, 0x80, 0x9c, + 0x1d, 0x8f, 0xb8, 0xfb, 0xa4, 0xf5, 0x02, 0xff, 0xdc, 0x2b, 0x75, 0x4a, 0xb3, 0x6a, 0x55, 0xd8, + 0xf5, 0x04, 0x05, 0x4e, 0x69, 0x85, 0xbe, 0xac, 0x96, 0x0c, 0xcf, 0x65, 0xf1, 0xdd, 0xb8, 0xf8, + 0x39, 0xf2, 0xd8, 0x7a, 0x61, 0x17, 0x26, 0x79, 0x91, 0x5e, 0x79, 0x3e, 0x8b, 0x97, 0xa6, 0xd1, + 0x8f, 0x36, 0x84, 0x16, 0x95, 0x43, 0xb1, 0x90, 0x84, 0xbe, 0x08, 0xd3, 0x3b, 0xc1, 0x17, 0x76, + 0xca, 0x0b, 0x59, 0x78, 0x91, 0xd8, 0xc7, 0xa2, 0xc2, 0x73, 0x92, 0x44, 0xe0, 0x50, 0x24, 0x7a, + 0x1c, 0x4a, 0x57, 0xb7, 0x6a, 0x52, 0x0b, 0x17, 0xd9, 0xea, 0x4f, 0xd0, 0x26, 0x38, 0x8a, 0xa0, + 0x3b, 0x4c, 0x7a, 0x78, 0xc4, 0x96, 0x38, 0xf4, 0x4e, 0x49, 0x87, 0x4d, 0xa9, 0x59, 0x0e, 0x04, + 0x37, 0xca, 0xa7, 0x62, 0xd4, 0x02, 0x8e, 0x25, 0x05, 0x7a, 0x0d, 0x4a, 0xc2, 0x64, 0x33, 0xdb, + 0xb4, 0xf4, 0x60, 0xe5, 0xe8, 0x38, 0x64, 0x81, 0xa3, 0xfc, 0xd0, 0x33, 0x50, 0xea, 0xb2, 0x0f, + 0x8f, 0x90, 0x2b, 0x3d, 0xcb, 0x2a, 0x9f, 0x66, 0x76, 0x53, 0x5e, 0x51, 0x6f, 0x85, 0x28, 0x1c, + 0xa5, 0xd3, 0xdf, 0x0c, 0xaf, 0xf9, 0xe4, 0xdb, 0xfa, 0x2f, 0x44, 0x57, 0x4b, 0xcb, 0xe2, 0xb3, + 0xb0, 0x89, 0xcf, 0x2b, 0x71, 0x43, 0x9b, 0xba, 0x56, 0x5d, 0xa9, 0x9f, 0x99, 0x3c, 0x4d, 0x54, + 0xbf, 0x1b, 0xc0, 0x4b, 0x81, 0x55, 0xed, 0xd4, 0xdf, 0xcf, 0xcb, 0xa3, 0x7e, 0x2c, 0xaf, 0xe6, + 0x42, 0xc1, 0xf4, 0x7c, 0xd3, 0xc9, 0xb0, 0x3e, 0x3b, 0xf6, 0xe0, 0x9e, 0xd5, 0x09, 0x31, 0x04, + 0xe6, 0xa2, 0xa8, 0x4c, 0xbb, 0x6d, 0xda, 0xf7, 0xc4, 0xf0, 0x6f, 0x64, 0x9e, 0x30, 0xe3, 0x32, + 0x19, 0x02, 0x73, 0x51, 0xe8, 0x36, 0xe4, 0x0d, 0x6b, 0x27, 0xa3, 0x4f, 0x00, 0xc7, 0x3f, 0x80, + 0xcd, 0xb3, 0xec, 0xb5, 0x8d, 0x3a, 0xa6, 0x42, 0xa8, 0x2c, 0xaf, 0x63, 0x0a, 0xdf, 0x3c, 0xa6, + 0xac, 0xc6, 0xe6, 0x5a, 0x9a, 0xac, 0xc6, 0xe6, 0x1a, 0xa6, 0x42, 0xf4, 0x77, 0x35, 0x58, 0x4c, + 0xd0, 0xc4, 0x3f, 0x97, 0xad, 0x0d, 0xff, 0xb9, 0x6c, 0xf1, 0x25, 0x84, 0x46, 0xd7, 0x32, 0x53, + 0x9f, 0x16, 0x6c, 0xc7, 0xf0, 0x38, 0xd1, 0x42, 0xff, 0x96, 0x06, 0xa5, 0x48, 0x59, 0x28, 0x0d, + 0xd5, 0x58, 0xf9, 0xac, 0xe8, 0x46, 0xf8, 0x11, 0x08, 0x76, 0xa9, 0xc0, 0x71, 0xfc, 0x7e, 0xab, + 0x1d, 0xde, 0xf2, 0x44, 0xee, 0xb7, 0x28, 0x14, 0x0b, 0x2c, 0x3d, 0x8d, 0x7b, 0x3e, 0xe9, 0xb2, + 0x85, 0x8c, 0x54, 0x89, 0xb2, 0x5b, 0x5e, 0x86, 0x61, 0xe2, 0xa8, 0xcd, 0x10, 0x29, 0xff, 0xc8, + 0x37, 0x27, 0x0c, 0x1a, 0x19, 0x32, 0x1c, 0x3a, 0x0f, 0x79, 0x62, 0xb7, 0x44, 0x80, 0x53, 0x12, + 0x24, 0xf9, 0xcb, 0x76, 0x0b, 0x53, 0xb8, 0x7e, 0x1d, 0x66, 0x1a, 0xa4, 0xe9, 0x12, 0xff, 0x45, + 0x72, 0x30, 0xdc, 0x0d, 0xcc, 0x79, 0x9e, 0xb9, 0xca, 0xa9, 0x0c, 0x69, 0x73, 0x0a, 0xd7, 0xff, + 0x40, 0x83, 0xd8, 0x27, 0x40, 0x90, 0x1e, 0x4b, 0x46, 0x41, 0x32, 0x11, 0xa5, 0x9c, 0xdc, 0x72, + 0x47, 0x9e, 0xdc, 0xd6, 0x01, 0x75, 0x0c, 0xbf, 0xb9, 0x27, 0xd6, 0x47, 0x7c, 0x6d, 0x86, 0xc7, + 0x96, 0x61, 0x11, 0x7a, 0x82, 0x02, 0xa7, 0xb4, 0xd2, 0xbf, 0x93, 0x83, 0x19, 0xe5, 0xcb, 0xab, + 0xc7, 0x0f, 0x7f, 0xf8, 0x8e, 0xa6, 0x1c, 0xd8, 0xf2, 0x23, 0x1e, 0xd8, 0xa2, 0xa7, 0xd4, 0x89, + 0x93, 0x3d, 0xa5, 0x16, 0x32, 0x39, 0xa5, 0xea, 0xdf, 0x9e, 0x80, 0x39, 0xf5, 0x3d, 0xd7, 0x10, + 0x73, 0xfa, 0xf1, 0xc4, 0x9c, 0x8e, 0x18, 0x0c, 0xe7, 0xc7, 0x0d, 0x86, 0x27, 0xc6, 0x0d, 0x86, + 0x0b, 0x0f, 0x10, 0x0c, 0x27, 0x43, 0xd9, 0xc9, 0xa1, 0x43, 0xd9, 0x4f, 0xcb, 0xbc, 0xc2, 0x94, + 0x72, 0x11, 0x17, 0xe6, 0x15, 0x90, 0xba, 0x0c, 0xab, 0x4e, 0x2b, 0x35, 0x3f, 0x53, 0x3c, 0xa6, + 0x5c, 0xc8, 0x4d, 0x4d, 0x03, 0x8c, 0x7e, 0xe4, 0xfd, 0xd0, 0xf0, 0x29, 0x00, 0xfd, 0x8d, 0x1c, + 0x84, 0x1f, 0x53, 0x65, 0x5f, 0x55, 0xf1, 0x22, 0x36, 0x4a, 0x38, 0xf0, 0xf5, 0x71, 0x3f, 0x5d, + 0x14, 0x72, 0x14, 0x79, 0xb4, 0x08, 0x04, 0x2b, 0x12, 0xff, 0x1b, 0x3e, 0xa2, 0x6a, 0xc0, 0x7c, + 0xac, 0x90, 0x2f, 0xf3, 0xbc, 0xfc, 0xb7, 0x72, 0x30, 0x2d, 0x4b, 0x21, 0xa9, 0x59, 0xef, 0xb9, + 0xc1, 0x47, 0x31, 0xa4, 0x59, 0xbf, 0x89, 0x37, 0x30, 0x85, 0xa3, 0x7b, 0x30, 0xb5, 0x47, 0x8c, + 0x16, 0x71, 0x83, 0x7b, 0x85, 0xcd, 0x8c, 0x6a, 0x30, 0xaf, 0x32, 0xae, 0xe1, 0x58, 0xf8, 0x6f, + 0x0f, 0x07, 0xe2, 0xe8, 0x61, 0xdd, 0x37, 0x3b, 0x84, 0x06, 0xb5, 0x11, 0x2b, 0x9a, 0x0f, 0x0f, + 0xeb, 0xdb, 0x0a, 0x16, 0xc7, 0xa8, 0xa9, 0x71, 0xb9, 0xed, 0x39, 0x36, 0x7b, 0xb0, 0x38, 0xa1, + 0x46, 0xf6, 0xeb, 0x8d, 0xeb, 0xd7, 0xd8, 0x7b, 0x45, 0x49, 0x41, 0xa9, 0x4d, 0x56, 0x0a, 0xe6, + 0x12, 0x71, 0xd3, 0xbe, 0x10, 0x16, 0xae, 0x73, 0x38, 0x96, 0x14, 0xfa, 0x4d, 0x98, 0x8f, 0x0d, + 0x24, 0x70, 0x8f, 0x5a, 0xba, 0x7b, 0x1c, 0xea, 0x7f, 0x39, 0xd4, 0xab, 0xef, 0x7d, 0xb0, 0xfc, + 0xc8, 0x77, 0x3f, 0x58, 0x7e, 0xe4, 0x7b, 0x1f, 0x2c, 0x3f, 0xf2, 0xc6, 0x60, 0x59, 0x7b, 0x6f, + 0xb0, 0xac, 0x7d, 0x77, 0xb0, 0xac, 0x7d, 0x6f, 0xb0, 0xac, 0xfd, 0xe3, 0x60, 0x59, 0x7b, 0xf7, + 0x07, 0xcb, 0x8f, 0xbc, 0x5c, 0x0c, 0x26, 0xf3, 0xbf, 0x02, 0x00, 0x00, 0xff, 0xff, 0x85, 0x55, + 0x6d, 0xa5, 0x84, 0x66, 0x00, 0x00, +} + +func (m *ALBTrafficRouting) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ALBTrafficRouting) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ALBTrafficRouting) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.AnnotationPrefix) + copy(dAtA[i:], m.AnnotationPrefix) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.AnnotationPrefix))) + i-- + dAtA[i] = 0x22 + i -= len(m.RootService) + copy(dAtA[i:], m.RootService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.RootService))) + i-- + dAtA[i] = 0x1a + i = encodeVarintGenerated(dAtA, i, uint64(m.ServicePort)) + i-- + dAtA[i] = 0x10 + i -= len(m.Ingress) + copy(dAtA[i:], m.Ingress) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Ingress))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisRun) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRun) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRun) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Status.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisRunArgument) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRunArgument) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRunArgument) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ValueFrom != nil { + { + size, err := m.ValueFrom.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + i -= len(m.Value) + copy(dAtA[i:], m.Value) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Value))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisRunList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRunList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRunList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Items) > 0 { + for iNdEx := len(m.Items) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Items[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + { + size, err := m.ListMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisRunSpec) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRunSpec) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRunSpec) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.Terminate { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + if len(m.Args) > 0 { + for iNdEx := len(m.Args) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Args[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + if len(m.Metrics) > 0 { + for iNdEx := len(m.Metrics) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Metrics[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *AnalysisRunStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisRunStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisRunStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.StartedAt != nil { + { + size, err := m.StartedAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if len(m.MetricResults) > 0 { + for iNdEx := len(m.MetricResults) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.MetricResults[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x12 + i -= len(m.Phase) + copy(dAtA[i:], m.Phase) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Phase))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisTemplate) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisTemplate) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisTemplate) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisTemplateList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisTemplateList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisTemplateList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Items) > 0 { + for iNdEx := len(m.Items) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Items[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + { + size, err := m.ListMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *AnalysisTemplateSpec) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AnalysisTemplateSpec) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AnalysisTemplateSpec) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Args) > 0 { + for iNdEx := len(m.Args) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Args[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + if len(m.Metrics) > 0 { + for iNdEx := len(m.Metrics) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Metrics[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *AntiAffinity) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *AntiAffinity) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *AntiAffinity) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.RequiredDuringSchedulingIgnoredDuringExecution != nil { + { + size, err := m.RequiredDuringSchedulingIgnoredDuringExecution.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.PreferredDuringSchedulingIgnoredDuringExecution != nil { + { + size, err := m.PreferredDuringSchedulingIgnoredDuringExecution.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *Argument) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Argument) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Argument) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ValueFrom != nil { + { + size, err := m.ValueFrom.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if m.Value != nil { + i -= len(*m.Value) + copy(dAtA[i:], *m.Value) + i = encodeVarintGenerated(dAtA, i, uint64(len(*m.Value))) + i-- + dAtA[i] = 0x12 + } + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ArgumentValueFrom) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ArgumentValueFrom) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ArgumentValueFrom) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.FieldRef != nil { + { + size, err := m.FieldRef.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.PodTemplateHashValue != nil { + i -= len(*m.PodTemplateHashValue) + copy(dAtA[i:], *m.PodTemplateHashValue) + i = encodeVarintGenerated(dAtA, i, uint64(len(*m.PodTemplateHashValue))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *BlueGreenStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *BlueGreenStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *BlueGreenStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.PostPromotionAnalysisRunStatus != nil { + { + size, err := m.PostPromotionAnalysisRunStatus.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + if m.PrePromotionAnalysisRunStatus != nil { + { + size, err := m.PrePromotionAnalysisRunStatus.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + i-- + if m.ScaleUpPreviewCheckPoint { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + i -= len(m.ActiveSelector) + copy(dAtA[i:], m.ActiveSelector) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.ActiveSelector))) + i-- + dAtA[i] = 0x12 + i -= len(m.PreviewSelector) + copy(dAtA[i:], m.PreviewSelector) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.PreviewSelector))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *BlueGreenStrategy) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *BlueGreenStrategy) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *BlueGreenStrategy) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ActiveMetadata != nil { + { + size, err := m.ActiveMetadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x6a + } + if m.PreviewMetadata != nil { + { + size, err := m.PreviewMetadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x62 + } + if m.PostPromotionAnalysis != nil { + { + size, err := m.PostPromotionAnalysis.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x5a + } + if m.AntiAffinity != nil { + { + size, err := m.AntiAffinity.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x52 + } + if m.PrePromotionAnalysis != nil { + { + size, err := m.PrePromotionAnalysis.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + if m.ScaleDownDelayRevisionLimit != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.ScaleDownDelayRevisionLimit)) + i-- + dAtA[i] = 0x40 + } + if m.ScaleDownDelaySeconds != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.ScaleDownDelaySeconds)) + i-- + dAtA[i] = 0x38 + } + if m.MaxUnavailable != nil { + { + size, err := m.MaxUnavailable.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x32 + } + i = encodeVarintGenerated(dAtA, i, uint64(m.AutoPromotionSeconds)) + i-- + dAtA[i] = 0x28 + if m.AutoPromotionEnabled != nil { + i-- + if *m.AutoPromotionEnabled { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x20 + } + if m.PreviewReplicaCount != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.PreviewReplicaCount)) + i-- + dAtA[i] = 0x18 + } + i -= len(m.PreviewService) + copy(dAtA[i:], m.PreviewService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.PreviewService))) + i-- + dAtA[i] = 0x12 + i -= len(m.ActiveService) + copy(dAtA[i:], m.ActiveService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.ActiveService))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *CanaryStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *CanaryStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *CanaryStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.CurrentExperiment) + copy(dAtA[i:], m.CurrentExperiment) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CurrentExperiment))) + i-- + dAtA[i] = 0x1a + if m.CurrentBackgroundAnalysisRunStatus != nil { + { + size, err := m.CurrentBackgroundAnalysisRunStatus.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.CurrentStepAnalysisRunStatus != nil { + { + size, err := m.CurrentStepAnalysisRunStatus.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *CanaryStep) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *CanaryStep) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *CanaryStep) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.SetCanaryScale != nil { + { + size, err := m.SetCanaryScale.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + if m.Analysis != nil { + { + size, err := m.Analysis.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if m.Experiment != nil { + { + size, err := m.Experiment.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if m.Pause != nil { + { + size, err := m.Pause.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.SetWeight != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.SetWeight)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + +func (m *CanaryStrategy) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *CanaryStrategy) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *CanaryStrategy) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.StableMetadata != nil { + { + size, err := m.StableMetadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x52 + } + if m.CanaryMetadata != nil { + { + size, err := m.CanaryMetadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + if m.AntiAffinity != nil { + { + size, err := m.AntiAffinity.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x42 + } + if m.Analysis != nil { + { + size, err := m.Analysis.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } + if m.MaxSurge != nil { + { + size, err := m.MaxSurge.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x32 + } + if m.MaxUnavailable != nil { + { + size, err := m.MaxUnavailable.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + if m.TrafficRouting != nil { + { + size, err := m.TrafficRouting.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if len(m.Steps) > 0 { + for iNdEx := len(m.Steps) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Steps[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.StableService) + copy(dAtA[i:], m.StableService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.StableService))) + i-- + dAtA[i] = 0x12 + i -= len(m.CanaryService) + copy(dAtA[i:], m.CanaryService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CanaryService))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ClusterAnalysisTemplate) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ClusterAnalysisTemplate) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ClusterAnalysisTemplate) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ClusterAnalysisTemplateList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ClusterAnalysisTemplateList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ClusterAnalysisTemplateList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Items) > 0 { + for iNdEx := len(m.Items) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Items[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + { + size, err := m.ListMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *DatadogMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *DatadogMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *DatadogMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Query) + copy(dAtA[i:], m.Query) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Query))) + i-- + dAtA[i] = 0x12 + i -= len(m.Interval) + copy(dAtA[i:], m.Interval) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Interval))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *Experiment) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Experiment) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Experiment) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Status.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ExperimentAnalysisRunStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentAnalysisRunStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentAnalysisRunStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x22 + i -= len(m.Phase) + copy(dAtA[i:], m.Phase) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Phase))) + i-- + dAtA[i] = 0x1a + i -= len(m.AnalysisRun) + copy(dAtA[i:], m.AnalysisRun) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.AnalysisRun))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ExperimentAnalysisTemplateRef) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentAnalysisTemplateRef) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentAnalysisTemplateRef) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.RequiredForCompletion { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x28 + if len(m.Args) > 0 { + for iNdEx := len(m.Args) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Args[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + } + i-- + if m.ClusterScope { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + i -= len(m.TemplateName) + copy(dAtA[i:], m.TemplateName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.TemplateName))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ExperimentCondition) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentCondition) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentCondition) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x32 + i -= len(m.Reason) + copy(dAtA[i:], m.Reason) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Reason))) + i-- + dAtA[i] = 0x2a + { + size, err := m.LastTransitionTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + { + size, err := m.LastUpdateTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + i -= len(m.Type) + copy(dAtA[i:], m.Type) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Type))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ExperimentList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Items) > 0 { + for iNdEx := len(m.Items) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Items[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + { + size, err := m.ListMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ExperimentSpec) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentSpec) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentSpec) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Analyses) > 0 { + for iNdEx := len(m.Analyses) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Analyses[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + } + i-- + if m.Terminate { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x20 + if m.ProgressDeadlineSeconds != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.ProgressDeadlineSeconds)) + i-- + dAtA[i] = 0x18 + } + i -= len(m.Duration) + copy(dAtA[i:], m.Duration) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Duration))) + i-- + dAtA[i] = 0x12 + if len(m.Templates) > 0 { + for iNdEx := len(m.Templates) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Templates[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *ExperimentStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ExperimentStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ExperimentStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.AnalysisRuns) > 0 { + for iNdEx := len(m.AnalysisRuns) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.AnalysisRuns[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x32 + } + } + if len(m.Conditions) > 0 { + for iNdEx := len(m.Conditions) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Conditions[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + } + if m.AvailableAt != nil { + { + size, err := m.AvailableAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if len(m.TemplateStatuses) > 0 { + for iNdEx := len(m.TemplateStatuses) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.TemplateStatuses[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x12 + i -= len(m.Phase) + copy(dAtA[i:], m.Phase) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Phase))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *FieldRef) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *FieldRef) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *FieldRef) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.FieldPath) + copy(dAtA[i:], m.FieldPath) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.FieldPath))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *IstioDestinationRule) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *IstioDestinationRule) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *IstioDestinationRule) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.StableSubsetName) + copy(dAtA[i:], m.StableSubsetName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.StableSubsetName))) + i-- + dAtA[i] = 0x1a + i -= len(m.CanarySubsetName) + copy(dAtA[i:], m.CanarySubsetName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CanarySubsetName))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *IstioTrafficRouting) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *IstioTrafficRouting) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *IstioTrafficRouting) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.DestinationRule != nil { + { + size, err := m.DestinationRule.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + { + size, err := m.VirtualService.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *IstioVirtualService) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *IstioVirtualService) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *IstioVirtualService) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Routes) > 0 { + for iNdEx := len(m.Routes) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Routes[iNdEx]) + copy(dAtA[i:], m.Routes[iNdEx]) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Routes[iNdEx]))) + i-- + dAtA[i] = 0x12 + } + } + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *JobMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *JobMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *JobMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.Metadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *KayentaMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *KayentaMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *KayentaMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Scopes) > 0 { + for iNdEx := len(m.Scopes) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Scopes[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x42 + } + } + { + size, err := m.Threshold.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + i -= len(m.StorageAccountName) + copy(dAtA[i:], m.StorageAccountName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.StorageAccountName))) + i-- + dAtA[i] = 0x32 + i -= len(m.ConfigurationAccountName) + copy(dAtA[i:], m.ConfigurationAccountName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.ConfigurationAccountName))) + i-- + dAtA[i] = 0x2a + i -= len(m.MetricsAccountName) + copy(dAtA[i:], m.MetricsAccountName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.MetricsAccountName))) + i-- + dAtA[i] = 0x22 + i -= len(m.CanaryConfigName) + copy(dAtA[i:], m.CanaryConfigName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CanaryConfigName))) + i-- + dAtA[i] = 0x1a + i -= len(m.Application) + copy(dAtA[i:], m.Application) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Application))) + i-- + dAtA[i] = 0x12 + i -= len(m.Address) + copy(dAtA[i:], m.Address) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Address))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *KayentaScope) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *KayentaScope) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *KayentaScope) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.ExperimentScope.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.ControlScope.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *KayentaThreshold) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *KayentaThreshold) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *KayentaThreshold) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i = encodeVarintGenerated(dAtA, i, uint64(m.Marginal)) + i-- + dAtA[i] = 0x10 + i = encodeVarintGenerated(dAtA, i, uint64(m.Pass)) + i-- + dAtA[i] = 0x8 + return len(dAtA) - i, nil +} + +func (m *Measurement) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Measurement) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Measurement) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ResumeAt != nil { + { + size, err := m.ResumeAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } + if len(m.Metadata) > 0 { + keysForMetadata := make([]string, 0, len(m.Metadata)) + for k := range m.Metadata { + keysForMetadata = append(keysForMetadata, string(k)) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForMetadata) + for iNdEx := len(keysForMetadata) - 1; iNdEx >= 0; iNdEx-- { + v := m.Metadata[string(keysForMetadata[iNdEx])] + baseI := i + i -= len(v) + copy(dAtA[i:], v) + i = encodeVarintGenerated(dAtA, i, uint64(len(v))) + i-- + dAtA[i] = 0x12 + i -= len(keysForMetadata[iNdEx]) + copy(dAtA[i:], keysForMetadata[iNdEx]) + i = encodeVarintGenerated(dAtA, i, uint64(len(keysForMetadata[iNdEx]))) + i-- + dAtA[i] = 0xa + i = encodeVarintGenerated(dAtA, i, uint64(baseI-i)) + i-- + dAtA[i] = 0x32 + } + } + i -= len(m.Value) + copy(dAtA[i:], m.Value) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Value))) + i-- + dAtA[i] = 0x2a + if m.FinishedAt != nil { + { + size, err := m.FinishedAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if m.StartedAt != nil { + { + size, err := m.StartedAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x12 + i -= len(m.Phase) + copy(dAtA[i:], m.Phase) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Phase))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *Metric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Metric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Metric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Provider.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x52 + if m.ConsecutiveErrorLimit != nil { + { + size, err := m.ConsecutiveErrorLimit.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + if m.InconclusiveLimit != nil { + { + size, err := m.InconclusiveLimit.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x42 + } + if m.FailureLimit != nil { + { + size, err := m.FailureLimit.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } + i -= len(m.FailureCondition) + copy(dAtA[i:], m.FailureCondition) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.FailureCondition))) + i-- + dAtA[i] = 0x32 + i -= len(m.SuccessCondition) + copy(dAtA[i:], m.SuccessCondition) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.SuccessCondition))) + i-- + dAtA[i] = 0x2a + if m.Count != nil { + { + size, err := m.Count.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + i -= len(m.InitialDelay) + copy(dAtA[i:], m.InitialDelay) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.InitialDelay))) + i-- + dAtA[i] = 0x1a + i -= len(m.Interval) + copy(dAtA[i:], m.Interval) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Interval))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *MetricProvider) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *MetricProvider) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MetricProvider) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Job != nil { + { + size, err := m.Job.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } + if m.NewRelic != nil { + { + size, err := m.NewRelic.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x32 + } + if m.Wavefront != nil { + { + size, err := m.Wavefront.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + if m.Datadog != nil { + { + size, err := m.Datadog.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if m.Web != nil { + { + size, err := m.Web.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if m.Kayenta != nil { + { + size, err := m.Kayenta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.Prometheus != nil { + { + size, err := m.Prometheus.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *MetricResult) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *MetricResult) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MetricResult) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i = encodeVarintGenerated(dAtA, i, uint64(m.ConsecutiveError)) + i-- + dAtA[i] = 0x50 + i = encodeVarintGenerated(dAtA, i, uint64(m.Error)) + i-- + dAtA[i] = 0x48 + i = encodeVarintGenerated(dAtA, i, uint64(m.Inconclusive)) + i-- + dAtA[i] = 0x40 + i = encodeVarintGenerated(dAtA, i, uint64(m.Failed)) + i-- + dAtA[i] = 0x38 + i = encodeVarintGenerated(dAtA, i, uint64(m.Successful)) + i-- + dAtA[i] = 0x30 + i = encodeVarintGenerated(dAtA, i, uint64(m.Count)) + i-- + dAtA[i] = 0x28 + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x22 + if len(m.Measurements) > 0 { + for iNdEx := len(m.Measurements) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Measurements[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.Phase) + copy(dAtA[i:], m.Phase) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Phase))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *NewRelicMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *NewRelicMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *NewRelicMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Query) + copy(dAtA[i:], m.Query) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Query))) + i-- + dAtA[i] = 0x12 + i -= len(m.Profile) + copy(dAtA[i:], m.Profile) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Profile))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *NginxTrafficRouting) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *NginxTrafficRouting) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *NginxTrafficRouting) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.AdditionalIngressAnnotations) > 0 { + keysForAdditionalIngressAnnotations := make([]string, 0, len(m.AdditionalIngressAnnotations)) + for k := range m.AdditionalIngressAnnotations { + keysForAdditionalIngressAnnotations = append(keysForAdditionalIngressAnnotations, string(k)) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForAdditionalIngressAnnotations) + for iNdEx := len(keysForAdditionalIngressAnnotations) - 1; iNdEx >= 0; iNdEx-- { + v := m.AdditionalIngressAnnotations[string(keysForAdditionalIngressAnnotations[iNdEx])] + baseI := i + i -= len(v) + copy(dAtA[i:], v) + i = encodeVarintGenerated(dAtA, i, uint64(len(v))) + i-- + dAtA[i] = 0x12 + i -= len(keysForAdditionalIngressAnnotations[iNdEx]) + copy(dAtA[i:], keysForAdditionalIngressAnnotations[iNdEx]) + i = encodeVarintGenerated(dAtA, i, uint64(len(keysForAdditionalIngressAnnotations[iNdEx]))) + i-- + dAtA[i] = 0xa + i = encodeVarintGenerated(dAtA, i, uint64(baseI-i)) + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.StableIngress) + copy(dAtA[i:], m.StableIngress) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.StableIngress))) + i-- + dAtA[i] = 0x12 + i -= len(m.AnnotationPrefix) + copy(dAtA[i:], m.AnnotationPrefix) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.AnnotationPrefix))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *PauseCondition) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PauseCondition) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PauseCondition) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.StartTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + i -= len(m.Reason) + copy(dAtA[i:], m.Reason) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Reason))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *PodTemplateMetadata) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PodTemplateMetadata) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PodTemplateMetadata) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Annotations) > 0 { + keysForAnnotations := make([]string, 0, len(m.Annotations)) + for k := range m.Annotations { + keysForAnnotations = append(keysForAnnotations, string(k)) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForAnnotations) + for iNdEx := len(keysForAnnotations) - 1; iNdEx >= 0; iNdEx-- { + v := m.Annotations[string(keysForAnnotations[iNdEx])] + baseI := i + i -= len(v) + copy(dAtA[i:], v) + i = encodeVarintGenerated(dAtA, i, uint64(len(v))) + i-- + dAtA[i] = 0x12 + i -= len(keysForAnnotations[iNdEx]) + copy(dAtA[i:], keysForAnnotations[iNdEx]) + i = encodeVarintGenerated(dAtA, i, uint64(len(keysForAnnotations[iNdEx]))) + i-- + dAtA[i] = 0xa + i = encodeVarintGenerated(dAtA, i, uint64(baseI-i)) + i-- + dAtA[i] = 0x12 + } + } + if len(m.Labels) > 0 { + keysForLabels := make([]string, 0, len(m.Labels)) + for k := range m.Labels { + keysForLabels = append(keysForLabels, string(k)) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForLabels) + for iNdEx := len(keysForLabels) - 1; iNdEx >= 0; iNdEx-- { + v := m.Labels[string(keysForLabels[iNdEx])] + baseI := i + i -= len(v) + copy(dAtA[i:], v) + i = encodeVarintGenerated(dAtA, i, uint64(len(v))) + i-- + dAtA[i] = 0x12 + i -= len(keysForLabels[iNdEx]) + copy(dAtA[i:], keysForLabels[iNdEx]) + i = encodeVarintGenerated(dAtA, i, uint64(len(keysForLabels[iNdEx]))) + i-- + dAtA[i] = 0xa + i = encodeVarintGenerated(dAtA, i, uint64(baseI-i)) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *PreferredDuringSchedulingIgnoredDuringExecution) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PreferredDuringSchedulingIgnoredDuringExecution) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PreferredDuringSchedulingIgnoredDuringExecution) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i = encodeVarintGenerated(dAtA, i, uint64(m.Weight)) + i-- + dAtA[i] = 0x8 + return len(dAtA) - i, nil +} + +func (m *PrometheusMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PrometheusMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PrometheusMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Query) + copy(dAtA[i:], m.Query) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Query))) + i-- + dAtA[i] = 0x12 + i -= len(m.Address) + copy(dAtA[i:], m.Address) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Address))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RequiredDuringSchedulingIgnoredDuringExecution) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RequiredDuringSchedulingIgnoredDuringExecution) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RequiredDuringSchedulingIgnoredDuringExecution) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *Rollout) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Rollout) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Rollout) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Status.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.Spec.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.ObjectMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutAnalysis) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutAnalysis) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutAnalysis) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Args) > 0 { + for iNdEx := len(m.Args) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Args[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + if len(m.Templates) > 0 { + for iNdEx := len(m.Templates) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Templates[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *RolloutAnalysisBackground) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutAnalysisBackground) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutAnalysisBackground) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.StartingStep != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.StartingStep)) + i-- + dAtA[i] = 0x10 + } + { + size, err := m.RolloutAnalysis.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutAnalysisRunStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutAnalysisRunStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutAnalysisRunStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x1a + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutAnalysisTemplate) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutAnalysisTemplate) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutAnalysisTemplate) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.ClusterScope { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x10 + i -= len(m.TemplateName) + copy(dAtA[i:], m.TemplateName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.TemplateName))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutCondition) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutCondition) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutCondition) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x32 + i -= len(m.Reason) + copy(dAtA[i:], m.Reason) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Reason))) + i-- + dAtA[i] = 0x2a + { + size, err := m.LastTransitionTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + { + size, err := m.LastUpdateTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x12 + i -= len(m.Type) + copy(dAtA[i:], m.Type) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Type))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutExperimentStep) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutExperimentStep) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutExperimentStep) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Analyses) > 0 { + for iNdEx := len(m.Analyses) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Analyses[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + } + i -= len(m.Duration) + copy(dAtA[i:], m.Duration) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Duration))) + i-- + dAtA[i] = 0x12 + if len(m.Templates) > 0 { + for iNdEx := len(m.Templates) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Templates[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func (m *RolloutExperimentStepAnalysisTemplateRef) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutExperimentStepAnalysisTemplateRef) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutExperimentStepAnalysisTemplateRef) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.RequiredForCompletion { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x28 + if len(m.Args) > 0 { + for iNdEx := len(m.Args) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Args[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + } + i-- + if m.ClusterScope { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + i -= len(m.TemplateName) + copy(dAtA[i:], m.TemplateName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.TemplateName))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutExperimentTemplate) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutExperimentTemplate) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutExperimentTemplate) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Selector != nil { + { + size, err := m.Selector.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + } + { + size, err := m.Metadata.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + if m.Replicas != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.Replicas)) + i-- + dAtA[i] = 0x18 + } + i -= len(m.SpecRef) + copy(dAtA[i:], m.SpecRef) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.SpecRef))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutList) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutList) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutList) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Items) > 0 { + for iNdEx := len(m.Items) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Items[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + { + size, err := m.ListMeta.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *RolloutPause) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutPause) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutPause) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Duration != nil { + { + size, err := m.Duration.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutSpec) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutSpec) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutSpec) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.RestartAt != nil { + { + size, err := m.RestartAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + if m.ProgressDeadlineSeconds != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.ProgressDeadlineSeconds)) + i-- + dAtA[i] = 0x40 + } + i-- + if m.Paused { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x38 + if m.RevisionHistoryLimit != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.RevisionHistoryLimit)) + i-- + dAtA[i] = 0x30 + } + { + size, err := m.Strategy.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + i = encodeVarintGenerated(dAtA, i, uint64(m.MinReadySeconds)) + i-- + dAtA[i] = 0x20 + { + size, err := m.Template.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + if m.Selector != nil { + { + size, err := m.Selector.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.Replicas != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.Replicas)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + +func (m *RolloutStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.PromoteFull { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0xa8 + if m.RestartedAt != nil { + { + size, err := m.RestartedAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0xa2 + } + i -= len(m.StableRS) + copy(dAtA[i:], m.StableRS) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.StableRS))) + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x9a + i -= len(m.Selector) + copy(dAtA[i:], m.Selector) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Selector))) + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x92 + i = encodeVarintGenerated(dAtA, i, uint64(m.HPAReplicas)) + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x88 + { + size, err := m.BlueGreen.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x82 + { + size, err := m.Canary.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x7a + if len(m.Conditions) > 0 { + for iNdEx := len(m.Conditions) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Conditions[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x72 + } + } + i -= len(m.ObservedGeneration) + copy(dAtA[i:], m.ObservedGeneration) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.ObservedGeneration))) + i-- + dAtA[i] = 0x6a + if m.CollisionCount != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.CollisionCount)) + i-- + dAtA[i] = 0x60 + } + if m.CurrentStepIndex != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.CurrentStepIndex)) + i-- + dAtA[i] = 0x58 + } + i = encodeVarintGenerated(dAtA, i, uint64(m.AvailableReplicas)) + i-- + dAtA[i] = 0x50 + i = encodeVarintGenerated(dAtA, i, uint64(m.ReadyReplicas)) + i-- + dAtA[i] = 0x48 + i = encodeVarintGenerated(dAtA, i, uint64(m.UpdatedReplicas)) + i-- + dAtA[i] = 0x40 + i = encodeVarintGenerated(dAtA, i, uint64(m.Replicas)) + i-- + dAtA[i] = 0x38 + i -= len(m.CurrentStepHash) + copy(dAtA[i:], m.CurrentStepHash) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CurrentStepHash))) + i-- + dAtA[i] = 0x32 + i -= len(m.CurrentPodHash) + copy(dAtA[i:], m.CurrentPodHash) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.CurrentPodHash))) + i-- + dAtA[i] = 0x2a + if m.AbortedAt != nil { + { + size, err := m.AbortedAt.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + i-- + if m.ControllerPause { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + if len(m.PauseConditions) > 0 { + for iNdEx := len(m.PauseConditions) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.PauseConditions[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + i-- + if m.Abort { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x8 + return len(dAtA) - i, nil +} + +func (m *RolloutStrategy) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutStrategy) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutStrategy) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Canary != nil { + { + size, err := m.Canary.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.BlueGreen != nil { + { + size, err := m.BlueGreen.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *RolloutTrafficRouting) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *RolloutTrafficRouting) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *RolloutTrafficRouting) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.SMI != nil { + { + size, err := m.SMI.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + if m.ALB != nil { + { + size, err := m.ALB.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if m.Nginx != nil { + { + size, err := m.Nginx.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.Istio != nil { + { + size, err := m.Istio.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *SMITrafficRouting) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *SMITrafficRouting) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *SMITrafficRouting) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.TrafficSplitName) + copy(dAtA[i:], m.TrafficSplitName) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.TrafficSplitName))) + i-- + dAtA[i] = 0x12 + i -= len(m.RootService) + copy(dAtA[i:], m.RootService) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.RootService))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ScopeDetail) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ScopeDetail) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ScopeDetail) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.End) + copy(dAtA[i:], m.End) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.End))) + i-- + dAtA[i] = 0x2a + i -= len(m.Start) + copy(dAtA[i:], m.Start) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Start))) + i-- + dAtA[i] = 0x22 + i = encodeVarintGenerated(dAtA, i, uint64(m.Step)) + i-- + dAtA[i] = 0x18 + i -= len(m.Region) + copy(dAtA[i:], m.Region) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Region))) + i-- + dAtA[i] = 0x12 + i -= len(m.Scope) + copy(dAtA[i:], m.Scope) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Scope))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *SecretKeyRef) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *SecretKeyRef) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *SecretKeyRef) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Key) + copy(dAtA[i:], m.Key) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Key))) + i-- + dAtA[i] = 0x12 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *SetCanaryScale) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *SetCanaryScale) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *SetCanaryScale) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.MatchTrafficWeight { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + if m.Replicas != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.Replicas)) + i-- + dAtA[i] = 0x10 + } + if m.Weight != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.Weight)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + +func (m *TemplateSpec) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TemplateSpec) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TemplateSpec) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Template.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + if m.Selector != nil { + { + size, err := m.Selector.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } + i = encodeVarintGenerated(dAtA, i, uint64(m.MinReadySeconds)) + i-- + dAtA[i] = 0x18 + if m.Replicas != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.Replicas)) + i-- + dAtA[i] = 0x10 + } + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *TemplateStatus) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TemplateStatus) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TemplateStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.LastTransitionTime != nil { + { + size, err := m.LastTransitionTime.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + i -= len(m.Message) + copy(dAtA[i:], m.Message) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Message))) + i-- + dAtA[i] = 0x42 + i -= len(m.Status) + copy(dAtA[i:], m.Status) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Status))) + i-- + dAtA[i] = 0x3a + if m.CollisionCount != nil { + i = encodeVarintGenerated(dAtA, i, uint64(*m.CollisionCount)) + i-- + dAtA[i] = 0x30 + } + i = encodeVarintGenerated(dAtA, i, uint64(m.AvailableReplicas)) + i-- + dAtA[i] = 0x28 + i = encodeVarintGenerated(dAtA, i, uint64(m.ReadyReplicas)) + i-- + dAtA[i] = 0x20 + i = encodeVarintGenerated(dAtA, i, uint64(m.UpdatedReplicas)) + i-- + dAtA[i] = 0x18 + i = encodeVarintGenerated(dAtA, i, uint64(m.Replicas)) + i-- + dAtA[i] = 0x10 + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *ValueFrom) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ValueFrom) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ValueFrom) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.FieldRef != nil { + { + size, err := m.FieldRef.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.SecretKeyRef != nil { + { + size, err := m.SecretKeyRef.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *WavefrontMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *WavefrontMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *WavefrontMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Query) + copy(dAtA[i:], m.Query) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Query))) + i-- + dAtA[i] = 0x12 + i -= len(m.Address) + copy(dAtA[i:], m.Address) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Address))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *WebMetric) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *WebMetric) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *WebMetric) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i-- + if m.Insecure { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x28 + i -= len(m.JSONPath) + copy(dAtA[i:], m.JSONPath) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.JSONPath))) + i-- + dAtA[i] = 0x22 + i = encodeVarintGenerated(dAtA, i, uint64(m.TimeoutSeconds)) + i-- + dAtA[i] = 0x18 + if len(m.Headers) > 0 { + for iNdEx := len(m.Headers) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Headers[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenerated(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + i -= len(m.URL) + copy(dAtA[i:], m.URL) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.URL))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *WebMetricHeader) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *WebMetricHeader) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *WebMetricHeader) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + i -= len(m.Value) + copy(dAtA[i:], m.Value) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Value))) + i-- + dAtA[i] = 0x12 + i -= len(m.Key) + copy(dAtA[i:], m.Key) + i = encodeVarintGenerated(dAtA, i, uint64(len(m.Key))) + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func encodeVarintGenerated(dAtA []byte, offset int, v uint64) int { + offset -= sovGenerated(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *ALBTrafficRouting) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Ingress) + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.ServicePort)) + l = len(m.RootService) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.AnnotationPrefix) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *AnalysisRun) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ObjectMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Status.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *AnalysisRunArgument) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Value) + n += 1 + l + sovGenerated(uint64(l)) + if m.ValueFrom != nil { + l = m.ValueFrom.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *AnalysisRunList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ListMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Items) > 0 { + for _, e := range m.Items { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *AnalysisRunSpec) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Metrics) > 0 { + for _, e := range m.Metrics { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if len(m.Args) > 0 { + for _, e := range m.Args { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + n += 2 + return n +} + +func (m *AnalysisRunStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Phase) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.MetricResults) > 0 { + for _, e := range m.MetricResults { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if m.StartedAt != nil { + l = m.StartedAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *AnalysisTemplate) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ObjectMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *AnalysisTemplateList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ListMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Items) > 0 { + for _, e := range m.Items { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *AnalysisTemplateSpec) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Metrics) > 0 { + for _, e := range m.Metrics { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if len(m.Args) > 0 { + for _, e := range m.Args { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *AntiAffinity) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.PreferredDuringSchedulingIgnoredDuringExecution != nil { + l = m.PreferredDuringSchedulingIgnoredDuringExecution.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.RequiredDuringSchedulingIgnoredDuringExecution != nil { + l = m.RequiredDuringSchedulingIgnoredDuringExecution.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *Argument) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + if m.Value != nil { + l = len(*m.Value) + n += 1 + l + sovGenerated(uint64(l)) + } + if m.ValueFrom != nil { + l = m.ValueFrom.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *ArgumentValueFrom) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.PodTemplateHashValue != nil { + l = len(*m.PodTemplateHashValue) + n += 1 + l + sovGenerated(uint64(l)) + } + if m.FieldRef != nil { + l = m.FieldRef.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *BlueGreenStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.PreviewSelector) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.ActiveSelector) + n += 1 + l + sovGenerated(uint64(l)) + n += 2 + if m.PrePromotionAnalysisRunStatus != nil { + l = m.PrePromotionAnalysisRunStatus.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.PostPromotionAnalysisRunStatus != nil { + l = m.PostPromotionAnalysisRunStatus.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *BlueGreenStrategy) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.ActiveService) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.PreviewService) + n += 1 + l + sovGenerated(uint64(l)) + if m.PreviewReplicaCount != nil { + n += 1 + sovGenerated(uint64(*m.PreviewReplicaCount)) + } + if m.AutoPromotionEnabled != nil { + n += 2 + } + n += 1 + sovGenerated(uint64(m.AutoPromotionSeconds)) + if m.MaxUnavailable != nil { + l = m.MaxUnavailable.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.ScaleDownDelaySeconds != nil { + n += 1 + sovGenerated(uint64(*m.ScaleDownDelaySeconds)) + } + if m.ScaleDownDelayRevisionLimit != nil { + n += 1 + sovGenerated(uint64(*m.ScaleDownDelayRevisionLimit)) + } + if m.PrePromotionAnalysis != nil { + l = m.PrePromotionAnalysis.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.AntiAffinity != nil { + l = m.AntiAffinity.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.PostPromotionAnalysis != nil { + l = m.PostPromotionAnalysis.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.PreviewMetadata != nil { + l = m.PreviewMetadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.ActiveMetadata != nil { + l = m.ActiveMetadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *CanaryStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.CurrentStepAnalysisRunStatus != nil { + l = m.CurrentStepAnalysisRunStatus.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.CurrentBackgroundAnalysisRunStatus != nil { + l = m.CurrentBackgroundAnalysisRunStatus.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = len(m.CurrentExperiment) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *CanaryStep) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.SetWeight != nil { + n += 1 + sovGenerated(uint64(*m.SetWeight)) + } + if m.Pause != nil { + l = m.Pause.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Experiment != nil { + l = m.Experiment.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Analysis != nil { + l = m.Analysis.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.SetCanaryScale != nil { + l = m.SetCanaryScale.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *CanaryStrategy) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.CanaryService) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.StableService) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Steps) > 0 { + for _, e := range m.Steps { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if m.TrafficRouting != nil { + l = m.TrafficRouting.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.MaxUnavailable != nil { + l = m.MaxUnavailable.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.MaxSurge != nil { + l = m.MaxSurge.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Analysis != nil { + l = m.Analysis.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.AntiAffinity != nil { + l = m.AntiAffinity.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.CanaryMetadata != nil { + l = m.CanaryMetadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.StableMetadata != nil { + l = m.StableMetadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *ClusterAnalysisTemplate) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ObjectMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *ClusterAnalysisTemplateList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ListMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Items) > 0 { + for _, e := range m.Items { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *DatadogMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Interval) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Query) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *Experiment) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ObjectMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Status.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *ExperimentAnalysisRunStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.AnalysisRun) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Phase) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *ExperimentAnalysisTemplateRef) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.TemplateName) + n += 1 + l + sovGenerated(uint64(l)) + n += 2 + if len(m.Args) > 0 { + for _, e := range m.Args { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + n += 2 + return n +} + +func (m *ExperimentCondition) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Type) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Status) + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastUpdateTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastTransitionTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Reason) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *ExperimentList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ListMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Items) > 0 { + for _, e := range m.Items { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *ExperimentSpec) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Templates) > 0 { + for _, e := range m.Templates { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + l = len(m.Duration) + n += 1 + l + sovGenerated(uint64(l)) + if m.ProgressDeadlineSeconds != nil { + n += 1 + sovGenerated(uint64(*m.ProgressDeadlineSeconds)) + } + n += 2 + if len(m.Analyses) > 0 { + for _, e := range m.Analyses { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *ExperimentStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Phase) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.TemplateStatuses) > 0 { + for _, e := range m.TemplateStatuses { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if m.AvailableAt != nil { + l = m.AvailableAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if len(m.Conditions) > 0 { + for _, e := range m.Conditions { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if len(m.AnalysisRuns) > 0 { + for _, e := range m.AnalysisRuns { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *FieldRef) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.FieldPath) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *IstioDestinationRule) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.CanarySubsetName) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.StableSubsetName) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *IstioTrafficRouting) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.VirtualService.Size() + n += 1 + l + sovGenerated(uint64(l)) + if m.DestinationRule != nil { + l = m.DestinationRule.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *IstioVirtualService) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Routes) > 0 { + for _, s := range m.Routes { + l = len(s) + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *JobMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.Metadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *KayentaMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Address) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Application) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.CanaryConfigName) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.MetricsAccountName) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.ConfigurationAccountName) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.StorageAccountName) + n += 1 + l + sovGenerated(uint64(l)) + l = m.Threshold.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Scopes) > 0 { + for _, e := range m.Scopes { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *KayentaScope) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = m.ControlScope.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.ExperimentScope.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *KayentaThreshold) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + n += 1 + sovGenerated(uint64(m.Pass)) + n += 1 + sovGenerated(uint64(m.Marginal)) + return n +} + +func (m *Measurement) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Phase) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + if m.StartedAt != nil { + l = m.StartedAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.FinishedAt != nil { + l = m.FinishedAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = len(m.Value) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Metadata) > 0 { + for k, v := range m.Metadata { + _ = k + _ = v + mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) + n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) + } + } + if m.ResumeAt != nil { + l = m.ResumeAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *Metric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Interval) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.InitialDelay) + n += 1 + l + sovGenerated(uint64(l)) + if m.Count != nil { + l = m.Count.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = len(m.SuccessCondition) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.FailureCondition) + n += 1 + l + sovGenerated(uint64(l)) + if m.FailureLimit != nil { + l = m.FailureLimit.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.InconclusiveLimit != nil { + l = m.InconclusiveLimit.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.ConsecutiveErrorLimit != nil { + l = m.ConsecutiveErrorLimit.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = m.Provider.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *MetricProvider) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Prometheus != nil { + l = m.Prometheus.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Kayenta != nil { + l = m.Kayenta.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Web != nil { + l = m.Web.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Datadog != nil { + l = m.Datadog.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Wavefront != nil { + l = m.Wavefront.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.NewRelic != nil { + l = m.NewRelic.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Job != nil { + l = m.Job.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *MetricResult) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Phase) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Measurements) > 0 { + for _, e := range m.Measurements { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.Count)) + n += 1 + sovGenerated(uint64(m.Successful)) + n += 1 + sovGenerated(uint64(m.Failed)) + n += 1 + sovGenerated(uint64(m.Inconclusive)) + n += 1 + sovGenerated(uint64(m.Error)) + n += 1 + sovGenerated(uint64(m.ConsecutiveError)) + return n +} + +func (m *NewRelicMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Profile) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Query) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *NginxTrafficRouting) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.AnnotationPrefix) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.StableIngress) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.AdditionalIngressAnnotations) > 0 { + for k, v := range m.AdditionalIngressAnnotations { + _ = k + _ = v + mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) + n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) + } + } + return n +} + +func (m *PauseCondition) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Reason) + n += 1 + l + sovGenerated(uint64(l)) + l = m.StartTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *PodTemplateMetadata) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Labels) > 0 { + for k, v := range m.Labels { + _ = k + _ = v + mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) + n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) + } + } + if len(m.Annotations) > 0 { + for k, v := range m.Annotations { + _ = k + _ = v + mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) + n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) + } + } + return n +} + +func (m *PreferredDuringSchedulingIgnoredDuringExecution) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + n += 1 + sovGenerated(uint64(m.Weight)) + return n +} + +func (m *PrometheusMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Address) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Query) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *RequiredDuringSchedulingIgnoredDuringExecution) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *Rollout) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ObjectMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Spec.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.Status.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *RolloutAnalysis) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Templates) > 0 { + for _, e := range m.Templates { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + if len(m.Args) > 0 { + for _, e := range m.Args { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *RolloutAnalysisBackground) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.RolloutAnalysis.Size() + n += 1 + l + sovGenerated(uint64(l)) + if m.StartingStep != nil { + n += 1 + sovGenerated(uint64(*m.StartingStep)) + } + return n +} + +func (m *RolloutAnalysisRunStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Status) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *RolloutAnalysisTemplate) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.TemplateName) + n += 1 + l + sovGenerated(uint64(l)) + n += 2 + return n +} + +func (m *RolloutCondition) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Type) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Status) + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastUpdateTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastTransitionTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Reason) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *RolloutExperimentStep) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Templates) > 0 { + for _, e := range m.Templates { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + l = len(m.Duration) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Analyses) > 0 { + for _, e := range m.Analyses { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *RolloutExperimentStepAnalysisTemplateRef) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.TemplateName) + n += 1 + l + sovGenerated(uint64(l)) + n += 2 + if len(m.Args) > 0 { + for _, e := range m.Args { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + n += 2 + return n +} + +func (m *RolloutExperimentTemplate) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.SpecRef) + n += 1 + l + sovGenerated(uint64(l)) + if m.Replicas != nil { + n += 1 + sovGenerated(uint64(*m.Replicas)) + } + l = m.Metadata.Size() + n += 1 + l + sovGenerated(uint64(l)) + if m.Selector != nil { + l = m.Selector.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *RolloutList) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.ListMeta.Size() + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Items) > 0 { + for _, e := range m.Items { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + return n +} + +func (m *RolloutPause) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Duration != nil { + l = m.Duration.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *RolloutSpec) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Replicas != nil { + n += 1 + sovGenerated(uint64(*m.Replicas)) + } + if m.Selector != nil { + l = m.Selector.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = m.Template.Size() + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.MinReadySeconds)) + l = m.Strategy.Size() + n += 1 + l + sovGenerated(uint64(l)) + if m.RevisionHistoryLimit != nil { + n += 1 + sovGenerated(uint64(*m.RevisionHistoryLimit)) + } + n += 2 + if m.ProgressDeadlineSeconds != nil { + n += 1 + sovGenerated(uint64(*m.ProgressDeadlineSeconds)) + } + if m.RestartAt != nil { + l = m.RestartAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *RolloutStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + n += 2 + if len(m.PauseConditions) > 0 { + for _, e := range m.PauseConditions { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + n += 2 + if m.AbortedAt != nil { + l = m.AbortedAt.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = len(m.CurrentPodHash) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.CurrentStepHash) + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.Replicas)) + n += 1 + sovGenerated(uint64(m.UpdatedReplicas)) + n += 1 + sovGenerated(uint64(m.ReadyReplicas)) + n += 1 + sovGenerated(uint64(m.AvailableReplicas)) + if m.CurrentStepIndex != nil { + n += 1 + sovGenerated(uint64(*m.CurrentStepIndex)) + } + if m.CollisionCount != nil { + n += 1 + sovGenerated(uint64(*m.CollisionCount)) + } + l = len(m.ObservedGeneration) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Conditions) > 0 { + for _, e := range m.Conditions { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + l = m.Canary.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.BlueGreen.Size() + n += 2 + l + sovGenerated(uint64(l)) + n += 2 + sovGenerated(uint64(m.HPAReplicas)) + l = len(m.Selector) + n += 2 + l + sovGenerated(uint64(l)) + l = len(m.StableRS) + n += 2 + l + sovGenerated(uint64(l)) + if m.RestartedAt != nil { + l = m.RestartedAt.Size() + n += 2 + l + sovGenerated(uint64(l)) + } + n += 3 + return n +} + +func (m *RolloutStrategy) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.BlueGreen != nil { + l = m.BlueGreen.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Canary != nil { + l = m.Canary.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *RolloutTrafficRouting) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Istio != nil { + l = m.Istio.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.Nginx != nil { + l = m.Nginx.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.ALB != nil { + l = m.ALB.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.SMI != nil { + l = m.SMI.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *SMITrafficRouting) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.RootService) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.TrafficSplitName) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *ScopeDetail) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Scope) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Region) + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.Step)) + l = len(m.Start) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.End) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *SecretKeyRef) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Key) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *SetCanaryScale) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Weight != nil { + n += 1 + sovGenerated(uint64(*m.Weight)) + } + if m.Replicas != nil { + n += 1 + sovGenerated(uint64(*m.Replicas)) + } + n += 2 + return n +} + +func (m *TemplateSpec) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + if m.Replicas != nil { + n += 1 + sovGenerated(uint64(*m.Replicas)) + } + n += 1 + sovGenerated(uint64(m.MinReadySeconds)) + if m.Selector != nil { + l = m.Selector.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + l = m.Template.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *TemplateStatus) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + n += 1 + l + sovGenerated(uint64(l)) + n += 1 + sovGenerated(uint64(m.Replicas)) + n += 1 + sovGenerated(uint64(m.UpdatedReplicas)) + n += 1 + sovGenerated(uint64(m.ReadyReplicas)) + n += 1 + sovGenerated(uint64(m.AvailableReplicas)) + if m.CollisionCount != nil { + n += 1 + sovGenerated(uint64(*m.CollisionCount)) + } + l = len(m.Status) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + if m.LastTransitionTime != nil { + l = m.LastTransitionTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *ValueFrom) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.SecretKeyRef != nil { + l = m.SecretKeyRef.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + if m.FieldRef != nil { + l = m.FieldRef.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + return n +} + +func (m *WavefrontMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Address) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Query) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func (m *WebMetric) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.URL) + n += 1 + l + sovGenerated(uint64(l)) + if len(m.Headers) > 0 { + for _, e := range m.Headers { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } + n += 1 + sovGenerated(uint64(m.TimeoutSeconds)) + l = len(m.JSONPath) + n += 1 + l + sovGenerated(uint64(l)) + n += 2 + return n +} + +func (m *WebMetricHeader) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Key) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Value) + n += 1 + l + sovGenerated(uint64(l)) + return n +} + +func sovGenerated(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozGenerated(x uint64) (n int) { + return sovGenerated(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (this *ALBTrafficRouting) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ALBTrafficRouting{`, + `Ingress:` + fmt.Sprintf("%v", this.Ingress) + `,`, + `ServicePort:` + fmt.Sprintf("%v", this.ServicePort) + `,`, + `RootService:` + fmt.Sprintf("%v", this.RootService) + `,`, + `AnnotationPrefix:` + fmt.Sprintf("%v", this.AnnotationPrefix) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisRun) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&AnalysisRun{`, + `ObjectMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ObjectMeta), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "AnalysisRunSpec", "AnalysisRunSpec", 1), `&`, ``, 1) + `,`, + `Status:` + strings.Replace(strings.Replace(this.Status.String(), "AnalysisRunStatus", "AnalysisRunStatus", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisRunArgument) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&AnalysisRunArgument{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Value:` + fmt.Sprintf("%v", this.Value) + `,`, + `ValueFrom:` + strings.Replace(this.ValueFrom.String(), "ArgumentValueFrom", "ArgumentValueFrom", 1) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisRunList) String() string { + if this == nil { + return "nil" + } + repeatedStringForItems := "[]AnalysisRun{" + for _, f := range this.Items { + repeatedStringForItems += strings.Replace(strings.Replace(f.String(), "AnalysisRun", "AnalysisRun", 1), `&`, ``, 1) + "," + } + repeatedStringForItems += "}" + s := strings.Join([]string{`&AnalysisRunList{`, + `ListMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ListMeta), "ListMeta", "v1.ListMeta", 1), `&`, ``, 1) + `,`, + `Items:` + repeatedStringForItems + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisRunSpec) String() string { + if this == nil { + return "nil" + } + repeatedStringForMetrics := "[]Metric{" + for _, f := range this.Metrics { + repeatedStringForMetrics += strings.Replace(strings.Replace(f.String(), "Metric", "Metric", 1), `&`, ``, 1) + "," + } + repeatedStringForMetrics += "}" + repeatedStringForArgs := "[]Argument{" + for _, f := range this.Args { + repeatedStringForArgs += strings.Replace(strings.Replace(f.String(), "Argument", "Argument", 1), `&`, ``, 1) + "," + } + repeatedStringForArgs += "}" + s := strings.Join([]string{`&AnalysisRunSpec{`, + `Metrics:` + repeatedStringForMetrics + `,`, + `Args:` + repeatedStringForArgs + `,`, + `Terminate:` + fmt.Sprintf("%v", this.Terminate) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisRunStatus) String() string { + if this == nil { + return "nil" + } + repeatedStringForMetricResults := "[]MetricResult{" + for _, f := range this.MetricResults { + repeatedStringForMetricResults += strings.Replace(strings.Replace(f.String(), "MetricResult", "MetricResult", 1), `&`, ``, 1) + "," + } + repeatedStringForMetricResults += "}" + s := strings.Join([]string{`&AnalysisRunStatus{`, + `Phase:` + fmt.Sprintf("%v", this.Phase) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `MetricResults:` + repeatedStringForMetricResults + `,`, + `StartedAt:` + strings.Replace(fmt.Sprintf("%v", this.StartedAt), "Time", "v1.Time", 1) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisTemplate) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&AnalysisTemplate{`, + `ObjectMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ObjectMeta), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "AnalysisTemplateSpec", "AnalysisTemplateSpec", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisTemplateList) String() string { + if this == nil { + return "nil" + } + repeatedStringForItems := "[]AnalysisTemplate{" + for _, f := range this.Items { + repeatedStringForItems += strings.Replace(strings.Replace(f.String(), "AnalysisTemplate", "AnalysisTemplate", 1), `&`, ``, 1) + "," + } + repeatedStringForItems += "}" + s := strings.Join([]string{`&AnalysisTemplateList{`, + `ListMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ListMeta), "ListMeta", "v1.ListMeta", 1), `&`, ``, 1) + `,`, + `Items:` + repeatedStringForItems + `,`, + `}`, + }, "") + return s +} +func (this *AnalysisTemplateSpec) String() string { + if this == nil { + return "nil" + } + repeatedStringForMetrics := "[]Metric{" + for _, f := range this.Metrics { + repeatedStringForMetrics += strings.Replace(strings.Replace(f.String(), "Metric", "Metric", 1), `&`, ``, 1) + "," + } + repeatedStringForMetrics += "}" + repeatedStringForArgs := "[]Argument{" + for _, f := range this.Args { + repeatedStringForArgs += strings.Replace(strings.Replace(f.String(), "Argument", "Argument", 1), `&`, ``, 1) + "," + } + repeatedStringForArgs += "}" + s := strings.Join([]string{`&AnalysisTemplateSpec{`, + `Metrics:` + repeatedStringForMetrics + `,`, + `Args:` + repeatedStringForArgs + `,`, + `}`, + }, "") + return s +} +func (this *AntiAffinity) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&AntiAffinity{`, + `PreferredDuringSchedulingIgnoredDuringExecution:` + strings.Replace(this.PreferredDuringSchedulingIgnoredDuringExecution.String(), "PreferredDuringSchedulingIgnoredDuringExecution", "PreferredDuringSchedulingIgnoredDuringExecution", 1) + `,`, + `RequiredDuringSchedulingIgnoredDuringExecution:` + strings.Replace(this.RequiredDuringSchedulingIgnoredDuringExecution.String(), "RequiredDuringSchedulingIgnoredDuringExecution", "RequiredDuringSchedulingIgnoredDuringExecution", 1) + `,`, + `}`, + }, "") + return s +} +func (this *Argument) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&Argument{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Value:` + valueToStringGenerated(this.Value) + `,`, + `ValueFrom:` + strings.Replace(this.ValueFrom.String(), "ValueFrom", "ValueFrom", 1) + `,`, + `}`, + }, "") + return s +} +func (this *ArgumentValueFrom) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ArgumentValueFrom{`, + `PodTemplateHashValue:` + valueToStringGenerated(this.PodTemplateHashValue) + `,`, + `FieldRef:` + strings.Replace(this.FieldRef.String(), "FieldRef", "FieldRef", 1) + `,`, + `}`, + }, "") + return s +} +func (this *BlueGreenStatus) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&BlueGreenStatus{`, + `PreviewSelector:` + fmt.Sprintf("%v", this.PreviewSelector) + `,`, + `ActiveSelector:` + fmt.Sprintf("%v", this.ActiveSelector) + `,`, + `ScaleUpPreviewCheckPoint:` + fmt.Sprintf("%v", this.ScaleUpPreviewCheckPoint) + `,`, + `PrePromotionAnalysisRunStatus:` + strings.Replace(this.PrePromotionAnalysisRunStatus.String(), "RolloutAnalysisRunStatus", "RolloutAnalysisRunStatus", 1) + `,`, + `PostPromotionAnalysisRunStatus:` + strings.Replace(this.PostPromotionAnalysisRunStatus.String(), "RolloutAnalysisRunStatus", "RolloutAnalysisRunStatus", 1) + `,`, + `}`, + }, "") + return s +} +func (this *BlueGreenStrategy) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&BlueGreenStrategy{`, + `ActiveService:` + fmt.Sprintf("%v", this.ActiveService) + `,`, + `PreviewService:` + fmt.Sprintf("%v", this.PreviewService) + `,`, + `PreviewReplicaCount:` + valueToStringGenerated(this.PreviewReplicaCount) + `,`, + `AutoPromotionEnabled:` + valueToStringGenerated(this.AutoPromotionEnabled) + `,`, + `AutoPromotionSeconds:` + fmt.Sprintf("%v", this.AutoPromotionSeconds) + `,`, + `MaxUnavailable:` + strings.Replace(fmt.Sprintf("%v", this.MaxUnavailable), "IntOrString", "intstr.IntOrString", 1) + `,`, + `ScaleDownDelaySeconds:` + valueToStringGenerated(this.ScaleDownDelaySeconds) + `,`, + `ScaleDownDelayRevisionLimit:` + valueToStringGenerated(this.ScaleDownDelayRevisionLimit) + `,`, + `PrePromotionAnalysis:` + strings.Replace(this.PrePromotionAnalysis.String(), "RolloutAnalysis", "RolloutAnalysis", 1) + `,`, + `AntiAffinity:` + strings.Replace(this.AntiAffinity.String(), "AntiAffinity", "AntiAffinity", 1) + `,`, + `PostPromotionAnalysis:` + strings.Replace(this.PostPromotionAnalysis.String(), "RolloutAnalysis", "RolloutAnalysis", 1) + `,`, + `PreviewMetadata:` + strings.Replace(this.PreviewMetadata.String(), "PodTemplateMetadata", "PodTemplateMetadata", 1) + `,`, + `ActiveMetadata:` + strings.Replace(this.ActiveMetadata.String(), "PodTemplateMetadata", "PodTemplateMetadata", 1) + `,`, + `}`, + }, "") + return s +} +func (this *CanaryStatus) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&CanaryStatus{`, + `CurrentStepAnalysisRunStatus:` + strings.Replace(this.CurrentStepAnalysisRunStatus.String(), "RolloutAnalysisRunStatus", "RolloutAnalysisRunStatus", 1) + `,`, + `CurrentBackgroundAnalysisRunStatus:` + strings.Replace(this.CurrentBackgroundAnalysisRunStatus.String(), "RolloutAnalysisRunStatus", "RolloutAnalysisRunStatus", 1) + `,`, + `CurrentExperiment:` + fmt.Sprintf("%v", this.CurrentExperiment) + `,`, + `}`, + }, "") + return s +} +func (this *CanaryStep) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&CanaryStep{`, + `SetWeight:` + valueToStringGenerated(this.SetWeight) + `,`, + `Pause:` + strings.Replace(this.Pause.String(), "RolloutPause", "RolloutPause", 1) + `,`, + `Experiment:` + strings.Replace(this.Experiment.String(), "RolloutExperimentStep", "RolloutExperimentStep", 1) + `,`, + `Analysis:` + strings.Replace(this.Analysis.String(), "RolloutAnalysis", "RolloutAnalysis", 1) + `,`, + `SetCanaryScale:` + strings.Replace(this.SetCanaryScale.String(), "SetCanaryScale", "SetCanaryScale", 1) + `,`, + `}`, + }, "") + return s +} +func (this *CanaryStrategy) String() string { + if this == nil { + return "nil" + } + repeatedStringForSteps := "[]CanaryStep{" + for _, f := range this.Steps { + repeatedStringForSteps += strings.Replace(strings.Replace(f.String(), "CanaryStep", "CanaryStep", 1), `&`, ``, 1) + "," + } + repeatedStringForSteps += "}" + s := strings.Join([]string{`&CanaryStrategy{`, + `CanaryService:` + fmt.Sprintf("%v", this.CanaryService) + `,`, + `StableService:` + fmt.Sprintf("%v", this.StableService) + `,`, + `Steps:` + repeatedStringForSteps + `,`, + `TrafficRouting:` + strings.Replace(this.TrafficRouting.String(), "RolloutTrafficRouting", "RolloutTrafficRouting", 1) + `,`, + `MaxUnavailable:` + strings.Replace(fmt.Sprintf("%v", this.MaxUnavailable), "IntOrString", "intstr.IntOrString", 1) + `,`, + `MaxSurge:` + strings.Replace(fmt.Sprintf("%v", this.MaxSurge), "IntOrString", "intstr.IntOrString", 1) + `,`, + `Analysis:` + strings.Replace(this.Analysis.String(), "RolloutAnalysisBackground", "RolloutAnalysisBackground", 1) + `,`, + `AntiAffinity:` + strings.Replace(this.AntiAffinity.String(), "AntiAffinity", "AntiAffinity", 1) + `,`, + `CanaryMetadata:` + strings.Replace(this.CanaryMetadata.String(), "PodTemplateMetadata", "PodTemplateMetadata", 1) + `,`, + `StableMetadata:` + strings.Replace(this.StableMetadata.String(), "PodTemplateMetadata", "PodTemplateMetadata", 1) + `,`, + `}`, + }, "") + return s +} +func (this *ClusterAnalysisTemplate) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ClusterAnalysisTemplate{`, + `ObjectMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ObjectMeta), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "AnalysisTemplateSpec", "AnalysisTemplateSpec", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *ClusterAnalysisTemplateList) String() string { + if this == nil { + return "nil" + } + repeatedStringForItems := "[]ClusterAnalysisTemplate{" + for _, f := range this.Items { + repeatedStringForItems += strings.Replace(strings.Replace(f.String(), "ClusterAnalysisTemplate", "ClusterAnalysisTemplate", 1), `&`, ``, 1) + "," + } + repeatedStringForItems += "}" + s := strings.Join([]string{`&ClusterAnalysisTemplateList{`, + `ListMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ListMeta), "ListMeta", "v1.ListMeta", 1), `&`, ``, 1) + `,`, + `Items:` + repeatedStringForItems + `,`, + `}`, + }, "") + return s +} +func (this *DatadogMetric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&DatadogMetric{`, + `Interval:` + fmt.Sprintf("%v", this.Interval) + `,`, + `Query:` + fmt.Sprintf("%v", this.Query) + `,`, + `}`, + }, "") + return s +} +func (this *Experiment) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&Experiment{`, + `ObjectMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ObjectMeta), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "ExperimentSpec", "ExperimentSpec", 1), `&`, ``, 1) + `,`, + `Status:` + strings.Replace(strings.Replace(this.Status.String(), "ExperimentStatus", "ExperimentStatus", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentAnalysisRunStatus) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ExperimentAnalysisRunStatus{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `AnalysisRun:` + fmt.Sprintf("%v", this.AnalysisRun) + `,`, + `Phase:` + fmt.Sprintf("%v", this.Phase) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentAnalysisTemplateRef) String() string { + if this == nil { + return "nil" + } + repeatedStringForArgs := "[]Argument{" + for _, f := range this.Args { + repeatedStringForArgs += strings.Replace(strings.Replace(f.String(), "Argument", "Argument", 1), `&`, ``, 1) + "," + } + repeatedStringForArgs += "}" + s := strings.Join([]string{`&ExperimentAnalysisTemplateRef{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `TemplateName:` + fmt.Sprintf("%v", this.TemplateName) + `,`, + `ClusterScope:` + fmt.Sprintf("%v", this.ClusterScope) + `,`, + `Args:` + repeatedStringForArgs + `,`, + `RequiredForCompletion:` + fmt.Sprintf("%v", this.RequiredForCompletion) + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentCondition) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ExperimentCondition{`, + `Type:` + fmt.Sprintf("%v", this.Type) + `,`, + `Status:` + fmt.Sprintf("%v", this.Status) + `,`, + `LastUpdateTime:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.LastUpdateTime), "Time", "v1.Time", 1), `&`, ``, 1) + `,`, + `LastTransitionTime:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.LastTransitionTime), "Time", "v1.Time", 1), `&`, ``, 1) + `,`, + `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentList) String() string { + if this == nil { + return "nil" + } + repeatedStringForItems := "[]Experiment{" + for _, f := range this.Items { + repeatedStringForItems += strings.Replace(strings.Replace(f.String(), "Experiment", "Experiment", 1), `&`, ``, 1) + "," + } + repeatedStringForItems += "}" + s := strings.Join([]string{`&ExperimentList{`, + `ListMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ListMeta), "ListMeta", "v1.ListMeta", 1), `&`, ``, 1) + `,`, + `Items:` + repeatedStringForItems + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentSpec) String() string { + if this == nil { + return "nil" + } + repeatedStringForTemplates := "[]TemplateSpec{" + for _, f := range this.Templates { + repeatedStringForTemplates += strings.Replace(strings.Replace(f.String(), "TemplateSpec", "TemplateSpec", 1), `&`, ``, 1) + "," + } + repeatedStringForTemplates += "}" + repeatedStringForAnalyses := "[]ExperimentAnalysisTemplateRef{" + for _, f := range this.Analyses { + repeatedStringForAnalyses += strings.Replace(strings.Replace(f.String(), "ExperimentAnalysisTemplateRef", "ExperimentAnalysisTemplateRef", 1), `&`, ``, 1) + "," + } + repeatedStringForAnalyses += "}" + s := strings.Join([]string{`&ExperimentSpec{`, + `Templates:` + repeatedStringForTemplates + `,`, + `Duration:` + fmt.Sprintf("%v", this.Duration) + `,`, + `ProgressDeadlineSeconds:` + valueToStringGenerated(this.ProgressDeadlineSeconds) + `,`, + `Terminate:` + fmt.Sprintf("%v", this.Terminate) + `,`, + `Analyses:` + repeatedStringForAnalyses + `,`, + `}`, + }, "") + return s +} +func (this *ExperimentStatus) String() string { + if this == nil { + return "nil" + } + repeatedStringForTemplateStatuses := "[]TemplateStatus{" + for _, f := range this.TemplateStatuses { + repeatedStringForTemplateStatuses += strings.Replace(strings.Replace(f.String(), "TemplateStatus", "TemplateStatus", 1), `&`, ``, 1) + "," + } + repeatedStringForTemplateStatuses += "}" + repeatedStringForConditions := "[]ExperimentCondition{" + for _, f := range this.Conditions { + repeatedStringForConditions += strings.Replace(strings.Replace(f.String(), "ExperimentCondition", "ExperimentCondition", 1), `&`, ``, 1) + "," + } + repeatedStringForConditions += "}" + repeatedStringForAnalysisRuns := "[]ExperimentAnalysisRunStatus{" + for _, f := range this.AnalysisRuns { + repeatedStringForAnalysisRuns += strings.Replace(strings.Replace(f.String(), "ExperimentAnalysisRunStatus", "ExperimentAnalysisRunStatus", 1), `&`, ``, 1) + "," + } + repeatedStringForAnalysisRuns += "}" + s := strings.Join([]string{`&ExperimentStatus{`, + `Phase:` + fmt.Sprintf("%v", this.Phase) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `TemplateStatuses:` + repeatedStringForTemplateStatuses + `,`, + `AvailableAt:` + strings.Replace(fmt.Sprintf("%v", this.AvailableAt), "Time", "v1.Time", 1) + `,`, + `Conditions:` + repeatedStringForConditions + `,`, + `AnalysisRuns:` + repeatedStringForAnalysisRuns + `,`, + `}`, + }, "") + return s +} +func (this *FieldRef) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&FieldRef{`, + `FieldPath:` + fmt.Sprintf("%v", this.FieldPath) + `,`, + `}`, + }, "") + return s +} +func (this *IstioDestinationRule) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&IstioDestinationRule{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `CanarySubsetName:` + fmt.Sprintf("%v", this.CanarySubsetName) + `,`, + `StableSubsetName:` + fmt.Sprintf("%v", this.StableSubsetName) + `,`, + `}`, + }, "") + return s +} +func (this *IstioTrafficRouting) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&IstioTrafficRouting{`, + `VirtualService:` + strings.Replace(strings.Replace(this.VirtualService.String(), "IstioVirtualService", "IstioVirtualService", 1), `&`, ``, 1) + `,`, + `DestinationRule:` + strings.Replace(this.DestinationRule.String(), "IstioDestinationRule", "IstioDestinationRule", 1) + `,`, + `}`, + }, "") + return s +} +func (this *IstioVirtualService) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&IstioVirtualService{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Routes:` + fmt.Sprintf("%v", this.Routes) + `,`, + `}`, + }, "") + return s +} +func (this *JobMetric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&JobMetric{`, + `Metadata:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Metadata), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Spec), "JobSpec", "v11.JobSpec", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *KayentaMetric) String() string { + if this == nil { + return "nil" + } + repeatedStringForScopes := "[]KayentaScope{" + for _, f := range this.Scopes { + repeatedStringForScopes += strings.Replace(strings.Replace(f.String(), "KayentaScope", "KayentaScope", 1), `&`, ``, 1) + "," + } + repeatedStringForScopes += "}" + s := strings.Join([]string{`&KayentaMetric{`, + `Address:` + fmt.Sprintf("%v", this.Address) + `,`, + `Application:` + fmt.Sprintf("%v", this.Application) + `,`, + `CanaryConfigName:` + fmt.Sprintf("%v", this.CanaryConfigName) + `,`, + `MetricsAccountName:` + fmt.Sprintf("%v", this.MetricsAccountName) + `,`, + `ConfigurationAccountName:` + fmt.Sprintf("%v", this.ConfigurationAccountName) + `,`, + `StorageAccountName:` + fmt.Sprintf("%v", this.StorageAccountName) + `,`, + `Threshold:` + strings.Replace(strings.Replace(this.Threshold.String(), "KayentaThreshold", "KayentaThreshold", 1), `&`, ``, 1) + `,`, + `Scopes:` + repeatedStringForScopes + `,`, + `}`, + }, "") + return s +} +func (this *KayentaScope) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&KayentaScope{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `ControlScope:` + strings.Replace(strings.Replace(this.ControlScope.String(), "ScopeDetail", "ScopeDetail", 1), `&`, ``, 1) + `,`, + `ExperimentScope:` + strings.Replace(strings.Replace(this.ExperimentScope.String(), "ScopeDetail", "ScopeDetail", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *KayentaThreshold) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&KayentaThreshold{`, + `Pass:` + fmt.Sprintf("%v", this.Pass) + `,`, + `Marginal:` + fmt.Sprintf("%v", this.Marginal) + `,`, + `}`, + }, "") + return s +} +func (this *Measurement) String() string { + if this == nil { + return "nil" + } + keysForMetadata := make([]string, 0, len(this.Metadata)) + for k := range this.Metadata { + keysForMetadata = append(keysForMetadata, k) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForMetadata) + mapStringForMetadata := "map[string]string{" + for _, k := range keysForMetadata { + mapStringForMetadata += fmt.Sprintf("%v: %v,", k, this.Metadata[k]) + } + mapStringForMetadata += "}" + s := strings.Join([]string{`&Measurement{`, + `Phase:` + fmt.Sprintf("%v", this.Phase) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `StartedAt:` + strings.Replace(fmt.Sprintf("%v", this.StartedAt), "Time", "v1.Time", 1) + `,`, + `FinishedAt:` + strings.Replace(fmt.Sprintf("%v", this.FinishedAt), "Time", "v1.Time", 1) + `,`, + `Value:` + fmt.Sprintf("%v", this.Value) + `,`, + `Metadata:` + mapStringForMetadata + `,`, + `ResumeAt:` + strings.Replace(fmt.Sprintf("%v", this.ResumeAt), "Time", "v1.Time", 1) + `,`, + `}`, + }, "") + return s +} +func (this *Metric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&Metric{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Interval:` + fmt.Sprintf("%v", this.Interval) + `,`, + `InitialDelay:` + fmt.Sprintf("%v", this.InitialDelay) + `,`, + `Count:` + strings.Replace(fmt.Sprintf("%v", this.Count), "IntOrString", "intstr.IntOrString", 1) + `,`, + `SuccessCondition:` + fmt.Sprintf("%v", this.SuccessCondition) + `,`, + `FailureCondition:` + fmt.Sprintf("%v", this.FailureCondition) + `,`, + `FailureLimit:` + strings.Replace(fmt.Sprintf("%v", this.FailureLimit), "IntOrString", "intstr.IntOrString", 1) + `,`, + `InconclusiveLimit:` + strings.Replace(fmt.Sprintf("%v", this.InconclusiveLimit), "IntOrString", "intstr.IntOrString", 1) + `,`, + `ConsecutiveErrorLimit:` + strings.Replace(fmt.Sprintf("%v", this.ConsecutiveErrorLimit), "IntOrString", "intstr.IntOrString", 1) + `,`, + `Provider:` + strings.Replace(strings.Replace(this.Provider.String(), "MetricProvider", "MetricProvider", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *MetricProvider) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&MetricProvider{`, + `Prometheus:` + strings.Replace(this.Prometheus.String(), "PrometheusMetric", "PrometheusMetric", 1) + `,`, + `Kayenta:` + strings.Replace(this.Kayenta.String(), "KayentaMetric", "KayentaMetric", 1) + `,`, + `Web:` + strings.Replace(this.Web.String(), "WebMetric", "WebMetric", 1) + `,`, + `Datadog:` + strings.Replace(this.Datadog.String(), "DatadogMetric", "DatadogMetric", 1) + `,`, + `Wavefront:` + strings.Replace(this.Wavefront.String(), "WavefrontMetric", "WavefrontMetric", 1) + `,`, + `NewRelic:` + strings.Replace(this.NewRelic.String(), "NewRelicMetric", "NewRelicMetric", 1) + `,`, + `Job:` + strings.Replace(this.Job.String(), "JobMetric", "JobMetric", 1) + `,`, + `}`, + }, "") + return s +} +func (this *MetricResult) String() string { + if this == nil { + return "nil" + } + repeatedStringForMeasurements := "[]Measurement{" + for _, f := range this.Measurements { + repeatedStringForMeasurements += strings.Replace(strings.Replace(f.String(), "Measurement", "Measurement", 1), `&`, ``, 1) + "," + } + repeatedStringForMeasurements += "}" + s := strings.Join([]string{`&MetricResult{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Phase:` + fmt.Sprintf("%v", this.Phase) + `,`, + `Measurements:` + repeatedStringForMeasurements + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `Count:` + fmt.Sprintf("%v", this.Count) + `,`, + `Successful:` + fmt.Sprintf("%v", this.Successful) + `,`, + `Failed:` + fmt.Sprintf("%v", this.Failed) + `,`, + `Inconclusive:` + fmt.Sprintf("%v", this.Inconclusive) + `,`, + `Error:` + fmt.Sprintf("%v", this.Error) + `,`, + `ConsecutiveError:` + fmt.Sprintf("%v", this.ConsecutiveError) + `,`, + `}`, + }, "") + return s +} +func (this *NewRelicMetric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&NewRelicMetric{`, + `Profile:` + fmt.Sprintf("%v", this.Profile) + `,`, + `Query:` + fmt.Sprintf("%v", this.Query) + `,`, + `}`, + }, "") + return s +} +func (this *NginxTrafficRouting) String() string { + if this == nil { + return "nil" + } + keysForAdditionalIngressAnnotations := make([]string, 0, len(this.AdditionalIngressAnnotations)) + for k := range this.AdditionalIngressAnnotations { + keysForAdditionalIngressAnnotations = append(keysForAdditionalIngressAnnotations, k) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForAdditionalIngressAnnotations) + mapStringForAdditionalIngressAnnotations := "map[string]string{" + for _, k := range keysForAdditionalIngressAnnotations { + mapStringForAdditionalIngressAnnotations += fmt.Sprintf("%v: %v,", k, this.AdditionalIngressAnnotations[k]) + } + mapStringForAdditionalIngressAnnotations += "}" + s := strings.Join([]string{`&NginxTrafficRouting{`, + `AnnotationPrefix:` + fmt.Sprintf("%v", this.AnnotationPrefix) + `,`, + `StableIngress:` + fmt.Sprintf("%v", this.StableIngress) + `,`, + `AdditionalIngressAnnotations:` + mapStringForAdditionalIngressAnnotations + `,`, + `}`, + }, "") + return s +} +func (this *PauseCondition) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&PauseCondition{`, + `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, + `StartTime:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.StartTime), "Time", "v1.Time", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *PodTemplateMetadata) String() string { + if this == nil { + return "nil" + } + keysForLabels := make([]string, 0, len(this.Labels)) + for k := range this.Labels { + keysForLabels = append(keysForLabels, k) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForLabels) + mapStringForLabels := "map[string]string{" + for _, k := range keysForLabels { + mapStringForLabels += fmt.Sprintf("%v: %v,", k, this.Labels[k]) + } + mapStringForLabels += "}" + keysForAnnotations := make([]string, 0, len(this.Annotations)) + for k := range this.Annotations { + keysForAnnotations = append(keysForAnnotations, k) + } + github_com_gogo_protobuf_sortkeys.Strings(keysForAnnotations) + mapStringForAnnotations := "map[string]string{" + for _, k := range keysForAnnotations { + mapStringForAnnotations += fmt.Sprintf("%v: %v,", k, this.Annotations[k]) + } + mapStringForAnnotations += "}" + s := strings.Join([]string{`&PodTemplateMetadata{`, + `Labels:` + mapStringForLabels + `,`, + `Annotations:` + mapStringForAnnotations + `,`, + `}`, + }, "") + return s +} +func (this *PreferredDuringSchedulingIgnoredDuringExecution) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&PreferredDuringSchedulingIgnoredDuringExecution{`, + `Weight:` + fmt.Sprintf("%v", this.Weight) + `,`, + `}`, + }, "") + return s +} +func (this *PrometheusMetric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&PrometheusMetric{`, + `Address:` + fmt.Sprintf("%v", this.Address) + `,`, + `Query:` + fmt.Sprintf("%v", this.Query) + `,`, + `}`, + }, "") + return s +} +func (this *RequiredDuringSchedulingIgnoredDuringExecution) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RequiredDuringSchedulingIgnoredDuringExecution{`, + `}`, + }, "") + return s +} +func (this *Rollout) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&Rollout{`, + `ObjectMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ObjectMeta), "ObjectMeta", "v1.ObjectMeta", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "RolloutSpec", "RolloutSpec", 1), `&`, ``, 1) + `,`, + `Status:` + strings.Replace(strings.Replace(this.Status.String(), "RolloutStatus", "RolloutStatus", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutAnalysis) String() string { + if this == nil { + return "nil" + } + repeatedStringForTemplates := "[]RolloutAnalysisTemplate{" + for _, f := range this.Templates { + repeatedStringForTemplates += strings.Replace(strings.Replace(f.String(), "RolloutAnalysisTemplate", "RolloutAnalysisTemplate", 1), `&`, ``, 1) + "," + } + repeatedStringForTemplates += "}" + repeatedStringForArgs := "[]AnalysisRunArgument{" + for _, f := range this.Args { + repeatedStringForArgs += strings.Replace(strings.Replace(f.String(), "AnalysisRunArgument", "AnalysisRunArgument", 1), `&`, ``, 1) + "," + } + repeatedStringForArgs += "}" + s := strings.Join([]string{`&RolloutAnalysis{`, + `Templates:` + repeatedStringForTemplates + `,`, + `Args:` + repeatedStringForArgs + `,`, + `}`, + }, "") + return s +} +func (this *RolloutAnalysisBackground) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutAnalysisBackground{`, + `RolloutAnalysis:` + strings.Replace(strings.Replace(this.RolloutAnalysis.String(), "RolloutAnalysis", "RolloutAnalysis", 1), `&`, ``, 1) + `,`, + `StartingStep:` + valueToStringGenerated(this.StartingStep) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutAnalysisRunStatus) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutAnalysisRunStatus{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Status:` + fmt.Sprintf("%v", this.Status) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutAnalysisTemplate) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutAnalysisTemplate{`, + `TemplateName:` + fmt.Sprintf("%v", this.TemplateName) + `,`, + `ClusterScope:` + fmt.Sprintf("%v", this.ClusterScope) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutCondition) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutCondition{`, + `Type:` + fmt.Sprintf("%v", this.Type) + `,`, + `Status:` + fmt.Sprintf("%v", this.Status) + `,`, + `LastUpdateTime:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.LastUpdateTime), "Time", "v1.Time", 1), `&`, ``, 1) + `,`, + `LastTransitionTime:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.LastTransitionTime), "Time", "v1.Time", 1), `&`, ``, 1) + `,`, + `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutExperimentStep) String() string { + if this == nil { + return "nil" + } + repeatedStringForTemplates := "[]RolloutExperimentTemplate{" + for _, f := range this.Templates { + repeatedStringForTemplates += strings.Replace(strings.Replace(f.String(), "RolloutExperimentTemplate", "RolloutExperimentTemplate", 1), `&`, ``, 1) + "," + } + repeatedStringForTemplates += "}" + repeatedStringForAnalyses := "[]RolloutExperimentStepAnalysisTemplateRef{" + for _, f := range this.Analyses { + repeatedStringForAnalyses += strings.Replace(strings.Replace(f.String(), "RolloutExperimentStepAnalysisTemplateRef", "RolloutExperimentStepAnalysisTemplateRef", 1), `&`, ``, 1) + "," + } + repeatedStringForAnalyses += "}" + s := strings.Join([]string{`&RolloutExperimentStep{`, + `Templates:` + repeatedStringForTemplates + `,`, + `Duration:` + fmt.Sprintf("%v", this.Duration) + `,`, + `Analyses:` + repeatedStringForAnalyses + `,`, + `}`, + }, "") + return s +} +func (this *RolloutExperimentStepAnalysisTemplateRef) String() string { + if this == nil { + return "nil" + } + repeatedStringForArgs := "[]AnalysisRunArgument{" + for _, f := range this.Args { + repeatedStringForArgs += strings.Replace(strings.Replace(f.String(), "AnalysisRunArgument", "AnalysisRunArgument", 1), `&`, ``, 1) + "," + } + repeatedStringForArgs += "}" + s := strings.Join([]string{`&RolloutExperimentStepAnalysisTemplateRef{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `TemplateName:` + fmt.Sprintf("%v", this.TemplateName) + `,`, + `ClusterScope:` + fmt.Sprintf("%v", this.ClusterScope) + `,`, + `Args:` + repeatedStringForArgs + `,`, + `RequiredForCompletion:` + fmt.Sprintf("%v", this.RequiredForCompletion) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutExperimentTemplate) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutExperimentTemplate{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `SpecRef:` + fmt.Sprintf("%v", this.SpecRef) + `,`, + `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, + `Metadata:` + strings.Replace(strings.Replace(this.Metadata.String(), "PodTemplateMetadata", "PodTemplateMetadata", 1), `&`, ``, 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "v1.LabelSelector", 1) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutList) String() string { + if this == nil { + return "nil" + } + repeatedStringForItems := "[]Rollout{" + for _, f := range this.Items { + repeatedStringForItems += strings.Replace(strings.Replace(f.String(), "Rollout", "Rollout", 1), `&`, ``, 1) + "," + } + repeatedStringForItems += "}" + s := strings.Join([]string{`&RolloutList{`, + `ListMeta:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.ListMeta), "ListMeta", "v1.ListMeta", 1), `&`, ``, 1) + `,`, + `Items:` + repeatedStringForItems + `,`, + `}`, + }, "") + return s +} +func (this *RolloutPause) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutPause{`, + `Duration:` + strings.Replace(fmt.Sprintf("%v", this.Duration), "IntOrString", "intstr.IntOrString", 1) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutSpec) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutSpec{`, + `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "v1.LabelSelector", 1) + `,`, + `Template:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Template), "PodTemplateSpec", "v12.PodTemplateSpec", 1), `&`, ``, 1) + `,`, + `MinReadySeconds:` + fmt.Sprintf("%v", this.MinReadySeconds) + `,`, + `Strategy:` + strings.Replace(strings.Replace(this.Strategy.String(), "RolloutStrategy", "RolloutStrategy", 1), `&`, ``, 1) + `,`, + `RevisionHistoryLimit:` + valueToStringGenerated(this.RevisionHistoryLimit) + `,`, + `Paused:` + fmt.Sprintf("%v", this.Paused) + `,`, + `ProgressDeadlineSeconds:` + valueToStringGenerated(this.ProgressDeadlineSeconds) + `,`, + `RestartAt:` + strings.Replace(fmt.Sprintf("%v", this.RestartAt), "Time", "v1.Time", 1) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutStatus) String() string { + if this == nil { + return "nil" + } + repeatedStringForPauseConditions := "[]PauseCondition{" + for _, f := range this.PauseConditions { + repeatedStringForPauseConditions += strings.Replace(strings.Replace(f.String(), "PauseCondition", "PauseCondition", 1), `&`, ``, 1) + "," + } + repeatedStringForPauseConditions += "}" + repeatedStringForConditions := "[]RolloutCondition{" + for _, f := range this.Conditions { + repeatedStringForConditions += strings.Replace(strings.Replace(f.String(), "RolloutCondition", "RolloutCondition", 1), `&`, ``, 1) + "," + } + repeatedStringForConditions += "}" + s := strings.Join([]string{`&RolloutStatus{`, + `Abort:` + fmt.Sprintf("%v", this.Abort) + `,`, + `PauseConditions:` + repeatedStringForPauseConditions + `,`, + `ControllerPause:` + fmt.Sprintf("%v", this.ControllerPause) + `,`, + `AbortedAt:` + strings.Replace(fmt.Sprintf("%v", this.AbortedAt), "Time", "v1.Time", 1) + `,`, + `CurrentPodHash:` + fmt.Sprintf("%v", this.CurrentPodHash) + `,`, + `CurrentStepHash:` + fmt.Sprintf("%v", this.CurrentStepHash) + `,`, + `Replicas:` + fmt.Sprintf("%v", this.Replicas) + `,`, + `UpdatedReplicas:` + fmt.Sprintf("%v", this.UpdatedReplicas) + `,`, + `ReadyReplicas:` + fmt.Sprintf("%v", this.ReadyReplicas) + `,`, + `AvailableReplicas:` + fmt.Sprintf("%v", this.AvailableReplicas) + `,`, + `CurrentStepIndex:` + valueToStringGenerated(this.CurrentStepIndex) + `,`, + `CollisionCount:` + valueToStringGenerated(this.CollisionCount) + `,`, + `ObservedGeneration:` + fmt.Sprintf("%v", this.ObservedGeneration) + `,`, + `Conditions:` + repeatedStringForConditions + `,`, + `Canary:` + strings.Replace(strings.Replace(this.Canary.String(), "CanaryStatus", "CanaryStatus", 1), `&`, ``, 1) + `,`, + `BlueGreen:` + strings.Replace(strings.Replace(this.BlueGreen.String(), "BlueGreenStatus", "BlueGreenStatus", 1), `&`, ``, 1) + `,`, + `HPAReplicas:` + fmt.Sprintf("%v", this.HPAReplicas) + `,`, + `Selector:` + fmt.Sprintf("%v", this.Selector) + `,`, + `StableRS:` + fmt.Sprintf("%v", this.StableRS) + `,`, + `RestartedAt:` + strings.Replace(fmt.Sprintf("%v", this.RestartedAt), "Time", "v1.Time", 1) + `,`, + `PromoteFull:` + fmt.Sprintf("%v", this.PromoteFull) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutStrategy) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutStrategy{`, + `BlueGreen:` + strings.Replace(this.BlueGreen.String(), "BlueGreenStrategy", "BlueGreenStrategy", 1) + `,`, + `Canary:` + strings.Replace(this.Canary.String(), "CanaryStrategy", "CanaryStrategy", 1) + `,`, + `}`, + }, "") + return s +} +func (this *RolloutTrafficRouting) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&RolloutTrafficRouting{`, + `Istio:` + strings.Replace(this.Istio.String(), "IstioTrafficRouting", "IstioTrafficRouting", 1) + `,`, + `Nginx:` + strings.Replace(this.Nginx.String(), "NginxTrafficRouting", "NginxTrafficRouting", 1) + `,`, + `ALB:` + strings.Replace(this.ALB.String(), "ALBTrafficRouting", "ALBTrafficRouting", 1) + `,`, + `SMI:` + strings.Replace(this.SMI.String(), "SMITrafficRouting", "SMITrafficRouting", 1) + `,`, + `}`, + }, "") + return s +} +func (this *SMITrafficRouting) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&SMITrafficRouting{`, + `RootService:` + fmt.Sprintf("%v", this.RootService) + `,`, + `TrafficSplitName:` + fmt.Sprintf("%v", this.TrafficSplitName) + `,`, + `}`, + }, "") + return s +} +func (this *ScopeDetail) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ScopeDetail{`, + `Scope:` + fmt.Sprintf("%v", this.Scope) + `,`, + `Region:` + fmt.Sprintf("%v", this.Region) + `,`, + `Step:` + fmt.Sprintf("%v", this.Step) + `,`, + `Start:` + fmt.Sprintf("%v", this.Start) + `,`, + `End:` + fmt.Sprintf("%v", this.End) + `,`, + `}`, + }, "") + return s +} +func (this *SecretKeyRef) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&SecretKeyRef{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Key:` + fmt.Sprintf("%v", this.Key) + `,`, + `}`, + }, "") + return s +} +func (this *SetCanaryScale) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&SetCanaryScale{`, + `Weight:` + valueToStringGenerated(this.Weight) + `,`, + `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, + `MatchTrafficWeight:` + fmt.Sprintf("%v", this.MatchTrafficWeight) + `,`, + `}`, + }, "") + return s +} +func (this *TemplateSpec) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&TemplateSpec{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, + `MinReadySeconds:` + fmt.Sprintf("%v", this.MinReadySeconds) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "v1.LabelSelector", 1) + `,`, + `Template:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Template), "PodTemplateSpec", "v12.PodTemplateSpec", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} +func (this *TemplateStatus) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&TemplateStatus{`, + `Name:` + fmt.Sprintf("%v", this.Name) + `,`, + `Replicas:` + fmt.Sprintf("%v", this.Replicas) + `,`, + `UpdatedReplicas:` + fmt.Sprintf("%v", this.UpdatedReplicas) + `,`, + `ReadyReplicas:` + fmt.Sprintf("%v", this.ReadyReplicas) + `,`, + `AvailableReplicas:` + fmt.Sprintf("%v", this.AvailableReplicas) + `,`, + `CollisionCount:` + valueToStringGenerated(this.CollisionCount) + `,`, + `Status:` + fmt.Sprintf("%v", this.Status) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `LastTransitionTime:` + strings.Replace(fmt.Sprintf("%v", this.LastTransitionTime), "Time", "v1.Time", 1) + `,`, + `}`, + }, "") + return s +} +func (this *ValueFrom) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&ValueFrom{`, + `SecretKeyRef:` + strings.Replace(this.SecretKeyRef.String(), "SecretKeyRef", "SecretKeyRef", 1) + `,`, + `FieldRef:` + strings.Replace(this.FieldRef.String(), "FieldRef", "FieldRef", 1) + `,`, + `}`, + }, "") + return s +} +func (this *WavefrontMetric) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&WavefrontMetric{`, + `Address:` + fmt.Sprintf("%v", this.Address) + `,`, + `Query:` + fmt.Sprintf("%v", this.Query) + `,`, + `}`, + }, "") + return s +} +func (this *WebMetric) String() string { + if this == nil { + return "nil" + } + repeatedStringForHeaders := "[]WebMetricHeader{" + for _, f := range this.Headers { + repeatedStringForHeaders += strings.Replace(strings.Replace(f.String(), "WebMetricHeader", "WebMetricHeader", 1), `&`, ``, 1) + "," + } + repeatedStringForHeaders += "}" + s := strings.Join([]string{`&WebMetric{`, + `URL:` + fmt.Sprintf("%v", this.URL) + `,`, + `Headers:` + repeatedStringForHeaders + `,`, + `TimeoutSeconds:` + fmt.Sprintf("%v", this.TimeoutSeconds) + `,`, + `JSONPath:` + fmt.Sprintf("%v", this.JSONPath) + `,`, + `Insecure:` + fmt.Sprintf("%v", this.Insecure) + `,`, + `}`, + }, "") + return s +} +func (this *WebMetricHeader) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&WebMetricHeader{`, + `Key:` + fmt.Sprintf("%v", this.Key) + `,`, + `Value:` + fmt.Sprintf("%v", this.Value) + `,`, + `}`, + }, "") + return s +} +func valueToStringGenerated(v interface{}) string { + rv := reflect.ValueOf(v) + if rv.IsNil() { + return "nil" + } + pv := reflect.Indirect(rv).Interface() + return fmt.Sprintf("*%v", pv) +} +func (m *ALBTrafficRouting) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ALBTrafficRouting: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ALBTrafficRouting: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Ingress", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Ingress = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ServicePort", wireType) + } + m.ServicePort = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ServicePort |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RootService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.RootService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnnotationPrefix", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnnotationPrefix = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRun) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRun: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRun: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Status.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRunArgument) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRunArgument: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRunArgument: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Value = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ValueFrom", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ValueFrom == nil { + m.ValueFrom = &ArgumentValueFrom{} + } + if err := m.ValueFrom.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRunList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRunList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRunList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ListMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ListMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Items", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Items = append(m.Items, AnalysisRun{}) + if err := m.Items[len(m.Items)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRunSpec) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRunSpec: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRunSpec: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Metrics", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Metrics = append(m.Metrics, Metric{}) + if err := m.Metrics[len(m.Metrics)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Args", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Args = append(m.Args, Argument{}) + if err := m.Args[len(m.Args)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Terminate", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Terminate = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisRunStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisRunStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisRunStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Phase", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Phase = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MetricResults", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.MetricResults = append(m.MetricResults, MetricResult{}) + if err := m.MetricResults[len(m.MetricResults)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StartedAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.StartedAt == nil { + m.StartedAt = &v1.Time{} + } + if err := m.StartedAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisTemplate) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisTemplate: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisTemplate: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisTemplateList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisTemplateList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisTemplateList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ListMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ListMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Items", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Items = append(m.Items, AnalysisTemplate{}) + if err := m.Items[len(m.Items)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AnalysisTemplateSpec) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AnalysisTemplateSpec: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AnalysisTemplateSpec: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Metrics", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Metrics = append(m.Metrics, Metric{}) + if err := m.Metrics[len(m.Metrics)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Args", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Args = append(m.Args, Argument{}) + if err := m.Args[len(m.Args)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AntiAffinity) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: AntiAffinity: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AntiAffinity: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PreferredDuringSchedulingIgnoredDuringExecution", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PreferredDuringSchedulingIgnoredDuringExecution == nil { + m.PreferredDuringSchedulingIgnoredDuringExecution = &PreferredDuringSchedulingIgnoredDuringExecution{} + } + if err := m.PreferredDuringSchedulingIgnoredDuringExecution.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RequiredDuringSchedulingIgnoredDuringExecution", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.RequiredDuringSchedulingIgnoredDuringExecution == nil { + m.RequiredDuringSchedulingIgnoredDuringExecution = &RequiredDuringSchedulingIgnoredDuringExecution{} + } + if err := m.RequiredDuringSchedulingIgnoredDuringExecution.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Argument) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Argument: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Argument: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + s := string(dAtA[iNdEx:postIndex]) + m.Value = &s + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ValueFrom", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ValueFrom == nil { + m.ValueFrom = &ValueFrom{} + } + if err := m.ValueFrom.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ArgumentValueFrom) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ArgumentValueFrom: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ArgumentValueFrom: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PodTemplateHashValue", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + s := ValueFromPodTemplateHash(dAtA[iNdEx:postIndex]) + m.PodTemplateHashValue = &s + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FieldRef", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.FieldRef == nil { + m.FieldRef = &FieldRef{} + } + if err := m.FieldRef.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *BlueGreenStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: BlueGreenStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: BlueGreenStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PreviewSelector", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.PreviewSelector = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ActiveSelector", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ActiveSelector = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ScaleUpPreviewCheckPoint", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ScaleUpPreviewCheckPoint = bool(v != 0) + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PrePromotionAnalysisRunStatus", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PrePromotionAnalysisRunStatus == nil { + m.PrePromotionAnalysisRunStatus = &RolloutAnalysisRunStatus{} + } + if err := m.PrePromotionAnalysisRunStatus.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PostPromotionAnalysisRunStatus", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PostPromotionAnalysisRunStatus == nil { + m.PostPromotionAnalysisRunStatus = &RolloutAnalysisRunStatus{} + } + if err := m.PostPromotionAnalysisRunStatus.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *BlueGreenStrategy) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: BlueGreenStrategy: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: BlueGreenStrategy: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ActiveService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ActiveService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PreviewService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.PreviewService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field PreviewReplicaCount", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.PreviewReplicaCount = &v + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AutoPromotionEnabled", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + b := bool(v != 0) + m.AutoPromotionEnabled = &b + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AutoPromotionSeconds", wireType) + } + m.AutoPromotionSeconds = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.AutoPromotionSeconds |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MaxUnavailable", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.MaxUnavailable == nil { + m.MaxUnavailable = &intstr.IntOrString{} + } + if err := m.MaxUnavailable.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ScaleDownDelaySeconds", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ScaleDownDelaySeconds = &v + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ScaleDownDelayRevisionLimit", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ScaleDownDelayRevisionLimit = &v + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PrePromotionAnalysis", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PrePromotionAnalysis == nil { + m.PrePromotionAnalysis = &RolloutAnalysis{} + } + if err := m.PrePromotionAnalysis.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 10: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AntiAffinity", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AntiAffinity == nil { + m.AntiAffinity = &AntiAffinity{} + } + if err := m.AntiAffinity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 11: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PostPromotionAnalysis", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PostPromotionAnalysis == nil { + m.PostPromotionAnalysis = &RolloutAnalysis{} + } + if err := m.PostPromotionAnalysis.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 12: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PreviewMetadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PreviewMetadata == nil { + m.PreviewMetadata = &PodTemplateMetadata{} + } + if err := m.PreviewMetadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 13: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ActiveMetadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ActiveMetadata == nil { + m.ActiveMetadata = &PodTemplateMetadata{} + } + if err := m.ActiveMetadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *CanaryStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: CanaryStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: CanaryStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentStepAnalysisRunStatus", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.CurrentStepAnalysisRunStatus == nil { + m.CurrentStepAnalysisRunStatus = &RolloutAnalysisRunStatus{} + } + if err := m.CurrentStepAnalysisRunStatus.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentBackgroundAnalysisRunStatus", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.CurrentBackgroundAnalysisRunStatus == nil { + m.CurrentBackgroundAnalysisRunStatus = &RolloutAnalysisRunStatus{} + } + if err := m.CurrentBackgroundAnalysisRunStatus.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentExperiment", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CurrentExperiment = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *CanaryStep) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: CanaryStep: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: CanaryStep: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field SetWeight", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.SetWeight = &v + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Pause", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Pause == nil { + m.Pause = &RolloutPause{} + } + if err := m.Pause.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Experiment", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Experiment == nil { + m.Experiment = &RolloutExperimentStep{} + } + if err := m.Experiment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Analysis", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Analysis == nil { + m.Analysis = &RolloutAnalysis{} + } + if err := m.Analysis.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SetCanaryScale", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.SetCanaryScale == nil { + m.SetCanaryScale = &SetCanaryScale{} + } + if err := m.SetCanaryScale.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *CanaryStrategy) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: CanaryStrategy: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: CanaryStrategy: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CanaryService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CanaryService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StableService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.StableService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Steps", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Steps = append(m.Steps, CanaryStep{}) + if err := m.Steps[len(m.Steps)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TrafficRouting", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.TrafficRouting == nil { + m.TrafficRouting = &RolloutTrafficRouting{} + } + if err := m.TrafficRouting.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MaxUnavailable", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.MaxUnavailable == nil { + m.MaxUnavailable = &intstr.IntOrString{} + } + if err := m.MaxUnavailable.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MaxSurge", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.MaxSurge == nil { + m.MaxSurge = &intstr.IntOrString{} + } + if err := m.MaxSurge.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Analysis", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Analysis == nil { + m.Analysis = &RolloutAnalysisBackground{} + } + if err := m.Analysis.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AntiAffinity", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AntiAffinity == nil { + m.AntiAffinity = &AntiAffinity{} + } + if err := m.AntiAffinity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CanaryMetadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.CanaryMetadata == nil { + m.CanaryMetadata = &PodTemplateMetadata{} + } + if err := m.CanaryMetadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 10: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StableMetadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.StableMetadata == nil { + m.StableMetadata = &PodTemplateMetadata{} + } + if err := m.StableMetadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ClusterAnalysisTemplate) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ClusterAnalysisTemplate: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ClusterAnalysisTemplate: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ClusterAnalysisTemplateList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ClusterAnalysisTemplateList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ClusterAnalysisTemplateList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ListMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ListMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Items", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Items = append(m.Items, ClusterAnalysisTemplate{}) + if err := m.Items[len(m.Items)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *DatadogMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: DatadogMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: DatadogMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Interval", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Interval = DurationString(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Query", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Query = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Experiment) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Experiment: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Experiment: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Status.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentAnalysisRunStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentAnalysisRunStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentAnalysisRunStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnalysisRun", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnalysisRun = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Phase", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Phase = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentAnalysisTemplateRef) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentAnalysisTemplateRef: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentAnalysisTemplateRef: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TemplateName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TemplateName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ClusterScope", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ClusterScope = bool(v != 0) + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Args", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Args = append(m.Args, Argument{}) + if err := m.Args[len(m.Args)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RequiredForCompletion", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.RequiredForCompletion = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentCondition) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentCondition: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentCondition: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Type", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Type = ExperimentConditionType(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = k8s_io_api_core_v1.ConditionStatus(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastUpdateTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastUpdateTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastTransitionTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Reason = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ListMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ListMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Items", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Items = append(m.Items, Experiment{}) + if err := m.Items[len(m.Items)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentSpec) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentSpec: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentSpec: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Templates", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Templates = append(m.Templates, TemplateSpec{}) + if err := m.Templates[len(m.Templates)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Duration", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Duration = DurationString(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ProgressDeadlineSeconds", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ProgressDeadlineSeconds = &v + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Terminate", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Terminate = bool(v != 0) + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Analyses", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Analyses = append(m.Analyses, ExperimentAnalysisTemplateRef{}) + if err := m.Analyses[len(m.Analyses)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ExperimentStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ExperimentStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ExperimentStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Phase", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Phase = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TemplateStatuses", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TemplateStatuses = append(m.TemplateStatuses, TemplateStatus{}) + if err := m.TemplateStatuses[len(m.TemplateStatuses)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AvailableAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AvailableAt == nil { + m.AvailableAt = &v1.Time{} + } + if err := m.AvailableAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Conditions", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Conditions = append(m.Conditions, ExperimentCondition{}) + if err := m.Conditions[len(m.Conditions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnalysisRuns", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnalysisRuns = append(m.AnalysisRuns, ExperimentAnalysisRunStatus{}) + if err := m.AnalysisRuns[len(m.AnalysisRuns)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *FieldRef) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: FieldRef: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: FieldRef: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FieldPath", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.FieldPath = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *IstioDestinationRule) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: IstioDestinationRule: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: IstioDestinationRule: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CanarySubsetName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CanarySubsetName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StableSubsetName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.StableSubsetName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *IstioTrafficRouting) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: IstioTrafficRouting: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: IstioTrafficRouting: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field VirtualService", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.VirtualService.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field DestinationRule", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.DestinationRule == nil { + m.DestinationRule = &IstioDestinationRule{} + } + if err := m.DestinationRule.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *IstioVirtualService) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: IstioVirtualService: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: IstioVirtualService: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Routes", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Routes = append(m.Routes, string(dAtA[iNdEx:postIndex])) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *JobMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: JobMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: JobMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Metadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Metadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *KayentaMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: KayentaMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: KayentaMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Address = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Application", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Application = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CanaryConfigName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CanaryConfigName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MetricsAccountName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.MetricsAccountName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ConfigurationAccountName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ConfigurationAccountName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StorageAccountName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.StorageAccountName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Threshold", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Threshold.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Scopes", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Scopes = append(m.Scopes, KayentaScope{}) + if err := m.Scopes[len(m.Scopes)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *KayentaScope) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: KayentaScope: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: KayentaScope: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ControlScope", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ControlScope.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ExperimentScope", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ExperimentScope.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *KayentaThreshold) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: KayentaThreshold: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: KayentaThreshold: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Pass", wireType) + } + m.Pass = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Pass |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Marginal", wireType) + } + m.Marginal = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Marginal |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Measurement) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Measurement: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Measurement: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Phase", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Phase = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StartedAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.StartedAt == nil { + m.StartedAt = &v1.Time{} + } + if err := m.StartedAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FinishedAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.FinishedAt == nil { + m.FinishedAt = &v1.Time{} + } + if err := m.FinishedAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Value = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Metadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Metadata == nil { + m.Metadata = make(map[string]string) + } + var mapkey string + var mapvalue string + for iNdEx < postIndex { + entryPreIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + if fieldNum == 1 { + var stringLenmapkey uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapkey |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapkey := int(stringLenmapkey) + if intStringLenmapkey < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapkey := iNdEx + intStringLenmapkey + if postStringIndexmapkey < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapkey > l { + return io.ErrUnexpectedEOF + } + mapkey = string(dAtA[iNdEx:postStringIndexmapkey]) + iNdEx = postStringIndexmapkey + } else if fieldNum == 2 { + var stringLenmapvalue uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapvalue |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapvalue := int(stringLenmapvalue) + if intStringLenmapvalue < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapvalue := iNdEx + intStringLenmapvalue + if postStringIndexmapvalue < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapvalue > l { + return io.ErrUnexpectedEOF + } + mapvalue = string(dAtA[iNdEx:postStringIndexmapvalue]) + iNdEx = postStringIndexmapvalue + } else { + iNdEx = entryPreIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > postIndex { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + m.Metadata[mapkey] = mapvalue + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ResumeAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ResumeAt == nil { + m.ResumeAt = &v1.Time{} + } + if err := m.ResumeAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Metric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Metric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Metric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Interval", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Interval = DurationString(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field InitialDelay", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.InitialDelay = DurationString(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Count", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Count == nil { + m.Count = &intstr.IntOrString{} + } + if err := m.Count.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SuccessCondition", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.SuccessCondition = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FailureCondition", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.FailureCondition = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FailureLimit", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.FailureLimit == nil { + m.FailureLimit = &intstr.IntOrString{} + } + if err := m.FailureLimit.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field InconclusiveLimit", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.InconclusiveLimit == nil { + m.InconclusiveLimit = &intstr.IntOrString{} + } + if err := m.InconclusiveLimit.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ConsecutiveErrorLimit", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ConsecutiveErrorLimit == nil { + m.ConsecutiveErrorLimit = &intstr.IntOrString{} + } + if err := m.ConsecutiveErrorLimit.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 10: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Provider", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Provider.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MetricProvider) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: MetricProvider: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MetricProvider: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Prometheus", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Prometheus == nil { + m.Prometheus = &PrometheusMetric{} + } + if err := m.Prometheus.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Kayenta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Kayenta == nil { + m.Kayenta = &KayentaMetric{} + } + if err := m.Kayenta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Web", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Web == nil { + m.Web = &WebMetric{} + } + if err := m.Web.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Datadog", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Datadog == nil { + m.Datadog = &DatadogMetric{} + } + if err := m.Datadog.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Wavefront", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Wavefront == nil { + m.Wavefront = &WavefrontMetric{} + } + if err := m.Wavefront.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field NewRelic", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.NewRelic == nil { + m.NewRelic = &NewRelicMetric{} + } + if err := m.NewRelic.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Job", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Job == nil { + m.Job = &JobMetric{} + } + if err := m.Job.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MetricResult) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: MetricResult: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MetricResult: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Phase", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Phase = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Measurements", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Measurements = append(m.Measurements, Measurement{}) + if err := m.Measurements[len(m.Measurements)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Count", wireType) + } + m.Count = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Count |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Successful", wireType) + } + m.Successful = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Successful |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Failed", wireType) + } + m.Failed = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Failed |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Inconclusive", wireType) + } + m.Inconclusive = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Inconclusive |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Error", wireType) + } + m.Error = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Error |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 10: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ConsecutiveError", wireType) + } + m.ConsecutiveError = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ConsecutiveError |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *NewRelicMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: NewRelicMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: NewRelicMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Profile", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Profile = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Query", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Query = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *NginxTrafficRouting) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: NginxTrafficRouting: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: NginxTrafficRouting: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AnnotationPrefix", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AnnotationPrefix = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StableIngress", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.StableIngress = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AdditionalIngressAnnotations", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AdditionalIngressAnnotations == nil { + m.AdditionalIngressAnnotations = make(map[string]string) + } + var mapkey string + var mapvalue string + for iNdEx < postIndex { + entryPreIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + if fieldNum == 1 { + var stringLenmapkey uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapkey |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapkey := int(stringLenmapkey) + if intStringLenmapkey < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapkey := iNdEx + intStringLenmapkey + if postStringIndexmapkey < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapkey > l { + return io.ErrUnexpectedEOF + } + mapkey = string(dAtA[iNdEx:postStringIndexmapkey]) + iNdEx = postStringIndexmapkey + } else if fieldNum == 2 { + var stringLenmapvalue uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapvalue |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapvalue := int(stringLenmapvalue) + if intStringLenmapvalue < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapvalue := iNdEx + intStringLenmapvalue + if postStringIndexmapvalue < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapvalue > l { + return io.ErrUnexpectedEOF + } + mapvalue = string(dAtA[iNdEx:postStringIndexmapvalue]) + iNdEx = postStringIndexmapvalue + } else { + iNdEx = entryPreIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > postIndex { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + m.AdditionalIngressAnnotations[mapkey] = mapvalue + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PauseCondition) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PauseCondition: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PauseCondition: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Reason = PauseReason(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StartTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.StartTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PodTemplateMetadata) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PodTemplateMetadata: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PodTemplateMetadata: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Labels", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Labels == nil { + m.Labels = make(map[string]string) + } + var mapkey string + var mapvalue string + for iNdEx < postIndex { + entryPreIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + if fieldNum == 1 { + var stringLenmapkey uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapkey |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapkey := int(stringLenmapkey) + if intStringLenmapkey < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapkey := iNdEx + intStringLenmapkey + if postStringIndexmapkey < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapkey > l { + return io.ErrUnexpectedEOF + } + mapkey = string(dAtA[iNdEx:postStringIndexmapkey]) + iNdEx = postStringIndexmapkey + } else if fieldNum == 2 { + var stringLenmapvalue uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapvalue |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapvalue := int(stringLenmapvalue) + if intStringLenmapvalue < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapvalue := iNdEx + intStringLenmapvalue + if postStringIndexmapvalue < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapvalue > l { + return io.ErrUnexpectedEOF + } + mapvalue = string(dAtA[iNdEx:postStringIndexmapvalue]) + iNdEx = postStringIndexmapvalue + } else { + iNdEx = entryPreIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > postIndex { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + m.Labels[mapkey] = mapvalue + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Annotations", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Annotations == nil { + m.Annotations = make(map[string]string) + } + var mapkey string + var mapvalue string + for iNdEx < postIndex { + entryPreIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + if fieldNum == 1 { + var stringLenmapkey uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapkey |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapkey := int(stringLenmapkey) + if intStringLenmapkey < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapkey := iNdEx + intStringLenmapkey + if postStringIndexmapkey < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapkey > l { + return io.ErrUnexpectedEOF + } + mapkey = string(dAtA[iNdEx:postStringIndexmapkey]) + iNdEx = postStringIndexmapkey + } else if fieldNum == 2 { + var stringLenmapvalue uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLenmapvalue |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLenmapvalue := int(stringLenmapvalue) + if intStringLenmapvalue < 0 { + return ErrInvalidLengthGenerated + } + postStringIndexmapvalue := iNdEx + intStringLenmapvalue + if postStringIndexmapvalue < 0 { + return ErrInvalidLengthGenerated + } + if postStringIndexmapvalue > l { + return io.ErrUnexpectedEOF + } + mapvalue = string(dAtA[iNdEx:postStringIndexmapvalue]) + iNdEx = postStringIndexmapvalue + } else { + iNdEx = entryPreIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > postIndex { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + m.Annotations[mapkey] = mapvalue + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PreferredDuringSchedulingIgnoredDuringExecution) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PreferredDuringSchedulingIgnoredDuringExecution: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PreferredDuringSchedulingIgnoredDuringExecution: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Weight", wireType) + } + m.Weight = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Weight |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *PrometheusMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PrometheusMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PrometheusMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Address = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Query", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Query = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RequiredDuringSchedulingIgnoredDuringExecution) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RequiredDuringSchedulingIgnoredDuringExecution: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RequiredDuringSchedulingIgnoredDuringExecution: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Rollout) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Rollout: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Rollout: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObjectMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ObjectMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Spec", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Spec.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Status.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutAnalysis) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutAnalysis: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutAnalysis: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Templates", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Templates = append(m.Templates, RolloutAnalysisTemplate{}) + if err := m.Templates[len(m.Templates)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Args", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Args = append(m.Args, AnalysisRunArgument{}) + if err := m.Args[len(m.Args)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutAnalysisBackground) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutAnalysisBackground: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutAnalysisBackground: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RolloutAnalysis", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.RolloutAnalysis.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field StartingStep", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.StartingStep = &v + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutAnalysisRunStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutAnalysisRunStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutAnalysisRunStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = AnalysisPhase(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutAnalysisTemplate) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutAnalysisTemplate: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutAnalysisTemplate: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TemplateName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TemplateName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ClusterScope", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ClusterScope = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutCondition) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutCondition: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutCondition: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Type", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Type = RolloutConditionType(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = k8s_io_api_core_v1.ConditionStatus(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastUpdateTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastUpdateTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastTransitionTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Reason = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutExperimentStep) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutExperimentStep: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutExperimentStep: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Templates", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Templates = append(m.Templates, RolloutExperimentTemplate{}) + if err := m.Templates[len(m.Templates)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Duration", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Duration = DurationString(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Analyses", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Analyses = append(m.Analyses, RolloutExperimentStepAnalysisTemplateRef{}) + if err := m.Analyses[len(m.Analyses)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutExperimentStepAnalysisTemplateRef) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutExperimentStepAnalysisTemplateRef: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutExperimentStepAnalysisTemplateRef: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TemplateName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TemplateName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ClusterScope", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ClusterScope = bool(v != 0) + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Args", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Args = append(m.Args, AnalysisRunArgument{}) + if err := m.Args[len(m.Args)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RequiredForCompletion", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.RequiredForCompletion = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutExperimentTemplate) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutExperimentTemplate: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutExperimentTemplate: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SpecRef", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.SpecRef = ReplicaSetSpecRef(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Replicas = &v + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Metadata", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Metadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Selector", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Selector == nil { + m.Selector = &v1.LabelSelector{} + } + if err := m.Selector.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutList) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutList: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutList: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ListMeta", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ListMeta.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Items", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Items = append(m.Items, Rollout{}) + if err := m.Items[len(m.Items)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutPause) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutPause: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutPause: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Duration", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Duration == nil { + m.Duration = &intstr.IntOrString{} + } + if err := m.Duration.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutSpec) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutSpec: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutSpec: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Replicas = &v + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Selector", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Selector == nil { + m.Selector = &v1.LabelSelector{} + } + if err := m.Selector.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Template", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Template.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field MinReadySeconds", wireType) + } + m.MinReadySeconds = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.MinReadySeconds |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Strategy", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Strategy.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RevisionHistoryLimit", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.RevisionHistoryLimit = &v + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Paused", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Paused = bool(v != 0) + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ProgressDeadlineSeconds", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ProgressDeadlineSeconds = &v + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RestartAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.RestartAt == nil { + m.RestartAt = &v1.Time{} + } + if err := m.RestartAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Abort", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Abort = bool(v != 0) + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PauseConditions", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.PauseConditions = append(m.PauseConditions, PauseCondition{}) + if err := m.PauseConditions[len(m.PauseConditions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ControllerPause", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ControllerPause = bool(v != 0) + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AbortedAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AbortedAt == nil { + m.AbortedAt = &v1.Time{} + } + if err := m.AbortedAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentPodHash", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CurrentPodHash = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentStepHash", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.CurrentStepHash = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + m.Replicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Replicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field UpdatedReplicas", wireType) + } + m.UpdatedReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.UpdatedReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ReadyReplicas", wireType) + } + m.ReadyReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ReadyReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 10: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AvailableReplicas", wireType) + } + m.AvailableReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.AvailableReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 11: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentStepIndex", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.CurrentStepIndex = &v + case 12: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field CollisionCount", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.CollisionCount = &v + case 13: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ObservedGeneration", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ObservedGeneration = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 14: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Conditions", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Conditions = append(m.Conditions, RolloutCondition{}) + if err := m.Conditions[len(m.Conditions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 15: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Canary", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Canary.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 16: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BlueGreen", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.BlueGreen.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 17: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field HPAReplicas", wireType) + } + m.HPAReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.HPAReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 18: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Selector", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Selector = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 19: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field StableRS", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.StableRS = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 20: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RestartedAt", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.RestartedAt == nil { + m.RestartedAt = &v1.Time{} + } + if err := m.RestartedAt.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 21: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field PromoteFull", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.PromoteFull = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutStrategy) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutStrategy: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutStrategy: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BlueGreen", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.BlueGreen == nil { + m.BlueGreen = &BlueGreenStrategy{} + } + if err := m.BlueGreen.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Canary", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Canary == nil { + m.Canary = &CanaryStrategy{} + } + if err := m.Canary.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *RolloutTrafficRouting) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: RolloutTrafficRouting: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: RolloutTrafficRouting: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Istio", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Istio == nil { + m.Istio = &IstioTrafficRouting{} + } + if err := m.Istio.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Nginx", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Nginx == nil { + m.Nginx = &NginxTrafficRouting{} + } + if err := m.Nginx.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ALB", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ALB == nil { + m.ALB = &ALBTrafficRouting{} + } + if err := m.ALB.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SMI", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.SMI == nil { + m.SMI = &SMITrafficRouting{} + } + if err := m.SMI.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SMITrafficRouting) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: SMITrafficRouting: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SMITrafficRouting: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RootService", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.RootService = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TrafficSplitName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TrafficSplitName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ScopeDetail) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ScopeDetail: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ScopeDetail: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Scope", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Scope = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Region", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Region = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Step", wireType) + } + m.Step = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Step |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Start", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Start = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field End", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.End = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SecretKeyRef) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: SecretKeyRef: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SecretKeyRef: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Key = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SetCanaryScale) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: SetCanaryScale: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SetCanaryScale: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Weight", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Weight = &v + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Replicas = &v + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field MatchTrafficWeight", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.MatchTrafficWeight = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *TemplateSpec) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TemplateSpec: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TemplateSpec: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Replicas = &v + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field MinReadySeconds", wireType) + } + m.MinReadySeconds = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.MinReadySeconds |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Selector", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Selector == nil { + m.Selector = &v1.LabelSelector{} + } + if err := m.Selector.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Template", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Template.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *TemplateStatus) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TemplateStatus: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TemplateStatus: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Replicas", wireType) + } + m.Replicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Replicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field UpdatedReplicas", wireType) + } + m.UpdatedReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.UpdatedReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ReadyReplicas", wireType) + } + m.ReadyReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ReadyReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AvailableReplicas", wireType) + } + m.AvailableReplicas = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.AvailableReplicas |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field CollisionCount", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int32(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.CollisionCount = &v + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = TemplateStatusCode(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.LastTransitionTime == nil { + m.LastTransitionTime = &v1.Time{} + } + if err := m.LastTransitionTime.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *ValueFrom) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: ValueFrom: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ValueFrom: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SecretKeyRef", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.SecretKeyRef == nil { + m.SecretKeyRef = &SecretKeyRef{} + } + if err := m.SecretKeyRef.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field FieldRef", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.FieldRef == nil { + m.FieldRef = &FieldRef{} + } + if err := m.FieldRef.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *WavefrontMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: WavefrontMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: WavefrontMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Address = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Query", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Query = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *WebMetric) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: WebMetric: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: WebMetric: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field URL", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.URL = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Headers", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Headers = append(m.Headers, WebMetricHeader{}) + if err := m.Headers[len(m.Headers)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TimeoutSeconds", wireType) + } + m.TimeoutSeconds = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TimeoutSeconds |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field JSONPath", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.JSONPath = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Insecure", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Insecure = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *WebMetricHeader) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: WebMetricHeader: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: WebMetricHeader: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Key = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenerated + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Value = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipGenerated(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenerated + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenerated + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenerated + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthGenerated + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupGenerated + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthGenerated + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthGenerated = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowGenerated = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupGenerated = fmt.Errorf("proto: unexpected end of group") +) diff --git a/pkg/apis/rollouts/v1alpha1/generated.proto b/pkg/apis/rollouts/v1alpha1/generated.proto new file mode 100644 index 0000000000..4c6221626a --- /dev/null +++ b/pkg/apis/rollouts/v1alpha1/generated.proto @@ -0,0 +1,1224 @@ +/* +Copyright 2021 The Kubernetes sample-controller 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. +*/ + + +// This file was autogenerated by go-to-protobuf. Do not edit it manually! + +syntax = "proto2"; + +package github.com.argoproj.argo_rollouts.pkg.apis.rollouts.v1alpha1; + +import "k8s.io/api/batch/v1/generated.proto"; +import "k8s.io/api/core/v1/generated.proto"; +import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; +import "k8s.io/apimachinery/pkg/runtime/generated.proto"; +import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; +import "k8s.io/apimachinery/pkg/util/intstr/generated.proto"; + +// Package-wide variables from generator "generated". +option go_package = "v1alpha1"; + +// ALBTrafficRouting configuration for ALB ingress controller to control traffic routing +message ALBTrafficRouting { + // Ingress refers to the name of an `Ingress` resource in the same namespace as the `Rollout` + optional string ingress = 1; + + // ServicePort refers to the port that the Ingress action should route traffic to + optional int32 servicePort = 2; + + // RootService references the service in the ingress to the controller should add the action to + optional string rootService = 3; + + // AnnotationPrefix has to match the configured annotation prefix on the alb ingress controller + // +optional + optional string annotationPrefix = 4; +} + +// AnalysisRun is an instantiation of an AnalysisTemplate +// +genclient +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +// +kubebuilder:resource:path=analysisruns, shortName=ar +// +kubebuilder:printcolumn:name="Status",type="string",JSONPath=".status.phase",description="AnalysisRun status" +message AnalysisRun { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional AnalysisRunSpec spec = 2; + + optional AnalysisRunStatus status = 3; +} + +// AnalysisRunArgument argument to add to analysisRun +message AnalysisRunArgument { + // Name argument name + optional string name = 1; + + // Value a hardcoded value for the argument. This field is a one of field with valueFrom + optional string value = 2; + + // ValueFrom A reference to where the value is stored. This field is a one of field with valueFrom + optional ArgumentValueFrom valueFrom = 3; +} + +// AnalysisRunList is a list of AnalysisTemplate resources +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +message AnalysisRunList { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; + + repeated AnalysisRun items = 2; +} + +// AnalysisRunSpec is the spec for a AnalysisRun resource +message AnalysisRunSpec { + // Metrics contains the list of metrics to query as part of an analysis run + // +patchMergeKey=name + // +patchStrategy=merge + repeated Metric metrics = 1; + + // Args are the list of arguments used in this run + // +optional + // +patchMergeKey=name + // +patchStrategy=merge + repeated Argument args = 2; + + // Terminate is used to prematurely stop the run (e.g. rollout completed and analysis is no longer desired) + optional bool terminate = 3; +} + +// AnalysisRunStatus is the status for a AnalysisRun resource +message AnalysisRunStatus { + // Phase is the status of the analysis run + optional string phase = 1; + + // Message is a message explaining current status + optional string message = 2; + + // MetricResults contains the metrics collected during the run + repeated MetricResult metricResults = 3; + + // StartedAt indicates when the analysisRun first started + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time startedAt = 4; +} + +// AnalysisTemplate holds the template for performing canary analysis +// +genclient +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +// +kubebuilder:resource:path=analysistemplates,shortName=at +message AnalysisTemplate { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional AnalysisTemplateSpec spec = 2; +} + +// AnalysisTemplateList is a list of AnalysisTemplate resources +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +message AnalysisTemplateList { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; + + repeated AnalysisTemplate items = 2; +} + +// AnalysisTemplateSpec is the specification for a AnalysisTemplate resource +message AnalysisTemplateSpec { + // Metrics contains the list of metrics to query as part of an analysis run + // +patchMergeKey=name + // +patchStrategy=merge + repeated Metric metrics = 1; + + // Args are the list of arguments to the template + // +patchMergeKey=name + // +patchStrategy=merge + // +optional + repeated Argument args = 2; +} + +// AntiAffinity defines which inter-pod scheduling rule to use for anti-affinity injection +message AntiAffinity { + // +optional + optional PreferredDuringSchedulingIgnoredDuringExecution preferredDuringSchedulingIgnoredDuringExecution = 1; + + // +optional + optional RequiredDuringSchedulingIgnoredDuringExecution requiredDuringSchedulingIgnoredDuringExecution = 2; +} + +// Argument is an argument to an AnalysisRun +message Argument { + // Name is the name of the argument + optional string name = 1; + + // Value is the value of the argument + // +optional + optional string value = 2; + + // ValueFrom is a reference to where a secret is stored. This field is one of the fields with valueFrom + // +optional + optional ValueFrom valueFrom = 3; +} + +// ArgumentValueFrom defines references to fields within resources to grab for the value (i.e. Pod Template Hash) +message ArgumentValueFrom { + // PodTemplateHashValue gets the value from one of the children ReplicaSet's Pod Template Hash + optional string podTemplateHashValue = 1; + + // FieldRef + optional FieldRef fieldRef = 2; +} + +// BlueGreenStatus status fields that only pertain to the blueGreen rollout +message BlueGreenStatus { + // PreviewSelector indicates which replicas set the preview service is serving traffic to + // +optional + optional string previewSelector = 1; + + // ActiveSelector indicates which replicas set the active service is serving traffic to + // +optional + optional string activeSelector = 2; + + // ScaleUpPreviewCheckPoint indicates that the Replicaset receiving traffic from the preview service is ready to be scaled up after the rollout is unpaused + // +optional + optional bool scaleUpPreviewCheckPoint = 3; + + // PrePromotionAnalysisRunStatus indicates the status of the current prepromotion analysis run + optional RolloutAnalysisRunStatus prePromotionAnalysisRunStatus = 4; + + // PostPromotionAnalysisRunStatus indicates the status of the current post promotion analysis run + optional RolloutAnalysisRunStatus postPromotionAnalysisRunStatus = 5; +} + +// BlueGreenStrategy defines parameters for Blue Green deployment +message BlueGreenStrategy { + // Name of the service that the rollout modifies as the active service. + optional string activeService = 1; + + // Name of the service that the rollout modifies as the preview service. + // +optional + optional string previewService = 2; + + // PreviewReplicaCount is the number of replicas to run for the preview stack before the + // switchover. Once the rollout is resumed the desired replicaset will be full scaled up before the switch occurs + // +optional + optional int32 previewReplicaCount = 3; + + // AutoPromotionEnabled indicates if the rollout should automatically promote the new ReplicaSet + // to the active service or enter a paused state. If not specified, the default value is true. + // +optional + optional bool autoPromotionEnabled = 4; + + // AutoPromotionSeconds is a duration in seconds in which to delay auto-promotion (default: 0). + // The countdown begins after the preview ReplicaSet have reached full availability. + // This option is ignored if autoPromotionEnabled is set to false. + // +optional + optional int32 autoPromotionSeconds = 5; + + // MaxUnavailable The maximum number of pods that can be unavailable during a restart operation. + // Defaults to 25% of total replicas. + // +optional + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 6; + + // ScaleDownDelaySeconds adds a delay before scaling down the previous replicaset. + // If omitted, the Rollout waits 30 seconds before scaling down the previous ReplicaSet. + // A minimum of 30 seconds is recommended to ensure IP table propagation across the nodes in + // a cluster. See https://github.com/argoproj/argo-rollouts/issues/19#issuecomment-476329960 for + // more information + // +optional + optional int32 scaleDownDelaySeconds = 7; + + // ScaleDownDelayRevisionLimit limits the number of old RS that can run at one time before getting scaled down + // +optional + optional int32 scaleDownDelayRevisionLimit = 8; + + // PrePromotionAnalysis configuration to run analysis before a selector switch + optional RolloutAnalysis prePromotionAnalysis = 9; + + // AntiAffinity enables anti-affinity rules for Blue Green deployment + // +optional + optional AntiAffinity antiAffinity = 10; + + // PostPromotionAnalysis configuration to run analysis after a selector switch + optional RolloutAnalysis postPromotionAnalysis = 11; + + // PreviewMetadata specify labels and annotations which will be attached to the preview pods for + // the duration which they act as a preview pod, and will be removed after + optional PodTemplateMetadata previewMetadata = 12; + + // ActiveMetadata specify labels and annotations which will be attached to the active pods for + // the duration which they act as a active pod, and will be removed after + optional PodTemplateMetadata activeMetadata = 13; +} + +// CanaryStatus status fields that only pertain to the canary rollout +message CanaryStatus { + // CurrentStepAnalysisRunStatus indicates the status of the current step analysis run + optional RolloutAnalysisRunStatus currentStepAnalysisRunStatus = 1; + + // CurrentBackgroundAnalysisRunStatus indicates the status of the current background analysis run + optional RolloutAnalysisRunStatus currentBackgroundAnalysisRunStatus = 2; + + // CurrentExperiment indicates the running experiment + optional string currentExperiment = 3; +} + +// CanaryStep defines a step of a canary deployment. +message CanaryStep { + // SetWeight sets what percentage of the newRS should receive + optional int32 setWeight = 1; + + // Pause freezes the rollout by setting spec.Paused to true. + // A Rollout will resume when spec.Paused is reset to false. + // +optional + optional RolloutPause pause = 2; + + // Experiment defines the experiment object that should be created + optional RolloutExperimentStep experiment = 3; + + // Analysis defines the AnalysisRun that will run for a step + optional RolloutAnalysis analysis = 4; + + // SetCanaryScale defines how to scale the newRS without changing traffic weight + // +optional + optional SetCanaryScale setCanaryScale = 5; +} + +// CanaryStrategy defines parameters for a Replica Based Canary +message CanaryStrategy { + // CanaryService holds the name of a service which selects pods with canary version and don't select any pods with stable version. + // +optional + optional string canaryService = 1; + + // StableService holds the name of a service which selects pods with stable version and don't select any pods with canary version. + // +optional + optional string stableService = 2; + + // Steps define the order of phases to execute the canary deployment + // +optional + repeated CanaryStep steps = 3; + + // TrafficRouting hosts all the supported service meshes supported to enable more fine-grained traffic routing + optional RolloutTrafficRouting trafficRouting = 4; + + // MaxUnavailable The maximum number of pods that can be unavailable during the update. + // Value can be an absolute number (ex: 5) or a percentage of total pods at the start of update (ex: 10%). + // Absolute number is calculated from percentage by rounding down. + // This can not be 0 if MaxSurge is 0. + // By default, a fixed value of 25% is used. + // Example: when this is set to 30%, the old RC can be scaled down by 30% + // immediately when the rolling update starts. Once new pods are ready, old RC + // can be scaled down further, followed by scaling up the new RC, ensuring + // that at least 70% of original number of pods are available at all times + // during the update. + // +optional + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 5; + + // MaxSurge The maximum number of pods that can be scheduled above the original number of + // pods. + // Value can be an absolute number (ex: 5) or a percentage of total pods at + // the start of the update (ex: 10%). This can not be 0 if MaxUnavailable is 0. + // Absolute number is calculated from percentage by rounding up. + // By default, a value of 25% is used. + // Example: when this is set to 30%, the new RC can be scaled up by 30% + // immediately when the rolling update starts. Once old pods have been killed, + // new RC can be scaled up further, ensuring that total number of pods running + // at any time during the update is at most 130% of original pods. + // +optional + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxSurge = 6; + + // Analysis runs a separate analysisRun while all the steps execute. This is intended to be a continuous validation of the new ReplicaSet + optional RolloutAnalysisBackground analysis = 7; + + // AntiAffinity enables anti-affinity rules for Canary deployment + // +optional + optional AntiAffinity antiAffinity = 8; + + // CanaryMetadata specify labels and annotations which will be attached to the canary pods for + // the duration which they act as a canary, and will be removed after + optional PodTemplateMetadata canaryMetadata = 9; + + // StableMetadata specify labels and annotations which will be attached to the stable pods for + // the duration which they act as a canary, and will be removed after + optional PodTemplateMetadata stableMetadata = 10; +} + +// ClusterAnalysisTemplate holds the template for performing canary analysis +// +genclient +// +genclient:nonNamespaced +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +// +kubebuilder:resource:path=clusteranalysistemplates,shortName=cat +message ClusterAnalysisTemplate { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional AnalysisTemplateSpec spec = 2; +} + +// AnalysisTemplateList is a list of AnalysisTemplate resources +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +message ClusterAnalysisTemplateList { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; + + repeated ClusterAnalysisTemplate items = 2; +} + +message DatadogMetric { + optional string interval = 1; + + optional string query = 2; +} + +// Experiment is a specification for an Experiment resource +// +genclient +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object +// +kubebuilder:resource:path=experiments,shortName=exp +// +kubebuilder:printcolumn:name="Status",type="string",JSONPath=".status.phase",description="Experiment status" +message Experiment { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional ExperimentSpec spec = 2; + + optional ExperimentStatus status = 3; +} + +message ExperimentAnalysisRunStatus { + // Name is the name of the analysis + optional string name = 1; + + // AnalysisRun is the name of the AnalysisRun + optional string analysisRun = 2; + + // Phase is the status of the AnalysisRun + optional string phase = 3; + + // Message is a message explaining the current status + optional string message = 4; +} + +message ExperimentAnalysisTemplateRef { + // Name is the name of the analysis + optional string name = 1; + + // TemplateName reference of the AnalysisTemplate name used by the Experiment to create the run + optional string templateName = 2; + + // Whether to look for the templateName at cluster scope or namespace scope + // +optional + optional bool clusterScope = 3; + + // Args are the arguments that will be added to the AnalysisRuns + // +optional + // +patchMergeKey=name + // +patchStrategy=merge + repeated Argument args = 4; + + // RequiredForCompletion blocks the Experiment from completing until the analysis has completed + optional bool requiredForCompletion = 5; +} + +// ExperimentCondition describes the state of a experiment at a certain point. +message ExperimentCondition { + // Type of deployment condition. + optional string type = 1; + + // Phase of the condition, one of True, False, Unknown. + optional string status = 2; + + // The last time this condition was updated. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastUpdateTime = 3; + + // Last time the condition transitioned from one status to another. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 4; + + // The reason for the condition's last transition. + optional string reason = 5; + + // A human readable message indicating details about the transition. + optional string message = 6; +} + +// ExperimentList is a list of Experiment resources +message ExperimentList { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; + + repeated Experiment items = 2; +} + +// ExperimentSpec is the spec for a Experiment resource +message ExperimentSpec { + // Templates are a list of PodSpecs that define the ReplicaSets that should be run during an experiment. + // +patchMergeKey=name + // +patchStrategy=merge + repeated TemplateSpec templates = 1; + + // Duration the amount of time for the experiment to run as a duration string (e.g. 30s, 5m, 1h). + // If omitted, the experiment will run indefinitely, stopped either via termination, or a failed analysis run. + // +optional + optional string duration = 2; + + // ProgressDeadlineSeconds The maximum time in seconds for a experiment to + // make progress before it is considered to be failed. Argo Rollouts will + // continue to process failed experiments and a condition with a + // ProgressDeadlineExceeded reason will be surfaced in the experiment status. + // Defaults to 600s. + // +optional + optional int32 progressDeadlineSeconds = 3; + + // Terminate is used to prematurely stop the experiment + optional bool terminate = 4; + + // Analyses references AnalysisTemplates to run during the experiment + // +patchMergeKey=name + // +patchStrategy=merge + repeated ExperimentAnalysisTemplateRef analyses = 5; +} + +// ExperimentStatus is the status for a Experiment resource +message ExperimentStatus { + // Phase is the status of the experiment. Takes into consideration ReplicaSet degradations and + // AnalysisRun statuses + optional string phase = 1; + + // Message is an explanation for the current status + // +optional + optional string message = 2; + + // TemplateStatuses holds the ReplicaSet related statuses for individual templates + // +optional + repeated TemplateStatus templateStatuses = 3; + + // AvailableAt the time when all the templates become healthy and the experiment should start tracking the time to + // run for the duration of specificed in the spec. + // +optional + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time availableAt = 4; + + // Conditions a list of conditions a experiment can have. + // +optional + repeated ExperimentCondition conditions = 5; + + // AnalysisRuns tracks the status of AnalysisRuns associated with this Experiment + // +optional + repeated ExperimentAnalysisRunStatus analysisRuns = 6; +} + +message FieldRef { + // Required: Path of the field to select in the specified API version + optional string fieldPath = 1; +} + +// IstioDestinationRule is a reference to an Istio DestinationRule to modify and shape traffic +message IstioDestinationRule { + // Name holds the name of the DestinationRule + optional string name = 1; + + // CanarySubsetName is the subset name to modify labels with canary ReplicaSet pod template hash value + optional string canarySubsetName = 2; + + // StableSubsetName is the subset name to modify labels with stable ReplicaSet pod template hash value + optional string stableSubsetName = 3; +} + +// IstioTrafficRouting configuration for Istio service mesh to enable fine grain configuration +message IstioTrafficRouting { + // VirtualService references an Istio VirtualService to modify to shape traffic + optional IstioVirtualService virtualService = 1; + + // DestinationRule references an Istio DestinationRule to modify to shape traffic + optional IstioDestinationRule destinationRule = 2; +} + +// IstioVirtualService holds information on the virtual service the rollout needs to modify +message IstioVirtualService { + // Name holds the name of the VirtualService + optional string name = 1; + + // Routes list of routes within VirtualService to edit + repeated string routes = 2; +} + +// JobMetric defines a job to run which acts as a metric +message JobMetric { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional k8s.io.api.batch.v1.JobSpec spec = 2; +} + +message KayentaMetric { + optional string address = 1; + + optional string application = 2; + + optional string canaryConfigName = 3; + + optional string metricsAccountName = 4; + + optional string configurationAccountName = 5; + + optional string storageAccountName = 6; + + optional KayentaThreshold threshold = 7; + + repeated KayentaScope scopes = 8; +} + +message KayentaScope { + optional string name = 1; + + optional ScopeDetail controlScope = 2; + + optional ScopeDetail experimentScope = 3; +} + +message KayentaThreshold { + optional int64 pass = 1; + + optional int64 marginal = 2; +} + +// Measurement is a point in time result value of a single metric, and the time it was measured +message Measurement { + // Phase is the status of this single measurement + optional string phase = 1; + + // Message contains a message describing current condition (e.g. error messages) + optional string message = 2; + + // StartedAt is the timestamp in which this measurement started to be measured + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time startedAt = 3; + + // FinishedAt is the timestamp in which this measurement completed and value was collected + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time finishedAt = 4; + + // Value is the measured value of the metric + optional string value = 5; + + // Metadata stores additional metadata about this metric result, used by the different providers + // (e.g. kayenta run ID, job name) + map metadata = 6; + + // ResumeAt is the timestamp when the analysisRun should try to resume the measurement + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time resumeAt = 7; +} + +// Metric defines a metric in which to perform analysis +message Metric { + // Name is the name of the metric + optional string name = 1; + + // Interval defines an interval string (e.g. 30s, 5m, 1h) between each measurement. + // If omitted, will perform a single measurement + optional string interval = 2; + + // InitialDelay how long the AnalysisRun should wait before starting this metric + optional string initialDelay = 3; + + // Count is the number of times to run the measurement. If both interval and count are omitted, + // the effective count is 1. If only interval is specified, metric runs indefinitely. + // If count > 1, interval must be specified. + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString count = 4; + + // SuccessCondition is an expression which determines if a measurement is considered successful + // Expression is a goevaluate expression. The keyword `result` is a variable reference to the + // value of measurement. Results can be both structured data or primitive. + // Examples: + // result > 10 + // (result.requests_made * result.requests_succeeded / 100) >= 90 + optional string successCondition = 5; + + // FailureCondition is an expression which determines if a measurement is considered failed + // If both success and failure conditions are specified, and the measurement does not fall into + // either condition, the measurement is considered Inconclusive + optional string failureCondition = 6; + + // FailureLimit is the maximum number of times the measurement is allowed to fail, before the + // entire metric is considered Failed (default: 0) + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString failureLimit = 7; + + // InconclusiveLimit is the maximum number of times the measurement is allowed to measure + // Inconclusive, before the entire metric is considered Inconclusive (default: 0) + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString inconclusiveLimit = 8; + + // ConsecutiveErrorLimit is the maximum number of times the measurement is allowed to error in + // succession, before the metric is considered error (default: 4) + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString consecutiveErrorLimit = 9; + + // Provider configuration to the external system to use to verify the analysis + optional MetricProvider provider = 10; +} + +// MetricProvider which external system to use to verify the analysis +// Only one of the fields in this struct should be non-nil +message MetricProvider { + // Prometheus specifies the prometheus metric to query + optional PrometheusMetric prometheus = 1; + + // Kayenta specifies a Kayenta metric + optional KayentaMetric kayenta = 2; + + // Web specifies a generic HTTP web metric + optional WebMetric web = 3; + + // Datadog specifies a datadog metric to query + optional DatadogMetric datadog = 4; + + // Wavefront specifies the wavefront metric to query + optional WavefrontMetric wavefront = 5; + + // NewRelic specifies the newrelic metric to query + optional NewRelicMetric newRelic = 6; + + // Job specifies the job metric run + optional JobMetric job = 7; +} + +// MetricResult contain a list of the most recent measurements for a single metric along with +// counters on how often the measurement +message MetricResult { + // Name is the name of the metric + optional string name = 1; + + // Phase is the overall aggregate status of the metric + optional string phase = 2; + + // Measurements holds the most recent measurements collected for the metric + repeated Measurement measurements = 3; + + // Message contains a message describing current condition (e.g. error messages) + optional string message = 4; + + // Count is the number of times the metric was measured without Error + // This is equal to the sum of Successful, Failed, Inconclusive + optional int32 count = 5; + + // Successful is the number of times the metric was measured Successful + optional int32 successful = 6; + + // Failed is the number of times the metric was measured Failed + optional int32 failed = 7; + + // Inconclusive is the number of times the metric was measured Inconclusive + optional int32 inconclusive = 8; + + // Error is the number of times an error was encountered during measurement + optional int32 error = 9; + + // ConsecutiveError is the number of times an error was encountered during measurement in succession + // Resets to zero when non-errors are encountered + optional int32 consecutiveError = 10; +} + +// NewRelicMetric defines the newrelic query to perform canary analysis +message NewRelicMetric { + // Profile is the name of the secret holding NR account configuration + optional string profile = 1; + + // Query is a raw newrelic NRQL query to perform + optional string query = 2; +} + +// NginxTrafficRouting configuration for Nginx ingress controller to control traffic routing +message NginxTrafficRouting { + // AnnotationPrefix has to match the configured annotation prefix on the nginx ingress controller + // +optional + optional string annotationPrefix = 1; + + // StableIngress refers to the name of an `Ingress` resource in the same namespace as the `Rollout` + optional string stableIngress = 2; + + // +optional + map additionalIngressAnnotations = 3; +} + +// PauseCondition the reason for a pause and when it started +message PauseCondition { + optional string reason = 1; + + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time startTime = 2; +} + +// PodTemplateMetadata extra labels to add to the template +message PodTemplateMetadata { + // Labels Additional labels to add to the experiment + // +optional + map labels = 1; + + // Annotations additional annotations to add to the experiment + // +optional + map annotations = 2; +} + +// PreferredDuringSchedulingIgnoredDuringExecution defines the weight of the anti-affinity injection +message PreferredDuringSchedulingIgnoredDuringExecution { + // Weight associated with matching the corresponding podAffinityTerm, in the range 1-100. + optional int32 weight = 1; +} + +// PrometheusMetric defines the prometheus query to perform canary analysis +message PrometheusMetric { + // Address is the HTTP address and port of the prometheus server + optional string address = 1; + + // Query is a raw prometheus query to perform + optional string query = 2; +} + +// RequiredDuringSchedulingIgnoredDuringExecution defines inter-pod scheduling rule to be RequiredDuringSchedulingIgnoredDuringExecution +message RequiredDuringSchedulingIgnoredDuringExecution { +} + +// Rollout is a specification for a Rollout resource +message Rollout { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; + + optional RolloutSpec spec = 2; + + optional RolloutStatus status = 3; +} + +// RolloutAnalysis defines a template that is used to create a analysisRun +message RolloutAnalysis { + // Templates reference to a list of analysis templates to combine for an AnalysisRun + repeated RolloutAnalysisTemplate templates = 1; + + // Args the arguments that will be added to the AnalysisRuns + // +patchMergeKey=name + // +patchStrategy=merge + repeated AnalysisRunArgument args = 2; +} + +// RolloutAnalysisBackground defines a template that is used to create a background analysisRun +message RolloutAnalysisBackground { + optional RolloutAnalysis rolloutAnalysis = 1; + + // StartingStep indicates which step the background analysis should start on + // If not listed, controller defaults to 0 + optional int32 startingStep = 2; +} + +message RolloutAnalysisRunStatus { + optional string name = 1; + + optional string status = 2; + + optional string message = 3; +} + +message RolloutAnalysisTemplate { + // TemplateName name of template to use in AnalysisRun + // +optional + optional string templateName = 1; + + // Whether to look for the templateName at cluster scope or namespace scope + // +optional + optional bool clusterScope = 2; +} + +// RolloutCondition describes the state of a rollout at a certain point. +message RolloutCondition { + // Type of deployment condition. + optional string type = 1; + + // Phase of the condition, one of True, False, Unknown. + optional string status = 2; + + // The last time this condition was updated. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastUpdateTime = 3; + + // Last time the condition transitioned from one status to another. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 4; + + // The reason for the condition's last transition. + optional string reason = 5; + + // A human readable message indicating details about the transition. + optional string message = 6; +} + +// RolloutExperimentStep defines a template that is used to create a experiment for a step +message RolloutExperimentStep { + // Templates what templates that should be added to the experiment. Should be non-nil + // +patchMergeKey=name + // +patchStrategy=merge + repeated RolloutExperimentTemplate templates = 1; + + // Duration is a duration string (e.g. 30s, 5m, 1h) that the experiment should run for + // +optional + optional string duration = 2; + + // Analyses reference which analysis templates to run with the experiment + // +patchMergeKey=name + // +patchStrategy=merge + repeated RolloutExperimentStepAnalysisTemplateRef analyses = 3; +} + +message RolloutExperimentStepAnalysisTemplateRef { + // Name is a name for this analysis template invocation + optional string name = 1; + + // TemplateName reference of the AnalysisTemplate name used by the Experiment to create the run + optional string templateName = 2; + + // Whether to look for the templateName at cluster scope or namespace scope + // +optional + optional bool clusterScope = 3; + + // Args the arguments that will be added to the AnalysisRuns + // +patchMergeKey=name + // +patchStrategy=merge + repeated AnalysisRunArgument args = 4; + + // RequiredForCompletion blocks the Experiment from completing until the analysis has completed + optional bool requiredForCompletion = 5; +} + +// RolloutExperimentTemplate defines the template used to create experiments for the Rollout's experiment canary step +message RolloutExperimentTemplate { + // Name description of template that passed to the template + optional string name = 1; + + // SpecRef indicates where the rollout should get the RS template from + optional string specRef = 2; + + // Replicas replica count for the template + // +optional + optional int32 replicas = 3; + + // Metadata sets labels and annotations to use for the RS created from the template + // +optional + optional PodTemplateMetadata metadata = 4; + + // Selector overrides the selector to be used for the template's ReplicaSet. If omitted, will + // use the same selector as the Rollout + // +optional + optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 5; +} + +// RolloutList is a list of Rollout resources +message RolloutList { + optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; + + repeated Rollout items = 2; +} + +// RolloutPause defines a pause stage for a rollout +message RolloutPause { + // Duration the amount of time to wait before moving to the next step. + // +optional + optional k8s.io.apimachinery.pkg.util.intstr.IntOrString duration = 1; +} + +// RolloutSpec is the spec for a Rollout resource +message RolloutSpec { + // Number of desired pods. This is a pointer to distinguish between explicit + // zero and not specified. Defaults to 1. + // +optional + optional int32 replicas = 1; + + // Label selector for pods. Existing ReplicaSets whose pods are + // selected by this will be the ones affected by this rollout. + // It must match the pod template's labels. + optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; + + // Template describes the pods that will be created. + optional k8s.io.api.core.v1.PodTemplateSpec template = 3; + + // Minimum number of seconds for which a newly created pod should be ready + // without any of its container crashing, for it to be considered available. + // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional + optional int32 minReadySeconds = 4; + + // The deployment strategy to use to replace existing pods with new ones. + // +optional + optional RolloutStrategy strategy = 5; + + // The number of old ReplicaSets to retain. If unspecified, will retain 10 old ReplicaSets + optional int32 revisionHistoryLimit = 6; + + // Paused pauses the rollout at its current step. + optional bool paused = 7; + + // ProgressDeadlineSeconds The maximum time in seconds for a rollout to + // make progress before it is considered to be failed. Argo Rollouts will + // continue to process failed rollouts and a condition with a + // ProgressDeadlineExceeded reason will be surfaced in the rollout status. + // Note that progress will not be estimated during the time a rollout is paused. + // Defaults to 600s. + optional int32 progressDeadlineSeconds = 8; + + // RestartAt indicates when all the pods of a Rollout should be restarted + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time restartAt = 9; +} + +// RolloutStatus is the status for a Rollout resource +message RolloutStatus { + // Abort cancel the current rollout progression + optional bool abort = 1; + + // PauseConditions indicates why the rollout is currently paused + repeated PauseCondition pauseConditions = 2; + + // ControllerPause indicates the controller has paused the rollout. It is set to true when + // the controller adds a pause condition. This field helps to discern the scenario where a + // rollout was resumed after being paused by the controller (e.g. via the plugin). In that + // situation, the pauseConditions would have been cleared , but controllerPause would still be + // set to true. + optional bool controllerPause = 3; + + // AbortedAt indicates the controller reconciled an aborted rollout. The controller uses this to understand if + // the controller needs to do some specific work when a Rollout is aborted. For example, the reconcileAbort is used + // to indicate if the Rollout should enter an aborted state when the latest AnalysisRun is a failure, or the controller + // has already put the Rollout into an aborted and should create a new AnalysisRun. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time abortedAt = 4; + + // CurrentPodHash the hash of the current pod template + // +optional + optional string currentPodHash = 5; + + // CurrentStepHash the hash of the current list of steps for the current strategy. This is used to detect when the + // list of current steps change + // +optional + optional string currentStepHash = 6; + + // Total number of non-terminated pods targeted by this rollout (their labels match the selector). + // +optional + optional int32 replicas = 7; + + // Total number of non-terminated pods targeted by this rollout that have the desired template spec. + // +optional + optional int32 updatedReplicas = 8; + + // Total number of ready pods targeted by this rollout. + // +optional + optional int32 readyReplicas = 9; + + // Total number of available pods (ready for at least minReadySeconds) targeted by this rollout. + // +optional + optional int32 availableReplicas = 10; + + // CurrentStepIndex defines the current step of the rollout is on. If the current step index is null, the + // controller will execute the rollout. + // +optional + optional int32 currentStepIndex = 11; + + // Count of hash collisions for the Rollout. The Rollout controller uses this + // field as a collision avoidance mechanism when it needs to create the name for the + // newest ReplicaSet. + // +optional + optional int32 collisionCount = 12; + + // The generation observed by the rollout controller by taking a hash of the spec. + // +optional + optional string observedGeneration = 13; + + // Conditions a list of conditions a rollout can have. + // +optional + repeated RolloutCondition conditions = 14; + + // Canary describes the state of the canary rollout + // +optional + optional CanaryStatus canary = 15; + + // BlueGreen describes the state of the bluegreen rollout + // +optional + optional BlueGreenStatus blueGreen = 16; + + // HPAReplicas the number of non-terminated replicas that are receiving active traffic + // +optional + optional int32 HPAReplicas = 17; + + // Selector that identifies the pods that are receiving active traffic + // +optional + optional string selector = 18; + + // StableRS indicates the replicaset that has successfully rolled out + // +optional + optional string stableRS = 19; + + // RestartedAt indicates last time a Rollout was restarted + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time restartedAt = 20; + + // PromoteFull indicates if the rollout should perform a full promotion, skipping analysis and pauses. + optional bool promoteFull = 21; +} + +// RolloutStrategy defines strategy to apply during next rollout +message RolloutStrategy { + // +optional + optional BlueGreenStrategy blueGreen = 1; + + // +optional + optional CanaryStrategy canary = 2; +} + +// RolloutTrafficRouting hosts all the different configuration for supported service meshes to enable more fine-grained traffic routing +message RolloutTrafficRouting { + // Istio holds Istio specific configuration to route traffic + optional IstioTrafficRouting istio = 1; + + // Nginx holds Nginx Ingress specific configuration to route traffic + optional NginxTrafficRouting nginx = 2; + + // Nginx holds ALB Ingress specific configuration to route traffic + optional ALBTrafficRouting alb = 3; + + // SMI holds TrafficSplit specific configuration to route traffic + optional SMITrafficRouting smi = 4; +} + +// SMITrafficRouting configuration for TrafficSplit Custom Resource to control traffic routing +message SMITrafficRouting { + // RootService holds the name of that clients use to communicate. + // +optional + optional string rootService = 1; + + // TrafficSplitName holds the name of the TrafficSplit. + // +optional + optional string trafficSplitName = 2; +} + +message ScopeDetail { + optional string scope = 1; + + optional string region = 2; + + optional int64 step = 3; + + optional string start = 4; + + optional string end = 5; +} + +message SecretKeyRef { + // Name is the name of the secret + optional string name = 1; + + // Key is the key of the secret to select from. + optional string key = 2; +} + +// SetCanaryScale defines how to scale the newRS without changing traffic weight +message SetCanaryScale { + // Weight sets the percentage of replicas the newRS should have + // +optional + optional int32 weight = 1; + + // Replicas sets the number of replicas the newRS should have + // +optional + optional int32 replicas = 2; + + // MatchTrafficWeight cancels out previously set Replicas or Weight, effectively activating SetWeight + // +optional + optional bool matchTrafficWeight = 3; +} + +message TemplateSpec { + // Name of the template used to identity replicaset running for this experiment + optional string name = 1; + + // Number of desired pods. This is a pointer to distinguish between explicit + // zero and not specified. Defaults to 1. + // +optional + optional int32 replicas = 2; + + // Minimum number of seconds for which a newly created pod should be ready + // without any of its container crashing, for it to be considered available. + // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional + optional int32 minReadySeconds = 3; + + // Label selector for pods. Existing ReplicaSets whose pods are + // selected by this will be the ones affected by this experiment. + // It must match the pod template's labels. Each selector must be unique to the other selectors in the other templates + optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; + + // Template describes the pods that will be created. + optional k8s.io.api.core.v1.PodTemplateSpec template = 5; +} + +// TemplateStatus is the status of a specific template of an Experiment +message TemplateStatus { + // Name of the template used to identity which hash to compare to the hash + optional string name = 1; + + // Total number of non-terminated pods targeted by this experiment (their labels match the selector). + optional int32 replicas = 2; + + // Total number of non-terminated pods targeted by this experiment that have the desired template spec. + optional int32 updatedReplicas = 3; + + // Total number of ready pods targeted by this experiment. + optional int32 readyReplicas = 4; + + // Total number of available pods (ready for at least minReadySeconds) targeted by this experiment. + optional int32 availableReplicas = 5; + + // CollisionCount count of hash collisions for the Experiment. The Experiment controller uses this + // field as a collision avoidance mechanism when it needs to create the name for the + // newest ReplicaSet. + // +optional + optional int32 collisionCount = 6; + + // Phase is the status of the ReplicaSet associated with the template + optional string status = 7; + + // Message is a message explaining the current status + optional string message = 8; + + // LastTransitionTime is the last time the replicaset transitioned, which resets the countdown + // on the ProgressDeadlineSeconds check. + optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 9; +} + +message ValueFrom { + // Secret is a reference to where a secret is stored. This field is one of the fields with valueFrom + // +optional + optional SecretKeyRef secretKeyRef = 1; + + // FieldRef is a reference to the fields in metadata which we are referencing. This field is one of the fields with + // valueFrom + // +optional + optional FieldRef fieldRef = 2; +} + +// WavefrontMetric defines the wavefront query to perform canary analysis +message WavefrontMetric { + // Address is the HTTP address and port of the wavefront server + optional string address = 1; + + // Query is a raw wavefront query to perform + optional string query = 2; +} + +message WebMetric { + // URL is the address of the web metric + optional string url = 1; + + // +patchMergeKey=key + // +patchStrategy=merge + // Headers are optional HTTP headers to use in the request + repeated WebMetricHeader headers = 2; + + // TimeoutSeconds is the timeout for the request in seconds (default: 10) + optional int64 timeoutSeconds = 3; + + // JSONPath is a JSON Path to use as the result variable (default: "{$}") + optional string jsonPath = 4; + + // Insecure skips host TLS verification + optional bool insecure = 5; +} + +message WebMetricHeader { + optional string key = 1; + + optional string value = 2; +} + diff --git a/pkg/apis/rollouts/v1alpha1/openapi_generated.go b/pkg/apis/rollouts/v1alpha1/openapi_generated.go index c82dfce767..6fcd0e038c 100644 --- a/pkg/apis/rollouts/v1alpha1/openapi_generated.go +++ b/pkg/apis/rollouts/v1alpha1/openapi_generated.go @@ -1759,14 +1759,14 @@ func schema_pkg_apis_rollouts_v1alpha1_KayentaThreshold(ref common.ReferenceCall SchemaProps: spec.SchemaProps{ Default: 0, Type: []string{"integer"}, - Format: "int32", + Format: "int64", }, }, "marginal": { SchemaProps: spec.SchemaProps{ Default: 0, Type: []string{"integer"}, - Format: "int32", + Format: "int64", }, }, }, @@ -3181,7 +3181,7 @@ func schema_pkg_apis_rollouts_v1alpha1_ScopeDetail(ref common.ReferenceCallback) SchemaProps: spec.SchemaProps{ Default: 0, Type: []string{"integer"}, - Format: "int32", + Format: "int64", }, }, "start": { @@ -3492,7 +3492,7 @@ func schema_pkg_apis_rollouts_v1alpha1_WebMetric(ref common.ReferenceCallback) c SchemaProps: spec.SchemaProps{ Description: "TimeoutSeconds is the timeout for the request in seconds (default: 10)", Type: []string{"integer"}, - Format: "int32", + Format: "int64", }, }, "jsonPath": { diff --git a/pkg/apis/rollouts/v1alpha1/types.go b/pkg/apis/rollouts/v1alpha1/types.go index aec5ac377a..5159d2e591 100644 --- a/pkg/apis/rollouts/v1alpha1/types.go +++ b/pkg/apis/rollouts/v1alpha1/types.go @@ -22,10 +22,10 @@ import ( // Rollout is a specification for a Rollout resource type Rollout struct { metav1.TypeMeta `json:",inline"` - metav1.ObjectMeta `json:"metadata,omitempty"` + metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - Spec RolloutSpec `json:"spec"` - Status RolloutStatus `json:"status,omitempty"` + Spec RolloutSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` + Status RolloutStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // RolloutSpec is the spec for a Rollout resource @@ -33,34 +33,34 @@ type RolloutSpec struct { // Number of desired pods. This is a pointer to distinguish between explicit // zero and not specified. Defaults to 1. // +optional - Replicas *int32 `json:"replicas,omitempty"` + Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` // Label selector for pods. Existing ReplicaSets whose pods are // selected by this will be the ones affected by this rollout. // It must match the pod template's labels. - Selector *metav1.LabelSelector `json:"selector"` + Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` // Template describes the pods that will be created. - Template corev1.PodTemplateSpec `json:"template"` + Template corev1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) // +optional - MinReadySeconds int32 `json:"minReadySeconds,omitempty"` + MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` // The deployment strategy to use to replace existing pods with new ones. // +optional - Strategy RolloutStrategy `json:"strategy"` + Strategy RolloutStrategy `json:"strategy" protobuf:"bytes,5,opt,name=strategy"` // The number of old ReplicaSets to retain. If unspecified, will retain 10 old ReplicaSets - RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty"` + RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` // Paused pauses the rollout at its current step. - Paused bool `json:"paused,omitempty"` + Paused bool `json:"paused,omitempty" protobuf:"varint,7,opt,name=paused"` // ProgressDeadlineSeconds The maximum time in seconds for a rollout to // make progress before it is considered to be failed. Argo Rollouts will // continue to process failed rollouts and a condition with a // ProgressDeadlineExceeded reason will be surfaced in the rollout status. // Note that progress will not be estimated during the time a rollout is paused. // Defaults to 600s. - ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty"` + ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty" protobuf:"varint,8,opt,name=progressDeadlineSeconds"` // RestartAt indicates when all the pods of a Rollout should be restarted - RestartAt *metav1.Time `json:"restartAt,omitempty"` + RestartAt *metav1.Time `json:"restartAt,omitempty" protobuf:"bytes,9,opt,name=restartAt"` } const ( @@ -84,72 +84,72 @@ const ( // RolloutStrategy defines strategy to apply during next rollout type RolloutStrategy struct { // +optional - BlueGreen *BlueGreenStrategy `json:"blueGreen,omitempty"` + BlueGreen *BlueGreenStrategy `json:"blueGreen,omitempty" protobuf:"bytes,1,opt,name=blueGreen"` // +optional - Canary *CanaryStrategy `json:"canary,omitempty"` + Canary *CanaryStrategy `json:"canary,omitempty" protobuf:"bytes,2,opt,name=canary"` } // BlueGreenStrategy defines parameters for Blue Green deployment type BlueGreenStrategy struct { // Name of the service that the rollout modifies as the active service. - ActiveService string `json:"activeService"` + ActiveService string `json:"activeService" protobuf:"bytes,1,opt,name=activeService"` // Name of the service that the rollout modifies as the preview service. // +optional - PreviewService string `json:"previewService,omitempty"` + PreviewService string `json:"previewService,omitempty" protobuf:"bytes,2,opt,name=previewService"` // PreviewReplicaCount is the number of replicas to run for the preview stack before the // switchover. Once the rollout is resumed the desired replicaset will be full scaled up before the switch occurs // +optional - PreviewReplicaCount *int32 `json:"previewReplicaCount,omitempty"` + PreviewReplicaCount *int32 `json:"previewReplicaCount,omitempty" protobuf:"varint,3,opt,name=previewReplicaCount"` // AutoPromotionEnabled indicates if the rollout should automatically promote the new ReplicaSet // to the active service or enter a paused state. If not specified, the default value is true. // +optional - AutoPromotionEnabled *bool `json:"autoPromotionEnabled,omitempty"` + AutoPromotionEnabled *bool `json:"autoPromotionEnabled,omitempty" protobuf:"varint,4,opt,name=autoPromotionEnabled"` // AutoPromotionSeconds is a duration in seconds in which to delay auto-promotion (default: 0). // The countdown begins after the preview ReplicaSet have reached full availability. // This option is ignored if autoPromotionEnabled is set to false. // +optional - AutoPromotionSeconds int32 `json:"autoPromotionSeconds,omitempty"` + AutoPromotionSeconds int32 `json:"autoPromotionSeconds,omitempty" protobuf:"varint,5,opt,name=autoPromotionSeconds"` // MaxUnavailable The maximum number of pods that can be unavailable during a restart operation. // Defaults to 25% of total replicas. // +optional - MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty"` + MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,6,opt,name=maxUnavailable"` // ScaleDownDelaySeconds adds a delay before scaling down the previous replicaset. // If omitted, the Rollout waits 30 seconds before scaling down the previous ReplicaSet. // A minimum of 30 seconds is recommended to ensure IP table propagation across the nodes in // a cluster. See https://github.com/argoproj/argo-rollouts/issues/19#issuecomment-476329960 for // more information // +optional - ScaleDownDelaySeconds *int32 `json:"scaleDownDelaySeconds,omitempty"` + ScaleDownDelaySeconds *int32 `json:"scaleDownDelaySeconds,omitempty" protobuf:"varint,7,opt,name=scaleDownDelaySeconds"` // ScaleDownDelayRevisionLimit limits the number of old RS that can run at one time before getting scaled down // +optional - ScaleDownDelayRevisionLimit *int32 `json:"scaleDownDelayRevisionLimit,omitempty"` + ScaleDownDelayRevisionLimit *int32 `json:"scaleDownDelayRevisionLimit,omitempty" protobuf:"varint,8,opt,name=scaleDownDelayRevisionLimit"` // PrePromotionAnalysis configuration to run analysis before a selector switch - PrePromotionAnalysis *RolloutAnalysis `json:"prePromotionAnalysis,omitempty"` + PrePromotionAnalysis *RolloutAnalysis `json:"prePromotionAnalysis,omitempty" protobuf:"bytes,9,opt,name=prePromotionAnalysis"` // AntiAffinity enables anti-affinity rules for Blue Green deployment // +optional - AntiAffinity *AntiAffinity `json:"antiAffinity,omitempty"` + AntiAffinity *AntiAffinity `json:"antiAffinity,omitempty" protobuf:"bytes,10,opt,name=antiAffinity"` // PostPromotionAnalysis configuration to run analysis after a selector switch - PostPromotionAnalysis *RolloutAnalysis `json:"postPromotionAnalysis,omitempty"` + PostPromotionAnalysis *RolloutAnalysis `json:"postPromotionAnalysis,omitempty" protobuf:"bytes,11,opt,name=postPromotionAnalysis"` // PreviewMetadata specify labels and annotations which will be attached to the preview pods for // the duration which they act as a preview pod, and will be removed after - PreviewMetadata *PodTemplateMetadata `json:"previewMetadata,omitempty"` + PreviewMetadata *PodTemplateMetadata `json:"previewMetadata,omitempty" protobuf:"bytes,12,opt,name=previewMetadata"` // ActiveMetadata specify labels and annotations which will be attached to the active pods for // the duration which they act as a active pod, and will be removed after - ActiveMetadata *PodTemplateMetadata `json:"activeMetadata,omitempty"` + ActiveMetadata *PodTemplateMetadata `json:"activeMetadata,omitempty" protobuf:"bytes,13,opt,name=activeMetadata"` } // AntiAffinity defines which inter-pod scheduling rule to use for anti-affinity injection type AntiAffinity struct { // +optional - PreferredDuringSchedulingIgnoredDuringExecution *PreferredDuringSchedulingIgnoredDuringExecution `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty"` + PreferredDuringSchedulingIgnoredDuringExecution *PreferredDuringSchedulingIgnoredDuringExecution `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,1,opt,name=preferredDuringSchedulingIgnoredDuringExecution"` // +optional - RequiredDuringSchedulingIgnoredDuringExecution *RequiredDuringSchedulingIgnoredDuringExecution `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty"` + RequiredDuringSchedulingIgnoredDuringExecution *RequiredDuringSchedulingIgnoredDuringExecution `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,2,opt,name=requiredDuringSchedulingIgnoredDuringExecution"` } // PreferredDuringSchedulingIgnoredDuringExecution defines the weight of the anti-affinity injection type PreferredDuringSchedulingIgnoredDuringExecution struct { // Weight associated with matching the corresponding podAffinityTerm, in the range 1-100. - Weight int32 `json:"weight"` + Weight int32 `json:"weight" protobuf:"varint,1,opt,name=weight"` } // RequiredDuringSchedulingIgnoredDuringExecution defines inter-pod scheduling rule to be RequiredDuringSchedulingIgnoredDuringExecution @@ -159,15 +159,15 @@ type RequiredDuringSchedulingIgnoredDuringExecution struct{} type CanaryStrategy struct { // CanaryService holds the name of a service which selects pods with canary version and don't select any pods with stable version. // +optional - CanaryService string `json:"canaryService,omitempty"` + CanaryService string `json:"canaryService,omitempty" protobuf:"bytes,1,opt,name=canaryService"` // StableService holds the name of a service which selects pods with stable version and don't select any pods with canary version. // +optional - StableService string `json:"stableService,omitempty"` + StableService string `json:"stableService,omitempty" protobuf:"bytes,2,opt,name=stableService"` // Steps define the order of phases to execute the canary deployment // +optional - Steps []CanaryStep `json:"steps,omitempty"` + Steps []CanaryStep `json:"steps,omitempty" protobuf:"bytes,3,rep,name=steps"` // TrafficRouting hosts all the supported service meshes supported to enable more fine-grained traffic routing - TrafficRouting *RolloutTrafficRouting `json:"trafficRouting,omitempty"` + TrafficRouting *RolloutTrafficRouting `json:"trafficRouting,omitempty" protobuf:"bytes,4,opt,name=trafficRouting"` // MaxUnavailable The maximum number of pods that can be unavailable during the update. // Value can be an absolute number (ex: 5) or a percentage of total pods at the start of update (ex: 10%). @@ -180,7 +180,7 @@ type CanaryStrategy struct { // that at least 70% of original number of pods are available at all times // during the update. // +optional - MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty"` + MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,5,opt,name=maxUnavailable"` // MaxSurge The maximum number of pods that can be scheduled above the original number of // pods. @@ -193,90 +193,90 @@ type CanaryStrategy struct { // new RC can be scaled up further, ensuring that total number of pods running // at any time during the update is at most 130% of original pods. // +optional - MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty"` + MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty" protobuf:"bytes,6,opt,name=maxSurge"` // Analysis runs a separate analysisRun while all the steps execute. This is intended to be a continuous validation of the new ReplicaSet - Analysis *RolloutAnalysisBackground `json:"analysis,omitempty"` + Analysis *RolloutAnalysisBackground `json:"analysis,omitempty" protobuf:"bytes,7,opt,name=analysis"` // AntiAffinity enables anti-affinity rules for Canary deployment // +optional - AntiAffinity *AntiAffinity `json:"antiAffinity,omitempty"` + AntiAffinity *AntiAffinity `json:"antiAffinity,omitempty" protobuf:"bytes,8,opt,name=antiAffinity"` // CanaryMetadata specify labels and annotations which will be attached to the canary pods for // the duration which they act as a canary, and will be removed after - CanaryMetadata *PodTemplateMetadata `json:"canaryMetadata,omitempty"` + CanaryMetadata *PodTemplateMetadata `json:"canaryMetadata,omitempty" protobuf:"bytes,9,opt,name=canaryMetadata"` // StableMetadata specify labels and annotations which will be attached to the stable pods for // the duration which they act as a canary, and will be removed after - StableMetadata *PodTemplateMetadata `json:"stableMetadata,omitempty"` + StableMetadata *PodTemplateMetadata `json:"stableMetadata,omitempty" protobuf:"bytes,10,opt,name=stableMetadata"` } // ALBTrafficRouting configuration for ALB ingress controller to control traffic routing type ALBTrafficRouting struct { // Ingress refers to the name of an `Ingress` resource in the same namespace as the `Rollout` - Ingress string `json:"ingress"` + Ingress string `json:"ingress" protobuf:"bytes,1,opt,name=ingress"` // ServicePort refers to the port that the Ingress action should route traffic to - ServicePort int32 `json:"servicePort"` + ServicePort int32 `json:"servicePort" protobuf:"varint,2,opt,name=servicePort"` // RootService references the service in the ingress to the controller should add the action to - RootService string `json:"rootService,omitempty"` + RootService string `json:"rootService,omitempty" protobuf:"bytes,3,opt,name=rootService"` // AnnotationPrefix has to match the configured annotation prefix on the alb ingress controller // +optional - AnnotationPrefix string `json:"annotationPrefix,omitempty"` + AnnotationPrefix string `json:"annotationPrefix,omitempty" protobuf:"bytes,4,opt,name=annotationPrefix"` } // RolloutTrafficRouting hosts all the different configuration for supported service meshes to enable more fine-grained traffic routing type RolloutTrafficRouting struct { // Istio holds Istio specific configuration to route traffic - Istio *IstioTrafficRouting `json:"istio,omitempty"` + Istio *IstioTrafficRouting `json:"istio,omitempty" protobuf:"bytes,1,opt,name=istio"` // Nginx holds Nginx Ingress specific configuration to route traffic - Nginx *NginxTrafficRouting `json:"nginx,omitempty"` + Nginx *NginxTrafficRouting `json:"nginx,omitempty" protobuf:"bytes,2,opt,name=nginx"` // Nginx holds ALB Ingress specific configuration to route traffic - ALB *ALBTrafficRouting `json:"alb,omitempty"` + ALB *ALBTrafficRouting `json:"alb,omitempty" protobuf:"bytes,3,opt,name=alb"` // SMI holds TrafficSplit specific configuration to route traffic - SMI *SMITrafficRouting `json:"smi,omitempty"` + SMI *SMITrafficRouting `json:"smi,omitempty" protobuf:"bytes,4,opt,name=smi"` } // SMITrafficRouting configuration for TrafficSplit Custom Resource to control traffic routing type SMITrafficRouting struct { // RootService holds the name of that clients use to communicate. // +optional - RootService string `json:"rootService,omitempty"` + RootService string `json:"rootService,omitempty" protobuf:"bytes,1,opt,name=rootService"` // TrafficSplitName holds the name of the TrafficSplit. // +optional - TrafficSplitName string `json:"trafficSplitName,omitempty"` + TrafficSplitName string `json:"trafficSplitName,omitempty" protobuf:"bytes,2,opt,name=trafficSplitName"` } // NginxTrafficRouting configuration for Nginx ingress controller to control traffic routing type NginxTrafficRouting struct { // AnnotationPrefix has to match the configured annotation prefix on the nginx ingress controller // +optional - AnnotationPrefix string `json:"annotationPrefix,omitempty"` + AnnotationPrefix string `json:"annotationPrefix,omitempty" protobuf:"bytes,1,opt,name=annotationPrefix"` // StableIngress refers to the name of an `Ingress` resource in the same namespace as the `Rollout` - StableIngress string `json:"stableIngress"` + StableIngress string `json:"stableIngress" protobuf:"bytes,2,opt,name=stableIngress"` // +optional - AdditionalIngressAnnotations map[string]string `json:"additionalIngressAnnotations,omitempty"` + AdditionalIngressAnnotations map[string]string `json:"additionalIngressAnnotations,omitempty" protobuf:"bytes,3,rep,name=additionalIngressAnnotations"` } // IstioTrafficRouting configuration for Istio service mesh to enable fine grain configuration type IstioTrafficRouting struct { // VirtualService references an Istio VirtualService to modify to shape traffic - VirtualService IstioVirtualService `json:"virtualService"` + VirtualService IstioVirtualService `json:"virtualService" protobuf:"bytes,1,opt,name=virtualService"` // DestinationRule references an Istio DestinationRule to modify to shape traffic - DestinationRule *IstioDestinationRule `json:"destinationRule,omitempty"` + DestinationRule *IstioDestinationRule `json:"destinationRule,omitempty" protobuf:"bytes,2,opt,name=destinationRule"` } // IstioVirtualService holds information on the virtual service the rollout needs to modify type IstioVirtualService struct { // Name holds the name of the VirtualService - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Routes list of routes within VirtualService to edit - Routes []string `json:"routes"` + Routes []string `json:"routes" protobuf:"bytes,2,rep,name=routes"` } // IstioDestinationRule is a reference to an Istio DestinationRule to modify and shape traffic type IstioDestinationRule struct { // Name holds the name of the DestinationRule - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // CanarySubsetName is the subset name to modify labels with canary ReplicaSet pod template hash value - CanarySubsetName string `json:"canarySubsetName"` + CanarySubsetName string `json:"canarySubsetName" protobuf:"bytes,2,opt,name=canarySubsetName"` // StableSubsetName is the subset name to modify labels with stable ReplicaSet pod template hash value - StableSubsetName string `json:"stableSubsetName"` + StableSubsetName string `json:"stableSubsetName" protobuf:"bytes,3,opt,name=stableSubsetName"` } // RolloutExperimentStep defines a template that is used to create a experiment for a step @@ -284,58 +284,58 @@ type RolloutExperimentStep struct { // Templates what templates that should be added to the experiment. Should be non-nil // +patchMergeKey=name // +patchStrategy=merge - Templates []RolloutExperimentTemplate `json:"templates" patchStrategy:"merge" patchMergeKey:"name"` + Templates []RolloutExperimentTemplate `json:"templates" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,1,rep,name=templates"` // Duration is a duration string (e.g. 30s, 5m, 1h) that the experiment should run for // +optional - Duration DurationString `json:"duration,omitempty"` + Duration DurationString `json:"duration,omitempty" protobuf:"bytes,2,opt,name=duration,casttype=DurationString"` // Analyses reference which analysis templates to run with the experiment // +patchMergeKey=name // +patchStrategy=merge - Analyses []RolloutExperimentStepAnalysisTemplateRef `json:"analyses,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Analyses []RolloutExperimentStepAnalysisTemplateRef `json:"analyses,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,3,rep,name=analyses"` } type RolloutExperimentStepAnalysisTemplateRef struct { // Name is a name for this analysis template invocation - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // TemplateName reference of the AnalysisTemplate name used by the Experiment to create the run - TemplateName string `json:"templateName"` + TemplateName string `json:"templateName" protobuf:"bytes,2,opt,name=templateName"` // Whether to look for the templateName at cluster scope or namespace scope // +optional - ClusterScope bool `json:"clusterScope,omitempty"` + ClusterScope bool `json:"clusterScope,omitempty" protobuf:"varint,3,opt,name=clusterScope"` // Args the arguments that will be added to the AnalysisRuns // +patchMergeKey=name // +patchStrategy=merge - Args []AnalysisRunArgument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Args []AnalysisRunArgument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,4,rep,name=args"` // RequiredForCompletion blocks the Experiment from completing until the analysis has completed - RequiredForCompletion bool `json:"requiredForCompletion,omitempty"` + RequiredForCompletion bool `json:"requiredForCompletion,omitempty" protobuf:"varint,5,opt,name=requiredForCompletion"` } // RolloutExperimentTemplate defines the template used to create experiments for the Rollout's experiment canary step type RolloutExperimentTemplate struct { // Name description of template that passed to the template - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // SpecRef indicates where the rollout should get the RS template from - SpecRef ReplicaSetSpecRef `json:"specRef"` + SpecRef ReplicaSetSpecRef `json:"specRef" protobuf:"bytes,2,opt,name=specRef,casttype=ReplicaSetSpecRef"` // Replicas replica count for the template // +optional - Replicas *int32 `json:"replicas,omitempty"` + Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,3,opt,name=replicas"` // Metadata sets labels and annotations to use for the RS created from the template // +optional - Metadata PodTemplateMetadata `json:"metadata,omitempty"` + Metadata PodTemplateMetadata `json:"metadata,omitempty" protobuf:"bytes,4,opt,name=metadata"` // Selector overrides the selector to be used for the template's ReplicaSet. If omitted, will // use the same selector as the Rollout // +optional - Selector *metav1.LabelSelector `json:"selector,omitempty"` + Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,5,opt,name=selector"` } // PodTemplateMetadata extra labels to add to the template type PodTemplateMetadata struct { // Labels Additional labels to add to the experiment // +optional - Labels map[string]string `json:"labels,omitempty"` + Labels map[string]string `json:"labels,omitempty" protobuf:"bytes,1,rep,name=labels"` // Annotations additional annotations to add to the experiment // +optional - Annotations map[string]string `json:"annotations,omitempty"` + Annotations map[string]string `json:"annotations,omitempty" protobuf:"bytes,2,rep,name=annotations"` } // ReplicaSetSpecRef defines which RS that the experiment's template will use. @@ -351,81 +351,81 @@ const ( // CanaryStep defines a step of a canary deployment. type CanaryStep struct { // SetWeight sets what percentage of the newRS should receive - SetWeight *int32 `json:"setWeight,omitempty"` + SetWeight *int32 `json:"setWeight,omitempty" protobuf:"varint,1,opt,name=setWeight"` // Pause freezes the rollout by setting spec.Paused to true. // A Rollout will resume when spec.Paused is reset to false. // +optional - Pause *RolloutPause `json:"pause,omitempty"` + Pause *RolloutPause `json:"pause,omitempty" protobuf:"bytes,2,opt,name=pause"` // Experiment defines the experiment object that should be created - Experiment *RolloutExperimentStep `json:"experiment,omitempty"` + Experiment *RolloutExperimentStep `json:"experiment,omitempty" protobuf:"bytes,3,opt,name=experiment"` // Analysis defines the AnalysisRun that will run for a step - Analysis *RolloutAnalysis `json:"analysis,omitempty"` + Analysis *RolloutAnalysis `json:"analysis,omitempty" protobuf:"bytes,4,opt,name=analysis"` // SetCanaryScale defines how to scale the newRS without changing traffic weight // +optional - SetCanaryScale *SetCanaryScale `json:"setCanaryScale,omitempty"` + SetCanaryScale *SetCanaryScale `json:"setCanaryScale,omitempty" protobuf:"bytes,5,opt,name=setCanaryScale"` } // SetCanaryScale defines how to scale the newRS without changing traffic weight type SetCanaryScale struct { // Weight sets the percentage of replicas the newRS should have // +optional - Weight *int32 `json:"weight,omitempty"` + Weight *int32 `json:"weight,omitempty" protobuf:"varint,1,opt,name=weight"` // Replicas sets the number of replicas the newRS should have // +optional - Replicas *int32 `json:"replicas,omitempty"` + Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` // MatchTrafficWeight cancels out previously set Replicas or Weight, effectively activating SetWeight // +optional - MatchTrafficWeight bool `json:"matchTrafficWeight,omitempty"` + MatchTrafficWeight bool `json:"matchTrafficWeight,omitempty" protobuf:"varint,3,opt,name=matchTrafficWeight"` } // RolloutAnalysisBackground defines a template that is used to create a background analysisRun type RolloutAnalysisBackground struct { - RolloutAnalysis `json:",inline"` + RolloutAnalysis `json:",inline" protobuf:"bytes,1,opt,name=rolloutAnalysis"` // StartingStep indicates which step the background analysis should start on // If not listed, controller defaults to 0 - StartingStep *int32 `json:"startingStep,omitempty"` + StartingStep *int32 `json:"startingStep,omitempty" protobuf:"varint,2,opt,name=startingStep"` } // RolloutAnalysis defines a template that is used to create a analysisRun type RolloutAnalysis struct { //Templates reference to a list of analysis templates to combine for an AnalysisRun - Templates []RolloutAnalysisTemplate `json:"templates,omitempty"` + Templates []RolloutAnalysisTemplate `json:"templates,omitempty" protobuf:"bytes,1,rep,name=templates"` // Args the arguments that will be added to the AnalysisRuns // +patchMergeKey=name // +patchStrategy=merge - Args []AnalysisRunArgument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name"` + Args []AnalysisRunArgument `json:"args,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=args"` } type RolloutAnalysisTemplate struct { //TemplateName name of template to use in AnalysisRun // +optional - TemplateName string `json:"templateName"` + TemplateName string `json:"templateName" protobuf:"bytes,1,opt,name=templateName"` // Whether to look for the templateName at cluster scope or namespace scope // +optional - ClusterScope bool `json:"clusterScope,omitempty"` + ClusterScope bool `json:"clusterScope,omitempty" protobuf:"varint,2,opt,name=clusterScope"` } // AnalysisRunArgument argument to add to analysisRun type AnalysisRunArgument struct { // Name argument name - Name string `json:"name"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Value a hardcoded value for the argument. This field is a one of field with valueFrom - Value string `json:"value,omitempty"` + Value string `json:"value,omitempty" protobuf:"bytes,2,opt,name=value"` // ValueFrom A reference to where the value is stored. This field is a one of field with valueFrom - ValueFrom *ArgumentValueFrom `json:"valueFrom,omitempty"` + ValueFrom *ArgumentValueFrom `json:"valueFrom,omitempty" protobuf:"bytes,3,opt,name=valueFrom"` } // ArgumentValueFrom defines references to fields within resources to grab for the value (i.e. Pod Template Hash) type ArgumentValueFrom struct { // PodTemplateHashValue gets the value from one of the children ReplicaSet's Pod Template Hash - PodTemplateHashValue *ValueFromPodTemplateHash `json:"podTemplateHashValue,omitempty"` + PodTemplateHashValue *ValueFromPodTemplateHash `json:"podTemplateHashValue,omitempty" protobuf:"bytes,1,opt,name=podTemplateHashValue,casttype=ValueFromPodTemplateHash"` //FieldRef - FieldRef *FieldRef `json:"fieldRef,omitempty"` + FieldRef *FieldRef `json:"fieldRef,omitempty" protobuf:"bytes,2,opt,name=fieldRef"` } type FieldRef struct { // Required: Path of the field to select in the specified API version - FieldPath string `json:"fieldPath"` + FieldPath string `json:"fieldPath" protobuf:"bytes,1,opt,name=fieldPath"` } // ValueFromPodTemplateHash indicates which ReplicaSet pod template pod hash to use @@ -457,7 +457,7 @@ const ( type RolloutPause struct { // Duration the amount of time to wait before moving to the next step. // +optional - Duration *intstr.IntOrString `json:"duration,omitempty"` + Duration *intstr.IntOrString `json:"duration,omitempty" protobuf:"bytes,1,opt,name=duration"` } // DurationSeconds converts the pause duration to seconds @@ -511,113 +511,113 @@ const ( // PauseCondition the reason for a pause and when it started type PauseCondition struct { - Reason PauseReason `json:"reason"` - StartTime metav1.Time `json:"startTime"` + Reason PauseReason `json:"reason" protobuf:"bytes,1,opt,name=reason,casttype=PauseReason"` + StartTime metav1.Time `json:"startTime" protobuf:"bytes,2,opt,name=startTime"` } // RolloutStatus is the status for a Rollout resource type RolloutStatus struct { // Abort cancel the current rollout progression - Abort bool `json:"abort,omitempty"` + Abort bool `json:"abort,omitempty" protobuf:"varint,1,opt,name=abort"` // PauseConditions indicates why the rollout is currently paused - PauseConditions []PauseCondition `json:"pauseConditions,omitempty"` + PauseConditions []PauseCondition `json:"pauseConditions,omitempty" protobuf:"bytes,2,rep,name=pauseConditions"` // ControllerPause indicates the controller has paused the rollout. It is set to true when // the controller adds a pause condition. This field helps to discern the scenario where a // rollout was resumed after being paused by the controller (e.g. via the plugin). In that // situation, the pauseConditions would have been cleared , but controllerPause would still be // set to true. - ControllerPause bool `json:"controllerPause,omitempty"` + ControllerPause bool `json:"controllerPause,omitempty" protobuf:"varint,3,opt,name=controllerPause"` // AbortedAt indicates the controller reconciled an aborted rollout. The controller uses this to understand if // the controller needs to do some specific work when a Rollout is aborted. For example, the reconcileAbort is used // to indicate if the Rollout should enter an aborted state when the latest AnalysisRun is a failure, or the controller // has already put the Rollout into an aborted and should create a new AnalysisRun. - AbortedAt *metav1.Time `json:"abortedAt,omitempty"` + AbortedAt *metav1.Time `json:"abortedAt,omitempty" protobuf:"bytes,4,opt,name=abortedAt"` // CurrentPodHash the hash of the current pod template // +optional - CurrentPodHash string `json:"currentPodHash,omitempty"` + CurrentPodHash string `json:"currentPodHash,omitempty" protobuf:"bytes,5,opt,name=currentPodHash"` // CurrentStepHash the hash of the current list of steps for the current strategy. This is used to detect when the // list of current steps change // +optional - CurrentStepHash string `json:"currentStepHash,omitempty"` + CurrentStepHash string `json:"currentStepHash,omitempty" protobuf:"bytes,6,opt,name=currentStepHash"` // Total number of non-terminated pods targeted by this rollout (their labels match the selector). // +optional - Replicas int32 `json:"replicas,omitempty"` + Replicas int32 `json:"replicas,omitempty" protobuf:"varint,7,opt,name=replicas"` // Total number of non-terminated pods targeted by this rollout that have the desired template spec. // +optional - UpdatedReplicas int32 `json:"updatedReplicas,omitempty"` + UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,8,opt,name=updatedReplicas"` // Total number of ready pods targeted by this rollout. // +optional - ReadyReplicas int32 `json:"readyReplicas,omitempty"` + ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,9,opt,name=readyReplicas"` // Total number of available pods (ready for at least minReadySeconds) targeted by this rollout. // +optional - AvailableReplicas int32 `json:"availableReplicas,omitempty"` + AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,10,opt,name=availableReplicas"` // CurrentStepIndex defines the current step of the rollout is on. If the current step index is null, the // controller will execute the rollout. // +optional - CurrentStepIndex *int32 `json:"currentStepIndex,omitempty"` + CurrentStepIndex *int32 `json:"currentStepIndex,omitempty" protobuf:"varint,11,opt,name=currentStepIndex"` // Count of hash collisions for the Rollout. The Rollout controller uses this // field as a collision avoidance mechanism when it needs to create the name for the // newest ReplicaSet. // +optional - CollisionCount *int32 `json:"collisionCount,omitempty"` + CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,12,opt,name=collisionCount"` // The generation observed by the rollout controller by taking a hash of the spec. // +optional - ObservedGeneration string `json:"observedGeneration,omitempty"` + ObservedGeneration string `json:"observedGeneration,omitempty" protobuf:"bytes,13,opt,name=observedGeneration"` // Conditions a list of conditions a rollout can have. // +optional - Conditions []RolloutCondition `json:"conditions,omitempty"` + Conditions []RolloutCondition `json:"conditions,omitempty" protobuf:"bytes,14,rep,name=conditions"` // Canary describes the state of the canary rollout // +optional - Canary CanaryStatus `json:"canary,omitempty"` + Canary CanaryStatus `json:"canary,omitempty" protobuf:"bytes,15,opt,name=canary"` // BlueGreen describes the state of the bluegreen rollout // +optional - BlueGreen BlueGreenStatus `json:"blueGreen,omitempty"` + BlueGreen BlueGreenStatus `json:"blueGreen,omitempty" protobuf:"bytes,16,opt,name=blueGreen"` // HPAReplicas the number of non-terminated replicas that are receiving active traffic // +optional - HPAReplicas int32 `json:"HPAReplicas,omitempty"` + HPAReplicas int32 `json:"HPAReplicas,omitempty" protobuf:"varint,17,opt,name=HPAReplicas"` // Selector that identifies the pods that are receiving active traffic // +optional - Selector string `json:"selector,omitempty"` + Selector string `json:"selector,omitempty" protobuf:"bytes,18,opt,name=selector"` // StableRS indicates the replicaset that has successfully rolled out // +optional - StableRS string `json:"stableRS,omitempty"` + StableRS string `json:"stableRS,omitempty" protobuf:"bytes,19,opt,name=stableRS"` // RestartedAt indicates last time a Rollout was restarted - RestartedAt *metav1.Time `json:"restartedAt,omitempty"` + RestartedAt *metav1.Time `json:"restartedAt,omitempty" protobuf:"bytes,20,opt,name=restartedAt"` // PromoteFull indicates if the rollout should perform a full promotion, skipping analysis and pauses. - PromoteFull bool `json:"promoteFull,omitempty"` + PromoteFull bool `json:"promoteFull,omitempty" protobuf:"varint,21,opt,name=promoteFull"` } // BlueGreenStatus status fields that only pertain to the blueGreen rollout type BlueGreenStatus struct { // PreviewSelector indicates which replicas set the preview service is serving traffic to // +optional - PreviewSelector string `json:"previewSelector,omitempty"` + PreviewSelector string `json:"previewSelector,omitempty" protobuf:"bytes,1,opt,name=previewSelector"` // ActiveSelector indicates which replicas set the active service is serving traffic to // +optional - ActiveSelector string `json:"activeSelector,omitempty"` + ActiveSelector string `json:"activeSelector,omitempty" protobuf:"bytes,2,opt,name=activeSelector"` // ScaleUpPreviewCheckPoint indicates that the Replicaset receiving traffic from the preview service is ready to be scaled up after the rollout is unpaused // +optional - ScaleUpPreviewCheckPoint bool `json:"scaleUpPreviewCheckPoint,omitempty"` + ScaleUpPreviewCheckPoint bool `json:"scaleUpPreviewCheckPoint,omitempty" protobuf:"varint,3,opt,name=scaleUpPreviewCheckPoint"` // PrePromotionAnalysisRunStatus indicates the status of the current prepromotion analysis run - PrePromotionAnalysisRunStatus *RolloutAnalysisRunStatus `json:"prePromotionAnalysisRunStatus,omitempty"` + PrePromotionAnalysisRunStatus *RolloutAnalysisRunStatus `json:"prePromotionAnalysisRunStatus,omitempty" protobuf:"bytes,4,opt,name=prePromotionAnalysisRunStatus"` // PostPromotionAnalysisRunStatus indicates the status of the current post promotion analysis run - PostPromotionAnalysisRunStatus *RolloutAnalysisRunStatus `json:"postPromotionAnalysisRunStatus,omitempty"` + PostPromotionAnalysisRunStatus *RolloutAnalysisRunStatus `json:"postPromotionAnalysisRunStatus,omitempty" protobuf:"bytes,5,opt,name=postPromotionAnalysisRunStatus"` } // CanaryStatus status fields that only pertain to the canary rollout type CanaryStatus struct { // CurrentStepAnalysisRunStatus indicates the status of the current step analysis run - CurrentStepAnalysisRunStatus *RolloutAnalysisRunStatus `json:"currentStepAnalysisRunStatus,omitempty"` + CurrentStepAnalysisRunStatus *RolloutAnalysisRunStatus `json:"currentStepAnalysisRunStatus,omitempty" protobuf:"bytes,1,opt,name=currentStepAnalysisRunStatus"` // CurrentBackgroundAnalysisRunStatus indicates the status of the current background analysis run - CurrentBackgroundAnalysisRunStatus *RolloutAnalysisRunStatus `json:"currentBackgroundAnalysisRunStatus,omitempty"` + CurrentBackgroundAnalysisRunStatus *RolloutAnalysisRunStatus `json:"currentBackgroundAnalysisRunStatus,omitempty" protobuf:"bytes,2,opt,name=currentBackgroundAnalysisRunStatus"` // CurrentExperiment indicates the running experiment - CurrentExperiment string `json:"currentExperiment,omitempty"` + CurrentExperiment string `json:"currentExperiment,omitempty" protobuf:"bytes,3,opt,name=currentExperiment"` } type RolloutAnalysisRunStatus struct { - Name string `json:"name"` - Status AnalysisPhase `json:"status"` - Message string `json:"message,omitempty"` + Name string `json:"name" protobuf:"bytes,1,opt,name=name"` + Status AnalysisPhase `json:"status" protobuf:"bytes,2,opt,name=status,casttype=AnalysisPhase"` + Message string `json:"message,omitempty" protobuf:"bytes,3,opt,name=message"` } // RolloutConditionType defines the conditions of Rollout @@ -646,17 +646,17 @@ const ( // RolloutCondition describes the state of a rollout at a certain point. type RolloutCondition struct { // Type of deployment condition. - Type RolloutConditionType `json:"type"` + Type RolloutConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=RolloutConditionType"` // Phase of the condition, one of True, False, Unknown. - Status corev1.ConditionStatus `json:"status"` + Status corev1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` // The last time this condition was updated. - LastUpdateTime metav1.Time `json:"lastUpdateTime"` + LastUpdateTime metav1.Time `json:"lastUpdateTime" protobuf:"bytes,3,opt,name=lastUpdateTime"` // Last time the condition transitioned from one status to another. - LastTransitionTime metav1.Time `json:"lastTransitionTime"` + LastTransitionTime metav1.Time `json:"lastTransitionTime" protobuf:"bytes,4,opt,name=lastTransitionTime"` // The reason for the condition's last transition. - Reason string `json:"reason"` + Reason string `json:"reason" protobuf:"bytes,5,opt,name=reason"` // A human readable message indicating details about the transition. - Message string `json:"message"` + Message string `json:"message" protobuf:"bytes,6,opt,name=message"` } // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object @@ -664,7 +664,7 @@ type RolloutCondition struct { // RolloutList is a list of Rollout resources type RolloutList struct { metav1.TypeMeta `json:",inline"` - metav1.ListMeta `json:"metadata"` + metav1.ListMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` - Items []Rollout `json:"items"` + Items []Rollout `json:"items" protobuf:"bytes,2,rep,name=items"` } diff --git a/pkg/kubectl-argo-rollouts/cmd/cmd.go b/pkg/kubectl-argo-rollouts/cmd/cmd.go index f6762b96c1..d9597bafd1 100644 --- a/pkg/kubectl-argo-rollouts/cmd/cmd.go +++ b/pkg/kubectl-argo-rollouts/cmd/cmd.go @@ -5,6 +5,7 @@ import ( "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/abort" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/create" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/dashboard" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/get" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/lint" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/list" @@ -65,6 +66,7 @@ func NewCmdArgoRollouts(o *options.ArgoRolloutsOptions) *cobra.Command { cmd.AddCommand(terminate.NewCmdTerminate(o)) cmd.AddCommand(set.NewCmdSet(o)) cmd.AddCommand(undo.NewCmdUndo(o)) + cmd.AddCommand(dashboard.NewCmdDashboard(o)) cmd.AddCommand(status.NewCmdStatus(o)) return cmd } diff --git a/pkg/kubectl-argo-rollouts/cmd/dashboard/dashboard.go b/pkg/kubectl-argo-rollouts/cmd/dashboard/dashboard.go new file mode 100644 index 0000000000..ce081a764c --- /dev/null +++ b/pkg/kubectl-argo-rollouts/cmd/dashboard/dashboard.go @@ -0,0 +1,38 @@ +package dashboard + +import ( + "context" + + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/options" + "github.com/argoproj/argo-rollouts/server" + "github.com/spf13/cobra" +) + +func NewCmdDashboard(o *options.ArgoRolloutsOptions) *cobra.Command { + var cmd = &cobra.Command{ + Use: "dashboard", + Short: "Start UI dashboard", + RunE: func(c *cobra.Command, args []string) error { + namespace := o.Namespace() + kubeclientset := o.KubeClientset() + rolloutclientset := o.RolloutsClientset() + + opts := server.ServerOptions{ + Namespace: namespace, + KubeClientset: kubeclientset, + RolloutsClientset: rolloutclientset, + DynamicClientset: o.DynamicClientset(), + } + + for { + ctx := context.Background() + ctx, cancel := context.WithCancel(ctx) + argorollouts := server.NewServer(opts) + argorollouts.Run(ctx, 3100, true) + cancel() + } + }, + } + + return cmd +} diff --git a/pkg/kubectl-argo-rollouts/cmd/get/get.go b/pkg/kubectl-argo-rollouts/cmd/get/get.go index bcd920ce7a..bb29d692e9 100644 --- a/pkg/kubectl-argo-rollouts/cmd/get/get.go +++ b/pkg/kubectl-argo-rollouts/cmd/get/get.go @@ -95,8 +95,9 @@ Tree view icons ) type GetOptions struct { - Watch bool - NoColor bool + Watch bool + NoColor bool + TimeoutSeconds int options.ArgoRolloutsOptions } diff --git a/pkg/kubectl-argo-rollouts/cmd/get/get_experiment.go b/pkg/kubectl-argo-rollouts/cmd/get/get_experiment.go index 968c0073cf..3420f4705a 100644 --- a/pkg/kubectl-argo-rollouts/cmd/get/get_experiment.go +++ b/pkg/kubectl-argo-rollouts/cmd/get/get_experiment.go @@ -10,6 +10,7 @@ import ( "github.com/juju/ansiterm" "github.com/spf13/cobra" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/info" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/options" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/viewcontroller" @@ -53,8 +54,8 @@ func NewCmdGetExperiment(o *options.ArgoRolloutsOptions) *cobra.Command { if !getOptions.Watch { getOptions.PrintExperiment(expInfo) } else { - expUpdates := make(chan *info.ExperimentInfo) - controller.RegisterCallback(func(expInfo *info.ExperimentInfo) { + expUpdates := make(chan *rollout.ExperimentInfo) + controller.RegisterCallback(func(expInfo *rollout.ExperimentInfo) { expUpdates <- expInfo }) go getOptions.WatchExperiment(ctx.Done(), expUpdates) @@ -69,9 +70,9 @@ func NewCmdGetExperiment(o *options.ArgoRolloutsOptions) *cobra.Command { return cmd } -func (o *GetOptions) WatchExperiment(stopCh <-chan struct{}, expUpdates chan *info.ExperimentInfo) { +func (o *GetOptions) WatchExperiment(stopCh <-chan struct{}, expUpdates chan *rollout.ExperimentInfo) { ticker := time.NewTicker(time.Second) - var currExpInfo *info.ExperimentInfo + var currExpInfo *rollout.ExperimentInfo // preventFlicker is used to rate-limit the updates we print to the terminal when updates occur // so rapidly that it causes the terminal to flicker var preventFlicker time.Time @@ -92,14 +93,14 @@ func (o *GetOptions) WatchExperiment(stopCh <-chan struct{}, expUpdates chan *in } } -func (o *GetOptions) PrintExperiment(exInfo *info.ExperimentInfo) { - fmt.Fprintf(o.Out, tableFormat, "Name:", exInfo.Name) - fmt.Fprintf(o.Out, tableFormat, "Namespace:", exInfo.Namespace) +func (o *GetOptions) PrintExperiment(exInfo *rollout.ExperimentInfo) { + fmt.Fprintf(o.Out, tableFormat, "Name:", exInfo.ObjectMeta.Name) + fmt.Fprintf(o.Out, tableFormat, "Namespace:", exInfo.ObjectMeta.Namespace) fmt.Fprintf(o.Out, tableFormat, "Status:", o.colorize(exInfo.Icon)+" "+exInfo.Status) if exInfo.Message != "" { fmt.Fprintf(o.Out, tableFormat, "Message:", exInfo.Message) } - images := exInfo.Images() + images := info.ExperimentImages(exInfo) if len(images) > 0 { fmt.Fprintf(o.Out, tableFormat, "Images:", o.formatImage(images[0])) for i := 1; i < len(images); i++ { @@ -111,28 +112,28 @@ func (o *GetOptions) PrintExperiment(exInfo *info.ExperimentInfo) { o.PrintExperimentTree(exInfo) } -func (o *GetOptions) PrintExperimentTree(exInfo *info.ExperimentInfo) { +func (o *GetOptions) PrintExperimentTree(exInfo *rollout.ExperimentInfo) { w := ansiterm.NewTabWriter(o.Out, 0, 0, 2, ' ', 0) o.PrintHeader(w) o.PrintExperimentInfo(w, *exInfo, "", "") _ = w.Flush() } -func (o *GetOptions) PrintExperimentInfo(w io.Writer, expInfo info.ExperimentInfo, prefix string, subpfx string) { - name := o.colorizeStatus(expInfo.Name, expInfo.Status) +func (o *GetOptions) PrintExperimentInfo(w io.Writer, expInfo rollout.ExperimentInfo, prefix string, subpfx string) { + name := o.colorizeStatus(expInfo.ObjectMeta.Name, expInfo.Status) infoCols := []string{} total := len(expInfo.ReplicaSets) + len(expInfo.AnalysisRuns) curr := 0 - fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconExperiment, name, "Experiment", o.colorize(expInfo.Icon), expInfo.Status, expInfo.Age(), strings.Join(infoCols, ",")) + fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconExperiment, name, "Experiment", o.colorize(expInfo.Icon), expInfo.Status, info.Age(*expInfo.ObjectMeta), strings.Join(infoCols, ",")) for _, rsInfo := range expInfo.ReplicaSets { childPrefix, childSubpfx := getPrefixes(curr == total-1, subpfx) - o.PrintReplicaSetInfo(w, rsInfo, childPrefix, childSubpfx) + o.PrintReplicaSetInfo(w, *rsInfo, childPrefix, childSubpfx) curr++ } for _, arInfo := range expInfo.AnalysisRuns { arPrefix, arChildPrefix := getPrefixes(curr == total-1, subpfx) - o.PrintAnalysisRunInfo(w, arInfo, arPrefix, arChildPrefix) + o.PrintAnalysisRunInfo(w, *arInfo, arPrefix, arChildPrefix) curr++ } } diff --git a/pkg/kubectl-argo-rollouts/cmd/get/get_rollout.go b/pkg/kubectl-argo-rollouts/cmd/get/get_rollout.go index 5b03f75566..8b6ee4fd89 100644 --- a/pkg/kubectl-argo-rollouts/cmd/get/get_rollout.go +++ b/pkg/kubectl-argo-rollouts/cmd/get/get_rollout.go @@ -10,6 +10,7 @@ import ( "github.com/juju/ansiterm" "github.com/spf13/cobra" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/info" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/options" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/viewcontroller" @@ -53,11 +54,19 @@ func NewCmdGetRollout(o *options.ArgoRolloutsOptions) *cobra.Command { if !getOptions.Watch { getOptions.PrintRollout(ri) } else { - rolloutUpdates := make(chan *info.RolloutInfo) - controller.RegisterCallback(func(roInfo *info.RolloutInfo) { + rolloutUpdates := make(chan *rollout.RolloutInfo) + controller.RegisterCallback(func(roInfo *rollout.RolloutInfo) { rolloutUpdates <- roInfo }) - go getOptions.WatchRollout(ctx.Done(), rolloutUpdates) + stopCh := ctx.Done() + if getOptions.TimeoutSeconds > 0 { + ts := time.Duration(getOptions.TimeoutSeconds) + newCtx, cancel := context.WithTimeout(ctx, ts*time.Second) + ctx = newCtx + defer cancel() + stopCh = newCtx.Done() + } + go getOptions.WatchRollout(stopCh, rolloutUpdates) controller.Run(ctx) close(rolloutUpdates) } @@ -66,12 +75,13 @@ func NewCmdGetRollout(o *options.ArgoRolloutsOptions) *cobra.Command { } cmd.Flags().BoolVarP(&getOptions.Watch, "watch", "w", false, "Watch live updates to the rollout") cmd.Flags().BoolVar(&getOptions.NoColor, "no-color", false, "Do not colorize output") + cmd.Flags().IntVar(&getOptions.TimeoutSeconds, "timeout-seconds", 0, "Timeout after specified seconds") return cmd } -func (o *GetOptions) WatchRollout(stopCh <-chan struct{}, rolloutUpdates chan *info.RolloutInfo) { +func Watch(stopCh <-chan struct{}, rolloutUpdates chan *rollout.RolloutInfo, callback func(*rollout.RolloutInfo)) { ticker := time.NewTicker(time.Second) - var currRolloutInfo *info.RolloutInfo + var currRolloutInfo *rollout.RolloutInfo // preventFlicker is used to rate-limit the updates we print to the terminal when updates occur // so rapidly that it causes the terminal to flicker var preventFlicker time.Time @@ -85,13 +95,20 @@ func (o *GetOptions) WatchRollout(stopCh <-chan struct{}, rolloutUpdates chan *i return } if currRolloutInfo != nil && time.Now().After(preventFlicker.Add(200*time.Millisecond)) { - o.Clear() - o.PrintRollout(currRolloutInfo) + callback(currRolloutInfo) preventFlicker = time.Now() } } } +func (o *GetOptions) WatchRollout(stopCh <-chan struct{}, rolloutUpdates chan *rollout.RolloutInfo) { + Watch(stopCh, rolloutUpdates, + func(i *rollout.RolloutInfo) { + o.Clear() + o.PrintRollout(i) + }) +} + // formatImage formats an ImageInfo with colorized imageinfo tags (e.g. canary, stable) func (o *GetOptions) formatImage(image info.ImageInfo) string { imageStr := image.Image @@ -105,9 +122,9 @@ func (o *GetOptions) formatImage(image info.ImageInfo) string { return imageStr } -func (o *GetOptions) PrintRollout(roInfo *info.RolloutInfo) { - fmt.Fprintf(o.Out, tableFormat, "Name:", roInfo.Name) - fmt.Fprintf(o.Out, tableFormat, "Namespace:", roInfo.Namespace) +func (o *GetOptions) PrintRollout(roInfo *rollout.RolloutInfo) { + fmt.Fprintf(o.Out, tableFormat, "Name:", roInfo.ObjectMeta.Name) + fmt.Fprintf(o.Out, tableFormat, "Namespace:", roInfo.ObjectMeta.Namespace) fmt.Fprintf(o.Out, tableFormat, "Status:", o.colorize(roInfo.Icon)+" "+roInfo.Status) if roInfo.Message != "" { fmt.Fprintf(o.Out, tableFormat, "Message:", roInfo.Message) @@ -118,7 +135,7 @@ func (o *GetOptions) PrintRollout(roInfo *info.RolloutInfo) { fmt.Fprintf(o.Out, tableFormat, " SetWeight:", roInfo.SetWeight) fmt.Fprintf(o.Out, tableFormat, " ActualWeight:", roInfo.ActualWeight) } - images := roInfo.Images() + images := info.Images(roInfo) if len(images) > 0 { fmt.Fprintf(o.Out, tableFormat, "Images:", o.formatImage(images[0])) for i := 1; i < len(images); i++ { @@ -136,11 +153,11 @@ func (o *GetOptions) PrintRollout(roInfo *info.RolloutInfo) { o.PrintRolloutTree(roInfo) } -func (o *GetOptions) PrintRolloutTree(roInfo *info.RolloutInfo) { +func (o *GetOptions) PrintRolloutTree(roInfo *rollout.RolloutInfo) { w := ansiterm.NewTabWriter(o.Out, 0, 0, 2, ' ', 0) o.PrintHeader(w) - fmt.Fprintf(w, "%s %s\t%s\t%s %s\t%s\t%v\n", IconRollout, roInfo.Name, "Rollout", o.colorize(roInfo.Icon), roInfo.Status, roInfo.Age(), "") - revisions := roInfo.Revisions() + fmt.Fprintf(w, "%s %s\t%s\t%s %s\t%s\t%v\n", IconRollout, roInfo.ObjectMeta.Name, "Rollout", o.colorize(roInfo.Icon), roInfo.Status, info.Age(*roInfo.ObjectMeta), "") + revisions := info.Revisions(roInfo) for i, rev := range revisions { isLast := i == len(revisions)-1 prefix, subpfx := getPrefixes(isLast, "") @@ -149,35 +166,35 @@ func (o *GetOptions) PrintRolloutTree(roInfo *info.RolloutInfo) { _ = w.Flush() } -func (o *GetOptions) PrintRevision(w io.Writer, roInfo *info.RolloutInfo, revision int, prefix string, subpfx string) { +func (o *GetOptions) PrintRevision(w io.Writer, roInfo *rollout.RolloutInfo, revision int, prefix string, subpfx string) { name := fmt.Sprintf("revision:%d", revision) fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconRevision, name, "", "", "", "", "") - replicaSets := roInfo.ReplicaSetsByRevision(revision) - experiments := roInfo.ExperimentsByRevision(revision) - analysisRuns := roInfo.AnalysisRunsByRevision(revision) + replicaSets := info.ReplicaSetsByRevision(roInfo, revision) + experiments := info.ExperimentsByRevision(roInfo, revision) + analysisRuns := info.AnalysisRunsByRevision(roInfo, revision) total := len(replicaSets) + len(experiments) + len(analysisRuns) curr := 0 for _, rsInfo := range replicaSets { childPrefix, childSubpfx := getPrefixes(curr == total-1, subpfx) - o.PrintReplicaSetInfo(w, rsInfo, childPrefix, childSubpfx) + o.PrintReplicaSetInfo(w, *rsInfo, childPrefix, childSubpfx) curr++ } for _, expInfo := range experiments { childPrefix, childSubpfx := getPrefixes(curr == total-1, subpfx) - o.PrintExperimentInfo(w, expInfo, childPrefix, childSubpfx) + o.PrintExperimentInfo(w, *expInfo, childPrefix, childSubpfx) curr++ } for _, arInfo := range analysisRuns { childPrefix, childSubpfx := getPrefixes(curr == total-1, subpfx) - o.PrintAnalysisRunInfo(w, arInfo, childPrefix, childSubpfx) + o.PrintAnalysisRunInfo(w, *arInfo, childPrefix, childSubpfx) curr++ } } -func (o *GetOptions) PrintReplicaSetInfo(w io.Writer, rsInfo info.ReplicaSetInfo, prefix string, subpfx string) { +func (o *GetOptions) PrintReplicaSetInfo(w io.Writer, rsInfo rollout.ReplicaSetInfo, prefix string, subpfx string) { infoCols := []string{} - name := rsInfo.Name + name := rsInfo.ObjectMeta.Name if rsInfo.Stable { infoCols = append(infoCols, o.colorize(info.InfoTagStable)) name = o.colorizeStatus(name, info.InfoTagStable) @@ -193,10 +210,10 @@ func (o *GetOptions) PrintReplicaSetInfo(w io.Writer, rsInfo info.ReplicaSetInfo name = o.colorizeStatus(name, info.InfoTagPreview) } if rsInfo.ScaleDownDeadline != "" { - infoCols = append(infoCols, fmt.Sprintf("delay:%s", rsInfo.ScaleDownDelay())) + infoCols = append(infoCols, fmt.Sprintf("delay:%s", info.ScaleDownDelay(rsInfo))) } - fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconReplicaSet, name, "ReplicaSet", o.colorize(rsInfo.Icon), rsInfo.Status, rsInfo.Age(), strings.Join(infoCols, ",")) + fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconReplicaSet, name, "ReplicaSet", o.colorize(rsInfo.Icon), rsInfo.Status, info.Age(*rsInfo.ObjectMeta), strings.Join(infoCols, ",")) for i, podInfo := range rsInfo.Pods { isLast := i == len(rsInfo.Pods)-1 podPrefix, _ := getPrefixes(isLast, subpfx) @@ -204,12 +221,12 @@ func (o *GetOptions) PrintReplicaSetInfo(w io.Writer, rsInfo info.ReplicaSetInfo if podInfo.Restarts > 0 { podInfoCol = append(podInfoCol, fmt.Sprintf("restarts:%d", podInfo.Restarts)) } - fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", podPrefix, IconPod, podInfo.Name, "Pod", o.colorize(podInfo.Icon), podInfo.Status, podInfo.Age(), strings.Join(podInfoCol, ",")) + fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", podPrefix, IconPod, podInfo.ObjectMeta.Name, "Pod", o.colorize(podInfo.Icon), podInfo.Status, info.Age(*podInfo.ObjectMeta), strings.Join(podInfoCol, ",")) } } -func (o *GetOptions) PrintAnalysisRunInfo(w io.Writer, arInfo info.AnalysisRunInfo, prefix string, subpfx string) { - name := o.colorizeStatus(arInfo.Name, arInfo.Status) +func (o *GetOptions) PrintAnalysisRunInfo(w io.Writer, arInfo rollout.AnalysisRunInfo, prefix string, subpfx string) { + name := o.colorizeStatus(arInfo.ObjectMeta.Name, arInfo.Status) infoCols := []string{} if arInfo.Successful > 0 { infoCols = append(infoCols, fmt.Sprintf("%s %d", o.colorize(info.IconOK), arInfo.Successful)) @@ -223,15 +240,15 @@ func (o *GetOptions) PrintAnalysisRunInfo(w io.Writer, arInfo info.AnalysisRunIn if arInfo.Error > 0 { infoCols = append(infoCols, fmt.Sprintf("%s %d", o.colorize(info.IconWarning), arInfo.Error)) } - fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconAnalysis, name, "AnalysisRun", o.colorize(arInfo.Icon), arInfo.Status, arInfo.Age(), strings.Join(infoCols, ",")) + fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconAnalysis, name, "AnalysisRun", o.colorize(arInfo.Icon), arInfo.Status, info.Age(*arInfo.ObjectMeta), strings.Join(infoCols, ",")) for i, jobInfo := range arInfo.Jobs { isLast := i == len(arInfo.Jobs)-1 jobPrefix, jobChildPrefix := getPrefixes(isLast, subpfx) - o.PrintJob(w, jobInfo, jobPrefix, jobChildPrefix) + o.PrintJob(w, *jobInfo, jobPrefix, jobChildPrefix) } } -func (o *GetOptions) PrintJob(w io.Writer, jobInfo info.JobInfo, prefix string, subpfx string) { - name := o.colorizeStatus(jobInfo.Name, jobInfo.Status) - fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconJob, name, "Job", o.colorize(jobInfo.Icon), jobInfo.Status, jobInfo.Age(), "") +func (o *GetOptions) PrintJob(w io.Writer, jobInfo rollout.JobInfo, prefix string, subpfx string) { + name := o.colorizeStatus(jobInfo.ObjectMeta.Name, jobInfo.Status) + fmt.Fprintf(w, "%s%s %s\t%s\t%s %s\t%s\t%v\n", prefix, IconJob, name, "Job", o.colorize(jobInfo.Icon), jobInfo.Status, info.Age(*jobInfo.ObjectMeta), "") } diff --git a/pkg/kubectl-argo-rollouts/cmd/get/get_test.go b/pkg/kubectl-argo-rollouts/cmd/get/get_test.go index 1e4abd429c..3ca3872be1 100644 --- a/pkg/kubectl-argo-rollouts/cmd/get/get_test.go +++ b/pkg/kubectl-argo-rollouts/cmd/get/get_test.go @@ -102,6 +102,20 @@ func TestWatchRolloutNotFound(t *testing.T) { assert.Equal(t, "Error: rollout.argoproj.io \"does-not-exist\" not found\n", stderr) } +func TestWatchBlueGreenRollout(t *testing.T) { + rolloutObjs := testdata.NewBlueGreenRollout() + + tf, o := options.NewFakeArgoRolloutsOptions(rolloutObjs.AllObjects()...) + o.RESTClientGetter = tf.WithNamespace(rolloutObjs.Rollouts[0].Namespace) + defer tf.Cleanup() + cmd := NewCmdGetRollout(o) + cmd.PersistentPreRunE = o.PersistentPreRunE + cmd.SetArgs([]string{rolloutObjs.Rollouts[0].Name, "--no-color", "--watch", "--timeout-seconds", "10"}) + err := cmd.Execute() + assert.NoError(t, err) + rolloutObjs = nil +} + func TestGetBlueGreenRollout(t *testing.T) { rolloutObjs := testdata.NewBlueGreenRollout() diff --git a/pkg/kubectl-argo-rollouts/cmd/status/status.go b/pkg/kubectl-argo-rollouts/cmd/status/status.go index f92f231e65..833b3fda29 100644 --- a/pkg/kubectl-argo-rollouts/cmd/status/status.go +++ b/pkg/kubectl-argo-rollouts/cmd/status/status.go @@ -5,7 +5,7 @@ import ( "fmt" "time" - "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/info" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/options" "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/viewcontroller" "github.com/spf13/cobra" @@ -60,9 +60,9 @@ func NewCmdStatus(o *options.ArgoRolloutsOptions) *cobra.Command { if !statusOptions.Watch { fmt.Fprintln(o.Out, ri.Status) } else { - rolloutUpdates := make(chan *info.RolloutInfo) + rolloutUpdates := make(chan *rollout.RolloutInfo) defer close(rolloutUpdates) - controller.RegisterCallback(func(roInfo *info.RolloutInfo) { + controller.RegisterCallback(func(roInfo *rollout.RolloutInfo) { rolloutUpdates <- roInfo }) go statusOptions.WatchStatus(ctx.Done(), cancel, statusOptions.Timeout, rolloutUpdates) @@ -88,9 +88,9 @@ func NewCmdStatus(o *options.ArgoRolloutsOptions) *cobra.Command { return cmd } -func (o *StatusOptions) WatchStatus(stopCh <-chan struct{}, cancelFunc context.CancelFunc, timeoutSeconds int64, rolloutUpdates chan *info.RolloutInfo) { +func (o *StatusOptions) WatchStatus(stopCh <-chan struct{}, cancelFunc context.CancelFunc, timeoutSeconds int64, rolloutUpdates chan *rollout.RolloutInfo) { timeout := make(chan bool) - var roInfo *info.RolloutInfo + var roInfo *rollout.RolloutInfo var preventFlicker time.Time if timeoutSeconds != 0 { diff --git a/pkg/kubectl-argo-rollouts/info/analysisrun_info.go b/pkg/kubectl-argo-rollouts/info/analysisrun_info.go index d92566d218..cecc3f2cd9 100644 --- a/pkg/kubectl-argo-rollouts/info/analysisrun_info.go +++ b/pkg/kubectl-argo-rollouts/info/analysisrun_info.go @@ -3,39 +3,23 @@ package info import ( "sort" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" "github.com/argoproj/argo-rollouts/metricproviders/job" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" analysisutil "github.com/argoproj/argo-rollouts/utils/analysis" ) -type AnalysisRunInfo struct { - Metadata - Icon string - Revision int - Status string - Successful int32 - Failed int32 - Inconclusive int32 - Error int32 - Jobs []JobInfo -} - -type JobInfo struct { - Metadata - Status string - Icon string -} - -func getAnalysisRunInfo(ownerUID types.UID, allAnalysisRuns []*v1alpha1.AnalysisRun) []AnalysisRunInfo { - var arInfos []AnalysisRunInfo +func getAnalysisRunInfo(ownerUID types.UID, allAnalysisRuns []*v1alpha1.AnalysisRun) []*rollout.AnalysisRunInfo { + var arInfos []*rollout.AnalysisRunInfo for _, run := range allAnalysisRuns { if ownerRef(run.OwnerReferences, []types.UID{ownerUID}) == nil { continue } - arInfo := AnalysisRunInfo{ - Metadata: Metadata{ + arInfo := rollout.AnalysisRunInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: run.Name, Namespace: run.Namespace, CreationTimestamp: run.CreationTimestamp, @@ -51,33 +35,33 @@ func getAnalysisRunInfo(ownerUID types.UID, allAnalysisRuns []*v1alpha1.Analysis lastMeasurement := analysisutil.LastMeasurement(run, mr.Name) if lastMeasurement != nil && lastMeasurement.Metadata != nil { if jobName, ok := lastMeasurement.Metadata[job.JobNameKey]; ok { - jobInfo := JobInfo{ - Metadata: Metadata{ + jobInfo := rollout.JobInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: jobName, }, Icon: analysisIcon(lastMeasurement.Phase), Status: string(lastMeasurement.Phase), } if lastMeasurement.StartedAt != nil { - jobInfo.CreationTimestamp = *lastMeasurement.StartedAt + jobInfo.ObjectMeta.CreationTimestamp = *lastMeasurement.StartedAt } - arInfo.Jobs = append(arInfo.Jobs, jobInfo) + arInfo.Jobs = append(arInfo.Jobs, &jobInfo) } } } arInfo.Icon = analysisIcon(run.Status.Phase) - arInfo.Revision = parseRevision(run.ObjectMeta.Annotations) + arInfo.Revision = int32(parseRevision(run.ObjectMeta.Annotations)) - arInfos = append(arInfos, arInfo) + arInfos = append(arInfos, &arInfo) } sort.Slice(arInfos[:], func(i, j int) bool { if arInfos[i].Revision != arInfos[j].Revision { return arInfos[i].Revision > arInfos[j].Revision } - if arInfos[i].CreationTimestamp != arInfos[j].CreationTimestamp { - return arInfos[i].CreationTimestamp.Before(&arInfos[j].CreationTimestamp) + if arInfos[i].ObjectMeta.CreationTimestamp != arInfos[j].ObjectMeta.CreationTimestamp { + return arInfos[i].ObjectMeta.CreationTimestamp.Before(&arInfos[j].ObjectMeta.CreationTimestamp) } - return arInfos[i].Name > arInfos[j].Name + return arInfos[i].ObjectMeta.Name > arInfos[j].ObjectMeta.Name }) return arInfos } diff --git a/pkg/kubectl-argo-rollouts/info/experiment_info.go b/pkg/kubectl-argo-rollouts/info/experiment_info.go index 1e4ba1a6cc..1799577cc1 100644 --- a/pkg/kubectl-argo-rollouts/info/experiment_info.go +++ b/pkg/kubectl-argo-rollouts/info/experiment_info.go @@ -6,30 +6,22 @@ import ( appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" ) -type ExperimentInfo struct { - Metadata - Icon string - Revision int - Status string - Message string - ReplicaSets []ReplicaSetInfo - AnalysisRuns []AnalysisRunInfo -} - func NewExperimentInfo( exp *v1alpha1.Experiment, allReplicaSets []*appsv1.ReplicaSet, allAnalysisRuns []*v1alpha1.AnalysisRun, allPods []*corev1.Pod, -) *ExperimentInfo { +) *rollout.ExperimentInfo { - expInfo := ExperimentInfo{ - Metadata: Metadata{ + expInfo := rollout.ExperimentInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: exp.Name, Namespace: exp.Namespace, CreationTimestamp: exp.CreationTimestamp, @@ -39,8 +31,8 @@ func NewExperimentInfo( Message: exp.Status.Message, } expInfo.Icon = analysisIcon(exp.Status.Phase) - expInfo.Revision = parseRevision(exp.ObjectMeta.Annotations) - expInfo.ReplicaSets = getReplicaSetInfo(exp.UID, nil, allReplicaSets, allPods) + expInfo.Revision = int32(parseRevision(exp.ObjectMeta.Annotations)) + expInfo.ReplicaSets = GetReplicaSetInfo(exp.UID, nil, allReplicaSets, allPods) expInfo.AnalysisRuns = getAnalysisRunInfo(exp.UID, allAnalysisRuns) return &expInfo } @@ -51,27 +43,27 @@ func getExperimentInfo( allReplicaSets []*appsv1.ReplicaSet, allAnalysisRuns []*v1alpha1.AnalysisRun, allPods []*corev1.Pod, -) []ExperimentInfo { +) []*rollout.ExperimentInfo { - var expInfos []ExperimentInfo + var expInfos []*rollout.ExperimentInfo for _, exp := range allExperiments { if ownerRef(exp.OwnerReferences, []types.UID{ro.UID}) == nil { continue } expInfo := NewExperimentInfo(exp, allReplicaSets, allAnalysisRuns, allPods) - expInfos = append(expInfos, *expInfo) + expInfos = append(expInfos, expInfo) } sort.Slice(expInfos[:], func(i, j int) bool { if expInfos[i].Revision > expInfos[j].Revision { return true } - return expInfos[i].CreationTimestamp.Before(&expInfos[j].CreationTimestamp) + return expInfos[i].ObjectMeta.CreationTimestamp.Before(&expInfos[j].ObjectMeta.CreationTimestamp) }) return expInfos } // Images returns a list of images that are currently running along with tags on which stack they belong to -func (r *ExperimentInfo) Images() []ImageInfo { +func ExperimentImages(r *rollout.ExperimentInfo) []ImageInfo { var images []ImageInfo for _, rsInfo := range r.ReplicaSets { if rsInfo.Replicas > 0 { diff --git a/pkg/kubectl-argo-rollouts/info/info.go b/pkg/kubectl-argo-rollouts/info/info.go index 563b4faef7..01fd1ebb5c 100644 --- a/pkg/kubectl-argo-rollouts/info/info.go +++ b/pkg/kubectl-argo-rollouts/info/info.go @@ -4,6 +4,7 @@ import ( "strconv" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/duration" @@ -29,19 +30,14 @@ const ( InfoTagPreview = "preview" ) -type Metadata struct { - Name string - Namespace string - UID types.UID - CreationTimestamp metav1.Time -} +type Metadata v1.ObjectMeta type ImageInfo struct { Image string Tags []string } -func (m Metadata) Age() string { +func Age(m v1.ObjectMeta) string { return duration.HumanDuration(metav1.Now().Sub(m.CreationTimestamp.Time)) } diff --git a/pkg/kubectl-argo-rollouts/info/info_test.go b/pkg/kubectl-argo-rollouts/info/info_test.go index 75d3535b09..6fe32f17a5 100644 --- a/pkg/kubectl-argo-rollouts/info/info_test.go +++ b/pkg/kubectl-argo-rollouts/info/info_test.go @@ -73,21 +73,20 @@ func newBlueGreenRollout() *v1alpha1.Rollout { }, } } - func TestAge(t *testing.T) { - m := Metadata{ + m := metav1.ObjectMeta{ CreationTimestamp: metav1.NewTime(time.Now().Add(-7 * time.Hour * time.Duration(24))), } - assert.Equal(t, "7d", m.Age()) + assert.Equal(t, "7d", Age(m)) } func TestCanaryRolloutInfo(t *testing.T) { rolloutObjs := testdata.NewCanaryRollout() roInfo := NewRolloutInfo(rolloutObjs.Rollouts[0], rolloutObjs.ReplicaSets, rolloutObjs.Pods, rolloutObjs.Experiments, rolloutObjs.AnalysisRuns) - assert.Equal(t, roInfo.Name, rolloutObjs.Rollouts[0].Name) - assert.Len(t, roInfo.Revisions(), 3) + assert.Equal(t, roInfo.ObjectMeta.Name, rolloutObjs.Rollouts[0].Name) + assert.Len(t, Revisions(roInfo), 3) - assert.Equal(t, roInfo.Images(), []ImageInfo{ + assert.Equal(t, Images(roInfo), []ImageInfo{ { Image: "argoproj/rollouts-demo:does-not-exist", Tags: []string{InfoTagCanary}, @@ -103,17 +102,17 @@ func TestBlueGreenRolloutInfo(t *testing.T) { { rolloutObjs := testdata.NewBlueGreenRollout() roInfo := NewRolloutInfo(rolloutObjs.Rollouts[0], rolloutObjs.ReplicaSets, rolloutObjs.Pods, rolloutObjs.Experiments, rolloutObjs.AnalysisRuns) - assert.Equal(t, roInfo.Name, rolloutObjs.Rollouts[0].Name) - assert.Len(t, roInfo.Revisions(), 3) + assert.Equal(t, roInfo.ObjectMeta.Name, rolloutObjs.Rollouts[0].Name) + assert.Len(t, Revisions(roInfo), 3) - assert.Len(t, roInfo.ReplicaSetsByRevision(11), 1) - assert.Len(t, roInfo.ReplicaSetsByRevision(10), 1) - assert.Len(t, roInfo.ReplicaSetsByRevision(8), 1) + assert.Len(t, ReplicaSetsByRevision(roInfo, 11), 1) + assert.Len(t, ReplicaSetsByRevision(roInfo, 10), 1) + assert.Len(t, ReplicaSetsByRevision(roInfo, 8), 1) assert.Equal(t, roInfo.ReplicaSets[0].ScaleDownDeadline, "") - assert.Equal(t, roInfo.ReplicaSets[0].ScaleDownDelay(), "") + assert.Equal(t, ScaleDownDelay(*roInfo.ReplicaSets[0]), "") - assert.Equal(t, roInfo.Images(), []ImageInfo{ + assert.Equal(t, Images(roInfo), []ImageInfo{ { Image: "argoproj/rollouts-demo:blue", Tags: []string{InfoTagStable, InfoTagActive}, @@ -131,24 +130,24 @@ func TestBlueGreenRolloutInfo(t *testing.T) { delayedRs := rolloutObjs.ReplicaSets[0].ObjectMeta.UID roInfo := NewRolloutInfo(rolloutObjs.Rollouts[0], rolloutObjs.ReplicaSets, rolloutObjs.Pods, rolloutObjs.Experiments, rolloutObjs.AnalysisRuns) - assert.Equal(t, roInfo.ReplicaSets[1].UID, delayedRs) + assert.Equal(t, roInfo.ReplicaSets[1].ObjectMeta.UID, delayedRs) assert.Equal(t, roInfo.ReplicaSets[1].ScaleDownDeadline, inFourHours) - assert.Equal(t, roInfo.ReplicaSets[1].ScaleDownDelay(), "3h59m") + assert.Equal(t, ScaleDownDelay(*roInfo.ReplicaSets[1]), "3h59m") } } func TestExperimentAnalysisRolloutInfo(t *testing.T) { rolloutObjs := testdata.NewExperimentAnalysisRollout() roInfo := NewRolloutInfo(rolloutObjs.Rollouts[0], rolloutObjs.ReplicaSets, rolloutObjs.Pods, rolloutObjs.Experiments, rolloutObjs.AnalysisRuns) - assert.Equal(t, roInfo.Name, rolloutObjs.Rollouts[0].Name) - assert.Len(t, roInfo.Revisions(), 2) + assert.Equal(t, roInfo.ObjectMeta.Name, rolloutObjs.Rollouts[0].Name) + assert.Len(t, Revisions(roInfo), 2) - assert.Len(t, roInfo.ReplicaSetsByRevision(1), 1) - assert.Len(t, roInfo.ReplicaSetsByRevision(2), 1) - assert.Len(t, roInfo.ExperimentsByRevision(2), 1) - assert.Len(t, roInfo.AnalysisRunsByRevision(2), 1) + assert.Len(t, ReplicaSetsByRevision(roInfo, 1), 1) + assert.Len(t, ReplicaSetsByRevision(roInfo, 2), 1) + assert.Len(t, ExperimentsByRevision(roInfo, 2), 1) + assert.Len(t, AnalysisRunsByRevision(roInfo, 2), 1) - assert.Equal(t, roInfo.Images(), []ImageInfo{ + assert.Equal(t, Images(roInfo), []ImageInfo{ { Image: "argoproj/rollouts-demo:blue", Tags: []string{InfoTagStable}, @@ -163,9 +162,9 @@ func TestExperimentAnalysisRolloutInfo(t *testing.T) { func TestExperimentInfo(t *testing.T) { rolloutObjs := testdata.NewExperimentAnalysisRollout() expInfo := NewExperimentInfo(rolloutObjs.Experiments[0], rolloutObjs.ReplicaSets, rolloutObjs.AnalysisRuns, rolloutObjs.Pods) - assert.Equal(t, expInfo.Name, rolloutObjs.Experiments[0].Name) + assert.Equal(t, expInfo.ObjectMeta.Name, rolloutObjs.Experiments[0].Name) - assert.Equal(t, expInfo.Images(), []ImageInfo{ + assert.Equal(t, ExperimentImages(expInfo), []ImageInfo{ { Image: "argoproj/rollouts-demo:blue", }, diff --git a/pkg/kubectl-argo-rollouts/info/pod_info.go b/pkg/kubectl-argo-rollouts/info/pod_info.go index d312416580..e53f350848 100644 --- a/pkg/kubectl-argo-rollouts/info/pod_info.go +++ b/pkg/kubectl-argo-rollouts/info/pod_info.go @@ -5,25 +5,19 @@ import ( "sort" "strings" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" corev1 "k8s.io/api/core/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" k8snode "k8s.io/kubernetes/pkg/util/node" ) -type PodInfo struct { - Metadata - Status string - Icon string - Ready string - Restarts int -} - -func addPodInfos(rsInfos []ReplicaSetInfo, allPods []*corev1.Pod) []ReplicaSetInfo { +func addPodInfos(rsInfos []*rollout.ReplicaSetInfo, allPods []*corev1.Pod) []*rollout.ReplicaSetInfo { var uids []types.UID uidToRSInfoIdx := make(map[types.UID]int) for i, rsInfo := range rsInfos { - uids = append(uids, rsInfo.UID) - uidToRSInfoIdx[rsInfo.UID] = i + uids = append(uids, rsInfo.ObjectMeta.UID) + uidToRSInfoIdx[rsInfo.ObjectMeta.UID] = i } for _, pod := range allPods { @@ -34,24 +28,24 @@ func addPodInfos(rsInfos []ReplicaSetInfo, allPods []*corev1.Pod) []ReplicaSetIn podInfo := newPodInfo(pod) idx := uidToRSInfoIdx[owner.UID] - rsInfos[idx].Pods = append(rsInfos[idx].Pods, podInfo) + rsInfos[idx].Pods = append(rsInfos[idx].Pods, &podInfo) } for _, rsInfo := range rsInfos { sort.Slice(rsInfo.Pods[:], func(i, j int) bool { - if rsInfo.Pods[i].CreationTimestamp != rsInfo.Pods[j].CreationTimestamp { - return rsInfo.Pods[i].CreationTimestamp.Before(&rsInfo.Pods[j].CreationTimestamp) + if rsInfo.Pods[i].ObjectMeta.CreationTimestamp != rsInfo.Pods[j].ObjectMeta.CreationTimestamp { + return rsInfo.Pods[i].ObjectMeta.CreationTimestamp.Before(&rsInfo.Pods[j].ObjectMeta.CreationTimestamp) } - return rsInfo.Pods[i].Name < rsInfo.Pods[j].Name + return rsInfo.Pods[i].ObjectMeta.Name < rsInfo.Pods[j].ObjectMeta.Name }) } return rsInfos } -func newPodInfo(pod *corev1.Pod) PodInfo { - podInfo := PodInfo{ - Metadata: Metadata{ +func newPodInfo(pod *corev1.Pod) rollout.PodInfo { + podInfo := rollout.PodInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: pod.Name, Namespace: pod.Namespace, CreationTimestamp: pod.CreationTimestamp, @@ -131,7 +125,7 @@ func newPodInfo(pod *corev1.Pod) PodInfo { podInfo.Status = reason podInfo.Icon = podIcon(podInfo.Status) podInfo.Ready = fmt.Sprintf("%d/%d", readyContainers, totalContainers) - podInfo.Restarts = restarts + podInfo.Restarts = int32(restarts) return podInfo } diff --git a/pkg/kubectl-argo-rollouts/info/replicaset_info.go b/pkg/kubectl-argo-rollouts/info/replicaset_info.go index 57f87cef53..44f148f0b5 100644 --- a/pkg/kubectl-argo-rollouts/info/replicaset_info.go +++ b/pkg/kubectl-argo-rollouts/info/replicaset_info.go @@ -5,42 +5,27 @@ import ( "time" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/duration" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" replicasetutil "github.com/argoproj/argo-rollouts/utils/replicaset" ) -type ReplicaSetInfo struct { - Metadata - Status string - Icon string - Revision int - Stable bool - Canary bool - Active bool - Preview bool - Replicas int32 - Available int32 - Template string - ScaleDownDeadline string - Images []string - Pods []PodInfo -} - -func getReplicaSetInfo(ownerUID types.UID, ro *v1alpha1.Rollout, allReplicaSets []*appsv1.ReplicaSet, allPods []*corev1.Pod) []ReplicaSetInfo { - var rsInfos []ReplicaSetInfo +func GetReplicaSetInfo(ownerUID types.UID, ro *v1alpha1.Rollout, allReplicaSets []*appsv1.ReplicaSet, allPods []*corev1.Pod) []*rollout.ReplicaSetInfo { + var rsInfos []*rollout.ReplicaSetInfo for _, rs := range allReplicaSets { // if owned by replicaset if ownerRef(rs.OwnerReferences, []types.UID{ownerUID}) == nil { continue } - rsInfo := ReplicaSetInfo{ - Metadata: Metadata{ + rsInfo := &rollout.ReplicaSetInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: rs.Name, Namespace: rs.Namespace, CreationTimestamp: rs.CreationTimestamp, @@ -51,7 +36,7 @@ func getReplicaSetInfo(ownerUID types.UID, ro *v1alpha1.Rollout, allReplicaSets Available: rs.Status.AvailableReplicas, } rsInfo.Icon = replicaSetIcon(rsInfo.Status) - rsInfo.Revision = parseRevision(rs.ObjectMeta.Annotations) + rsInfo.Revision = int32(parseRevision(rs.ObjectMeta.Annotations)) rsInfo.Template = parseExperimentTemplateName(rs.ObjectMeta.Annotations) rsInfo.ScaleDownDeadline = parseScaleDownDeadline(rs.ObjectMeta.Annotations) @@ -85,10 +70,10 @@ func getReplicaSetInfo(ownerUID types.UID, ro *v1alpha1.Rollout, allReplicaSets if rsInfos[i].Revision != rsInfos[j].Revision { return rsInfos[i].Revision > rsInfos[j].Revision } - if rsInfos[i].CreationTimestamp != rsInfos[j].CreationTimestamp { - rsInfos[i].CreationTimestamp.Before(&rsInfos[j].CreationTimestamp) + if rsInfos[i].ObjectMeta.CreationTimestamp != rsInfos[j].ObjectMeta.CreationTimestamp { + rsInfos[i].ObjectMeta.CreationTimestamp.Before(&rsInfos[j].ObjectMeta.CreationTimestamp) } - return rsInfos[i].Name < rsInfos[j].Name + return rsInfos[i].ObjectMeta.Name < rsInfos[j].ObjectMeta.Name }) return addPodInfos(rsInfos, allPods) } @@ -134,7 +119,7 @@ func getReplicaSetCondition(status appsv1.ReplicaSetStatus, condType appsv1.Repl return nil } -func (rs ReplicaSetInfo) ScaleDownDelay() string { +func ScaleDownDelay(rs rollout.ReplicaSetInfo) string { if deadline, err := time.Parse(time.RFC3339, rs.ScaleDownDeadline); err == nil { now := metav1.Now().Time if deadline.Before(now) { diff --git a/pkg/kubectl-argo-rollouts/info/rollout_info.go b/pkg/kubectl-argo-rollouts/info/rollout_info.go index 900e9f8cd6..7175a265a3 100644 --- a/pkg/kubectl-argo-rollouts/info/rollout_info.go +++ b/pkg/kubectl-argo-rollouts/info/rollout_info.go @@ -7,52 +7,34 @@ import ( appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" "github.com/argoproj/argo-rollouts/utils/conditions" "github.com/argoproj/argo-rollouts/utils/defaults" replicasetutil "github.com/argoproj/argo-rollouts/utils/replicaset" ) -type RolloutInfo struct { - Metadata - - Status string - Message string - Icon string - Strategy string - Step string - SetWeight string - ActualWeight string - - Ready int32 - Current int32 - Desired int32 - Updated int32 - Available int32 - - ReplicaSets []ReplicaSetInfo - Experiments []ExperimentInfo - AnalysisRuns []AnalysisRunInfo -} - func NewRolloutInfo( ro *v1alpha1.Rollout, allReplicaSets []*appsv1.ReplicaSet, allPods []*corev1.Pod, allExperiments []*v1alpha1.Experiment, allARs []*v1alpha1.AnalysisRun, -) *RolloutInfo { +) *rollout.RolloutInfo { - roInfo := RolloutInfo{ - Metadata: Metadata{ + roInfo := rollout.RolloutInfo{ + ObjectMeta: &v1.ObjectMeta{ Name: ro.Name, Namespace: ro.Namespace, UID: ro.UID, CreationTimestamp: ro.CreationTimestamp, + ResourceVersion: ro.ObjectMeta.ResourceVersion, }, } - roInfo.ReplicaSets = getReplicaSetInfo(ro.UID, ro, allReplicaSets, allPods) + + roInfo.ReplicaSets = GetReplicaSetInfo(ro.UID, ro, allReplicaSets, allPods) roInfo.Experiments = getExperimentInfo(ro, allExperiments, allReplicaSets, allARs, allPods) roInfo.AnalysisRuns = getAnalysisRunInfo(ro.UID, allARs) @@ -60,6 +42,11 @@ func NewRolloutInfo( roInfo.Strategy = "Canary" if ro.Status.CurrentStepIndex != nil && len(ro.Spec.Strategy.Canary.Steps) > 0 { roInfo.Step = fmt.Sprintf("%d/%d", *ro.Status.CurrentStepIndex, len(ro.Spec.Strategy.Canary.Steps)) + var steps []*v1alpha1.CanaryStep + for i := range ro.Spec.Strategy.Canary.Steps { + steps = append(steps, &ro.Spec.Strategy.Canary.Steps[i]) + } + roInfo.Steps = steps } // NOTE that this is desired weight, not the actual current weight roInfo.SetWeight = strconv.Itoa(int(replicasetutil.GetCurrentSetWeight(ro))) @@ -85,6 +72,19 @@ func NewRolloutInfo( } roInfo.Status, roInfo.Message = RolloutStatusString(ro) roInfo.Icon = rolloutIcon(roInfo.Status) + roInfo.Containers = []*rollout.ContainerInfo{} + for c := range ro.Spec.Template.Spec.Containers { + curContainer := ro.Spec.Template.Spec.Containers[c] + roInfo.Containers = append(roInfo.Containers, &rollout.ContainerInfo{Name: curContainer.Name, Image: curContainer.Image}) + } + + if ro.Status.RestartedAt != nil { + roInfo.RestartedAt = ro.Status.RestartedAt.String() + } else { + roInfo.RestartedAt = "Never" + } + + roInfo.Generation = ro.Status.ObservedGeneration roInfo.Desired = defaults.GetReplicasOrDefault(ro.Spec.Replicas) roInfo.Ready = ro.Status.ReadyReplicas @@ -208,7 +208,7 @@ func rolloutIcon(status string) string { // Images returns a list of images that are currently running along with informational tags about // 1. which stack they belong to (canary, stable, active, preview) // 2. which experiment template they are part of -func (r *RolloutInfo) Images() []ImageInfo { +func Images(r *rollout.RolloutInfo) []ImageInfo { var images []ImageInfo for _, rsInfo := range r.ReplicaSets { if rsInfo.Replicas > 0 { @@ -233,7 +233,7 @@ func (r *RolloutInfo) Images() []ImageInfo { } } for _, expInfo := range r.Experiments { - for _, expImage := range expInfo.Images() { + for _, expImage := range ExperimentImages(expInfo) { images = mergeImageAndTags(expImage, images) } } @@ -278,16 +278,16 @@ func mergeTags(newTags []string, existingTags []string) []string { return tags } -func (r *RolloutInfo) Revisions() []int { +func Revisions(r *rollout.RolloutInfo) []int { revisionMap := make(map[int]bool) for _, rsInfo := range r.ReplicaSets { - revisionMap[rsInfo.Revision] = true + revisionMap[int(rsInfo.Revision)] = true } for _, expInfo := range r.Experiments { - revisionMap[expInfo.Revision] = true + revisionMap[int(expInfo.Revision)] = true } for _, arInfo := range r.AnalysisRuns { - revisionMap[arInfo.Revision] = true + revisionMap[int(arInfo.Revision)] = true } revisions := make([]int, 0, len(revisionMap)) for k := range revisionMap { @@ -297,30 +297,30 @@ func (r *RolloutInfo) Revisions() []int { return revisions } -func (r *RolloutInfo) ReplicaSetsByRevision(rev int) []ReplicaSetInfo { - var replicaSets []ReplicaSetInfo +func ReplicaSetsByRevision(r *rollout.RolloutInfo, rev int) []*rollout.ReplicaSetInfo { + var replicaSets []*rollout.ReplicaSetInfo for _, rs := range r.ReplicaSets { - if rs.Revision == rev { + if rs.Revision == int32(rev) { replicaSets = append(replicaSets, rs) } } return replicaSets } -func (r *RolloutInfo) ExperimentsByRevision(rev int) []ExperimentInfo { - var experiments []ExperimentInfo +func ExperimentsByRevision(r *rollout.RolloutInfo, rev int) []*rollout.ExperimentInfo { + var experiments []*rollout.ExperimentInfo for _, e := range r.Experiments { - if e.Revision == rev { + if int(e.Revision) == rev { experiments = append(experiments, e) } } return experiments } -func (r *RolloutInfo) AnalysisRunsByRevision(rev int) []AnalysisRunInfo { - var runs []AnalysisRunInfo +func AnalysisRunsByRevision(r *rollout.RolloutInfo, rev int) []*rollout.AnalysisRunInfo { + var runs []*rollout.AnalysisRunInfo for _, run := range r.AnalysisRuns { - if run.Revision == rev { + if int(run.Revision) == rev { runs = append(runs, run) } } diff --git a/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller.go b/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller.go index 67a41647d6..2add879dd2 100644 --- a/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller.go +++ b/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller.go @@ -16,6 +16,7 @@ import ( "k8s.io/client-go/tools/cache" "k8s.io/client-go/util/workqueue" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" rolloutclientset "github.com/argoproj/argo-rollouts/pkg/client/clientset/versioned" rolloutinformers "github.com/argoproj/argo-rollouts/pkg/client/informers/externalversions" rolloutlisters "github.com/argoproj/argo-rollouts/pkg/client/listers/rollouts/v1alpha1" @@ -53,9 +54,9 @@ type ExperimentViewController struct { *viewController } -type RolloutInfoCallback func(*info.RolloutInfo) +type RolloutInfoCallback func(*rollout.RolloutInfo) -type ExperimentInfoCallback func(*info.ExperimentInfo) +type ExperimentInfoCallback func(*rollout.ExperimentInfo) func NewRolloutViewController(namespace string, name string, kubeClient kubernetes.Interface, rolloutClient rolloutclientset.Interface) *RolloutViewController { vc := newViewController(namespace, name, kubeClient, rolloutClient) @@ -165,7 +166,7 @@ func (c *viewController) processNextWorkItem() bool { return true } -func (c *RolloutViewController) GetRolloutInfo() (*info.RolloutInfo, error) { +func (c *RolloutViewController) GetRolloutInfo() (*rollout.RolloutInfo, error) { ro, err := c.rolloutLister.Get(c.name) if err != nil { return nil, err @@ -197,12 +198,12 @@ func (c *RolloutViewController) GetRolloutInfo() (*info.RolloutInfo, error) { func (c *RolloutViewController) RegisterCallback(callback RolloutInfoCallback) { cb := func(i interface{}) { - callback(i.(*info.RolloutInfo)) + callback(i.(*rollout.RolloutInfo)) } c.callbacks = append(c.callbacks, cb) } -func (c *ExperimentViewController) GetExperimentInfo() (*info.ExperimentInfo, error) { +func (c *ExperimentViewController) GetExperimentInfo() (*rollout.ExperimentInfo, error) { exp, err := c.experimentLister.Get(c.name) if err != nil { return nil, err @@ -225,7 +226,7 @@ func (c *ExperimentViewController) GetExperimentInfo() (*info.ExperimentInfo, er func (c *ExperimentViewController) RegisterCallback(callback ExperimentInfoCallback) { cb := func(i interface{}) { - callback(i.(*info.ExperimentInfo)) + callback(i.(*rollout.ExperimentInfo)) } c.callbacks = append(c.callbacks, cb) } diff --git a/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller_test.go b/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller_test.go index 7ffc8bab2a..90752629c2 100644 --- a/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller_test.go +++ b/pkg/kubectl-argo-rollouts/viewcontroller/viewcontroller_test.go @@ -5,8 +5,8 @@ import ( "testing" "time" + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" rolloutsfake "github.com/argoproj/argo-rollouts/pkg/client/clientset/versioned/fake" - "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/info" "github.com/stretchr/testify/assert" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/runtime" @@ -41,7 +41,7 @@ func TestRolloutController(t *testing.T) { cancel() roInfo, err := c.GetRolloutInfo() assert.NoError(t, err) - assert.Equal(t, roInfo.Name, "foo") + assert.Equal(t, roInfo.ObjectMeta.Name, "foo") } func TestRolloutControllerCallback(t *testing.T) { @@ -53,9 +53,9 @@ func TestRolloutControllerCallback(t *testing.T) { } callbackCalled := false - cb := func(roInfo *info.RolloutInfo) { + cb := func(roInfo *rollout.RolloutInfo) { callbackCalled = true - assert.Equal(t, roInfo.Name, "foo") + assert.Equal(t, roInfo.ObjectMeta.Name, "foo") } c := newFakeRolloutController(ro.Namespace, ro.Name, ro) @@ -89,7 +89,7 @@ func TestExperimentController(t *testing.T) { cancel() roInfo, err := c.GetExperimentInfo() assert.NoError(t, err) - assert.Equal(t, roInfo.Name, "foo") + assert.Equal(t, roInfo.ObjectMeta.Name, "foo") } func TestExperimentControllerCallback(t *testing.T) { @@ -101,9 +101,9 @@ func TestExperimentControllerCallback(t *testing.T) { } callbackCalled := false - cb := func(expInfo *info.ExperimentInfo) { + cb := func(expInfo *rollout.ExperimentInfo) { callbackCalled = true - assert.Equal(t, expInfo.Name, "foo") + assert.Equal(t, expInfo.ObjectMeta.Name, "foo") } c := newFakeExperimentController(ro.Namespace, ro.Name, ro) diff --git a/server/server.go b/server/server.go new file mode 100644 index 0000000000..96a18005ea --- /dev/null +++ b/server/server.go @@ -0,0 +1,425 @@ +package server + +import ( + "context" + "embed" + "fmt" + "io/fs" + "net" + "net/http" + "os" + "time" + + "github.com/argoproj/pkg/errors" + "github.com/golang/protobuf/ptypes/empty" + "github.com/grpc-ecosystem/grpc-gateway/runtime" + log "github.com/sirupsen/logrus" + "github.com/soheilhy/cmux" + "google.golang.org/grpc" + appsv1 "k8s.io/api/apps/v1" + corev1 "k8s.io/api/core/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/labels" + "k8s.io/apimachinery/pkg/util/wait" + "k8s.io/client-go/dynamic" + kubeinformers "k8s.io/client-go/informers" + "k8s.io/client-go/kubernetes" + appslisters "k8s.io/client-go/listers/apps/v1" + corelisters "k8s.io/client-go/listers/core/v1" + "k8s.io/client-go/tools/cache" + + "github.com/argoproj/argo-rollouts/pkg/apiclient/rollout" + "github.com/argoproj/argo-rollouts/pkg/apis/rollouts/v1alpha1" + rolloutclientset "github.com/argoproj/argo-rollouts/pkg/client/clientset/versioned" + rolloutinformers "github.com/argoproj/argo-rollouts/pkg/client/informers/externalversions" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/abort" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/get" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/promote" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/restart" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/retry" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/set" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/cmd/undo" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/info" + "github.com/argoproj/argo-rollouts/pkg/kubectl-argo-rollouts/viewcontroller" + "github.com/argoproj/argo-rollouts/utils/json" + versionutils "github.com/argoproj/argo-rollouts/utils/version" +) + +//go:embed static/* +var static embed.FS //nolint + +var backoff = wait.Backoff{ + Steps: 5, + Duration: 500 * time.Millisecond, + Factor: 1.0, + Jitter: 0.1, +} + +type ServerOptions struct { + KubeClientset kubernetes.Interface + RolloutsClientset rolloutclientset.Interface + DynamicClientset dynamic.Interface + Namespace string +} + +const ( + // MaxGRPCMessageSize contains max grpc message size + MaxGRPCMessageSize = 100 * 1024 * 1024 +) + +// ArgoRolloutsServer holds information about rollouts server +type ArgoRolloutsServer struct { + Options ServerOptions + NamespaceVC NamespaceViewController + stopCh chan struct{} +} + +type NamespaceViewController struct { + namespace string + + kubeInformerFactory kubeinformers.SharedInformerFactory + replicaSetLister appslisters.ReplicaSetNamespaceLister + podLister corelisters.PodNamespaceLister + cacheSyncs []cache.InformerSynced +} + +func (vc *NamespaceViewController) Start(ctx context.Context) { + vc.kubeInformerFactory.Start(ctx.Done()) + cache.WaitForCacheSync(ctx.Done(), vc.cacheSyncs...) +} + +// NewServer creates an ArgoRolloutsServer +func NewServer(o ServerOptions) *ArgoRolloutsServer { + kubeInformerFactory := kubeinformers.NewSharedInformerFactoryWithOptions(o.KubeClientset, 0, kubeinformers.WithNamespace(o.Namespace)) + + vc := NamespaceViewController{ + namespace: o.Namespace, + kubeInformerFactory: kubeInformerFactory, + podLister: kubeInformerFactory.Core().V1().Pods().Lister().Pods(o.Namespace), + replicaSetLister: kubeInformerFactory.Apps().V1().ReplicaSets().Lister().ReplicaSets(o.Namespace), + } + + vc.cacheSyncs = append(vc.cacheSyncs, + kubeInformerFactory.Apps().V1().ReplicaSets().Informer().HasSynced, + kubeInformerFactory.Core().V1().Pods().Informer().HasSynced, + ) + + return &ArgoRolloutsServer{Options: o, NamespaceVC: vc} +} + +type spaFileSystem struct { + root http.FileSystem +} + +func (fs *spaFileSystem) Open(name string) (http.File, error) { + f, err := fs.root.Open(name) + if os.IsNotExist(err) { + return fs.root.Open("index.html") + } + return f, err +} + +func (s *ArgoRolloutsServer) newHTTPServer(ctx context.Context, port int) *http.Server { + mux := http.NewServeMux() + endpoint := fmt.Sprintf("0.0.0.0:%d", port) + + httpS := http.Server{ + Addr: endpoint, + Handler: mux, + } + + gwMuxOpts := runtime.WithMarshalerOption(runtime.MIMEWildcard, new(json.JSONMarshaler)) + gwmux := runtime.NewServeMux(gwMuxOpts, + runtime.WithIncomingHeaderMatcher(func(key string) (string, bool) { return key, true }), + runtime.WithProtoErrorHandler(runtime.DefaultHTTPProtoErrorHandler), + ) + + opts := []grpc.DialOption{ + grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(MaxGRPCMessageSize)), + } + opts = append(opts, grpc.WithInsecure()) + + err := rollout.RegisterRolloutServiceHandlerFromEndpoint(ctx, gwmux, endpoint, opts) + if err != nil { + panic(err) + } + + var handler http.Handler = gwmux + + ui, err := fs.Sub(static, "static") + if err != nil { + log.Error("Could not load UI static files") + panic(err) + } + + mux.Handle("/api/", handler) + mux.Handle("/", http.FileServer(&spaFileSystem{http.FS(ui)})) + + return &httpS +} + +func (s *ArgoRolloutsServer) newGRPCServer() *grpc.Server { + grpcS := grpc.NewServer() + var rolloutsServer rollout.RolloutServiceServer = NewServer(s.Options) + rollout.RegisterRolloutServiceServer(grpcS, rolloutsServer) + return grpcS +} + +func (s *ArgoRolloutsServer) checkServeErr(name string, err error) { + if err != nil { + if s.stopCh == nil { + log.Infof("graceful shutdown %s: %v", name, err) + } else { + log.Fatalf("%s: %v", name, err) + } + } else { + log.Infof("graceful shutdown %s", name) + } +} + +// Run starts the server +func (s *ArgoRolloutsServer) Run(ctx context.Context, port int, dashboard bool) { + httpServer := s.newHTTPServer(ctx, port) + grpcServer := s.newGRPCServer() + + // Start listener + var conn net.Listener + var realErr error + _ = wait.ExponentialBackoff(backoff, func() (bool, error) { + conn, realErr = net.Listen("tcp", fmt.Sprintf(":%d", port)) + if realErr != nil { + log.Warnf("failed listen: %v", realErr) + return false, nil + } + return true, nil + }) + errors.CheckError(realErr) + + startupMessage := fmt.Sprintf("Argo Rollouts api-server serving on port %d (namespace: %s)", port, s.Options.Namespace) + if dashboard { + startupMessage = fmt.Sprintf("Argo Rollouts Dashboard is now available at localhost %d", port) + } + + log.Info(startupMessage) + + tcpm := cmux.New(conn) + + httpL := tcpm.Match(cmux.HTTP1Fast()) + grpcL := tcpm.Match(cmux.Any()) + + go func() { + s.checkServeErr("httpServer", httpServer.Serve(httpL)) + }() + go func() { + s.checkServeErr("grpcServer", grpcServer.Serve(grpcL)) + }() + go func() { s.checkServeErr("tcpm", tcpm.Serve()) }() + + s.stopCh = make(chan struct{}) + <-s.stopCh + errors.CheckError(conn.Close()) +} + +func (s *ArgoRolloutsServer) initRolloutViewController(name string, ctx context.Context) *viewcontroller.RolloutViewController { + controller := viewcontroller.NewRolloutViewController(s.Options.Namespace, name, s.Options.KubeClientset, s.Options.RolloutsClientset) + controller.Start(ctx) + return controller +} + +func (s *ArgoRolloutsServer) getRolloutInfo(name string) (*rollout.RolloutInfo, error) { + controller := s.initRolloutViewController(name, context.Background()) + ri, err := controller.GetRolloutInfo() + if err != nil { + return nil, err + } + return ri, nil +} + +// GetRollout returns a rollout +func (s *ArgoRolloutsServer) GetRolloutInfo(c context.Context, q *rollout.RolloutInfoQuery) (*rollout.RolloutInfo, error) { + return s.getRolloutInfo(q.GetName()) +} + +// WatchRollout returns a rollout stream +func (s *ArgoRolloutsServer) WatchRolloutInfo(q *rollout.RolloutInfoQuery, ws rollout.RolloutService_WatchRolloutInfoServer) error { + ctx := context.Background() + controller := s.initRolloutViewController(q.GetName(), ctx) + + rolloutUpdates := make(chan *rollout.RolloutInfo) + controller.RegisterCallback(func(roInfo *rollout.RolloutInfo) { + rolloutUpdates <- roInfo + }) + + go get.Watch(ctx.Done(), rolloutUpdates, func(i *rollout.RolloutInfo) { + ws.Send(i) + }) + controller.Run(ctx) + close(rolloutUpdates) + return nil +} + +func (s *ArgoRolloutsServer) ListReplicaSetsAndPods(ctx context.Context) ([]*appsv1.ReplicaSet, []*corev1.Pod, error) { + s.NamespaceVC.Start(ctx) + + allReplicaSets, err := s.NamespaceVC.replicaSetLister.List(labels.Everything()) + if err != nil { + return nil, nil, err + } + + allPods, err := s.NamespaceVC.podLister.List(labels.Everything()) + if err != nil { + return allReplicaSets, nil, err + } + + return allReplicaSets, allPods, nil +} + +// ListRollouts returns a list of all rollouts +func (s *ArgoRolloutsServer) ListRolloutInfos(ctx context.Context, q *rollout.RolloutInfoListQuery) (*rollout.RolloutInfoList, error) { + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + rolloutList, err := rolloutIf.List(ctx, v1.ListOptions{}) + + if err != nil { + return nil, err + } + + allReplicaSets, allPods, err := s.ListReplicaSetsAndPods(ctx) + if err != nil { + return nil, err + } + + var riList []*rollout.RolloutInfo + for i := range rolloutList.Items { + cur := rolloutList.Items[i] + ri := info.NewRolloutInfo(&cur, nil, nil, nil, nil) + ri.ReplicaSets = info.GetReplicaSetInfo(cur.UID, &cur, allReplicaSets, allPods) + riList = append(riList, ri) + } + + return &rollout.RolloutInfoList{Rollouts: riList}, nil +} + +func (s *ArgoRolloutsServer) RestartRollout(ctx context.Context, q *rollout.RestartRolloutRequest) (*v1alpha1.Rollout, error) { + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + restartAt := time.Now().UTC() + return restart.RestartRollout(rolloutIf, q.GetName(), &restartAt) +} + +// WatchRollouts returns a stream of all rollouts +func (s *ArgoRolloutsServer) WatchRolloutInfos(q *rollout.RolloutInfoListQuery, ws rollout.RolloutService_WatchRolloutInfosServer) error { + send := func(r *rollout.RolloutInfo) { + err := ws.Send(&rollout.RolloutWatchEvent{ + Type: "Updated", + RolloutInfo: r, + }) + if err != nil { + return + } + } + ctx := context.Background() + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + + allReplicaSets, allPods, err := s.ListReplicaSetsAndPods(ctx) + if err != nil { + return err + } + + watchIf, err := rolloutIf.Watch(ctx, v1.ListOptions{}) + if err != nil { + return err + } + + var ro *v1alpha1.Rollout + retries := 0 +L: + for { + select { + case next := <-watchIf.ResultChan(): + ro, _ = next.Object.(*v1alpha1.Rollout) + case <-ctx.Done(): + break L + } + if ro == nil { + watchIf.Stop() + newWatchIf, err := rolloutIf.Watch(ctx, v1.ListOptions{}) + if err != nil { + if retries > 5 { + return err + } + log.Warn(err) + time.Sleep(time.Second) + retries++ + } else { + watchIf = newWatchIf + retries = 0 + } + continue + } + // get shallow rollout info + ri := info.NewRolloutInfo(ro, allReplicaSets, allPods, nil, nil) + send(ri) + } + watchIf.Stop() + return nil +} + +func (s *ArgoRolloutsServer) RolloutToRolloutInfo(ro *v1alpha1.Rollout) (*rollout.RolloutInfo, error) { + ctx := context.Background() + allReplicaSets, allPods, err := s.ListReplicaSetsAndPods(ctx) + if err != nil { + return nil, err + } + return info.NewRolloutInfo(ro, allReplicaSets, allPods, nil, nil), nil +} + +func (s *ArgoRolloutsServer) GetNamespace(ctx context.Context, e *empty.Empty) (*rollout.NamespaceInfo, error) { + return &rollout.NamespaceInfo{Namespace: s.Options.Namespace}, nil +} + +func (s *ArgoRolloutsServer) PromoteRollout(ctx context.Context, q *rollout.PromoteRolloutRequest) (*v1alpha1.Rollout, error) { + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + return promote.PromoteRollout(rolloutIf, q.GetName(), false, false, false) +} + +func (s *ArgoRolloutsServer) AbortRollout(ctx context.Context, q *rollout.AbortRolloutRequest) (*v1alpha1.Rollout, error) { + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + return abort.AbortRollout(rolloutIf, q.GetName()) +} + +func (s *ArgoRolloutsServer) getRollout(namespace string, name string) (*v1alpha1.Rollout, error) { + rolloutsInformerFactory := rolloutinformers.NewSharedInformerFactoryWithOptions(s.Options.RolloutsClientset, 0, rolloutinformers.WithNamespace(namespace)) + rolloutsLister := rolloutsInformerFactory.Argoproj().V1alpha1().Rollouts().Lister().Rollouts(namespace) + return rolloutsLister.Get(name) +} + +func (s *ArgoRolloutsServer) SetRolloutImage(ctx context.Context, q *rollout.SetImageRequest) (*v1alpha1.Rollout, error) { + imageString := fmt.Sprintf("%s:%s", q.GetImage(), q.GetTag()) + set.SetImage(s.Options.DynamicClientset, q.GetNamespace(), q.GetRollout(), q.GetContainer(), imageString) + return s.getRollout(q.GetNamespace(), q.GetRollout()) +} + +func (s *ArgoRolloutsServer) UndoRollout(ctx context.Context, q *rollout.UndoRolloutRequest) (*v1alpha1.Rollout, error) { + rolloutIf := s.Options.DynamicClientset.Resource(v1alpha1.RolloutGVR).Namespace(q.GetNamespace()) + _, err := undo.RunUndoRollout(rolloutIf, s.Options.KubeClientset, q.GetRollout(), q.GetRevision()) + if err != nil { + return nil, err + } + return s.getRollout(q.GetNamespace(), q.GetRollout()) +} + +func (s *ArgoRolloutsServer) RetryRollout(ctx context.Context, q *rollout.RetryRolloutRequest) (*v1alpha1.Rollout, error) { + rolloutIf := s.Options.RolloutsClientset.ArgoprojV1alpha1().Rollouts(q.GetNamespace()) + ro, err := retry.RetryRollout(rolloutIf, q.GetName()) + if err != nil { + return nil, err + } + + return ro, nil +} + +func (s *ArgoRolloutsServer) Version(ctx context.Context, _ *empty.Empty) (*rollout.VersionInfo, error) { + version := versionutils.GetVersion() + return &rollout.VersionInfo{ + RolloutsVersion: version.String(), + }, nil +} diff --git a/server/static/.gitkeep b/server/static/.gitkeep new file mode 100644 index 0000000000..e69de29bb2 diff --git a/sonar-project.properties b/sonar-project.properties new file mode 100644 index 0000000000..448dba91da --- /dev/null +++ b/sonar-project.properties @@ -0,0 +1,15 @@ +sonar.projectKey=argoproj_argo-rollouts +sonar.organization=argoproj + +sonar.sources=. +sonar.sourceEncoding=UTF-8 +sonar.host.url=https://sonarcloud.io + +# Exclude following set of patterns from coverage analysis +sonar.coverage.exclusions=**/*.pb.go,**/*.pb.gw.go,**/mocks/**,**/*.ts*,**/vendor/**,**/openapi_generated.go,**/*_test.go,**/*_generated*,test/**,pkg/client/**,pkg/apiclient/** + +# Exclude following set of patterns from code analysis +sonar.go.exclusions=**/vendor/**,*/*.pb.go,**/*_test.go,**/*.pb.gw.go,**/mocks/**,**/openapi_generated.go,**/*_generated*.go + +# Exclude following set of patterns from duplication detection +sonar.cpd.exclusions=**/*.pb.go,**/*.g.cs,**/*.gw.go,**/mocks/* \ No newline at end of file diff --git a/ui/.gitignore b/ui/.gitignore new file mode 100644 index 0000000000..4d29575de8 --- /dev/null +++ b/ui/.gitignore @@ -0,0 +1,23 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.js + +# testing +/coverage + +# production +/build + +# misc +.DS_Store +.env.local +.env.development.local +.env.test.local +.env.production.local + +npm-debug.log* +yarn-debug.log* +yarn-error.log* diff --git a/ui/.prettierrc b/ui/.prettierrc new file mode 100644 index 0000000000..0abdae70b5 --- /dev/null +++ b/ui/.prettierrc @@ -0,0 +1,9 @@ +{ + "bracketSpacing": false, + "jsxSingleQuote": true, + "printWidth": 180, + "singleQuote": true, + "tabWidth": 4, + "jsxBracketSameLine": true, + "quoteProps": "consistent" +} diff --git a/ui/package.json b/ui/package.json new file mode 100644 index 0000000000..f851407e83 --- /dev/null +++ b/ui/package.json @@ -0,0 +1,70 @@ +{ + "name": "ui", + "version": "0.1.0", + "private": true, + "dependencies": { + "@fortawesome/fontawesome-free": "^5.15.2", + "@fortawesome/fontawesome-svg-core": "^1.2.34", + "@fortawesome/free-regular-svg-icons": "^5.15.2", + "@fortawesome/free-solid-svg-icons": "^5.15.2", + "@fortawesome/react-fontawesome": "^0.1.14", + "@testing-library/jest-dom": "^5.11.4", + "@testing-library/react": "^11.1.0", + "@testing-library/user-event": "^12.1.10", + "@types/jest": "^26.0.15", + "@types/node": "^12.0.0", + "@types/react": "^17.0.0", + "@types/react-dom": "^17.0.0", + "@types/react-helmet": "^6.1.0", + "@types/react-router-dom": "^5.1.7", + "moment": "^2.29.1", + "moment-timezone": "^0.5.33", + "portable-fetch": "^3.0.0", + "react": "^17.0.1", + "react-dom": "^17.0.1", + "react-helmet": "^6.1.0", + "react-hot-loader": "^3.1.3", + "react-keyhooks": "^0.1.2", + "react-router-dom": "^5.2.0", + "react-scripts": "4.0.3", + "rxjs": "^6.6.6", + "typescript": "^4.1.2", + "web-vitals": "^1.0.1", + "webpack-dev-server": "^3.11.2" + }, + "scripts": { + "start": "webpack serve --config ./src/app/webpack.dev.js", + "build": "rm -rf dist && webpack --config ./src/app/webpack.prod.js", + "test": "react-scripts test", + "eject": "react-scripts eject", + "protogen": "swagger-codegen generate -i ../pkg/apiclient/rollout/rollout.swagger.json -l typescript-fetch -o src/models/rollout/generated" + }, + "eslintConfig": { + "extends": [ + "react-app", + "react-app/jest" + ] + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "devDependencies": { + "copy-webpack-plugin": "^6.3.2", + "mini-css-extract-plugin": "^1.3.9", + "raw-loader": "^4.0.2", + "sass": "^1.32.8", + "ts-loader": "^8.0.17", + "webpack-bundle-analyzer": "^4.4.0", + "webpack-cli": "^4.5.0", + "webpack-merge": "^5.7.3" + } +} diff --git a/ui/src/app/App.scss b/ui/src/app/App.scss new file mode 100644 index 0000000000..b4d17a3c74 --- /dev/null +++ b/ui/src/app/App.scss @@ -0,0 +1,38 @@ +@import './shared/styles/colors.scss'; + +body, +html { + padding: 0; + margin: 0; + height: 100%; + button, + form, + input, + textarea { + appearance: none; + -webkit-appearance: none; + color: inherit; + font: inherit; + margin: 0; + } +} + +a { + color: inherit; + text-decoration: none; +} + +#root { + height: 100%; +} + +.rollouts { + height: 100%; + overflow-y: auto; + font-family: 'Heebo', sans-serif; + background-color: $argo-color-gray-3; + + &--dark { + background-color: $midnight-sky; + } +} diff --git a/ui/src/app/App.tsx b/ui/src/app/App.tsx new file mode 100644 index 0000000000..93a1c3fe98 --- /dev/null +++ b/ui/src/app/App.tsx @@ -0,0 +1,55 @@ +import * as React from 'react'; + +import './App.scss'; +import {Header} from './components/header/header'; +import {RolloutsList} from './components/rollouts-list/rollouts-list'; +import {Redirect, Route, Router, Switch} from 'react-router-dom'; +import {Rollout} from './components/rollout/rollout'; +import {createBrowserHistory} from 'history'; +import {ThemeProvider} from './shared/context/theme'; +import {ThemeDiv} from './components/theme-div/theme-div'; +import {NamespaceProvider} from './shared/context/api'; +import {Key, useKeyListener} from 'react-keyhooks'; + +const bases = document.getElementsByTagName('base'); +const base = bases.length > 0 ? bases[0].getAttribute('href') || '/' : '/'; +export const history = createBrowserHistory({basename: base}); + +const Page = (props: {path: string; component: React.ReactNode; exact?: boolean}) => { + return ( + + + +

    + {props.component} + + + + ); +}; + +const App = () => { + const useKeyPress = useKeyListener(); + useKeyPress(Key.Q, () => { + // TODO: Provide help menu for keyboard shortcuts + return false; + }); + return ( + + + + + + + } /> + } /> + + + + + + + ); +}; + +export default App; diff --git a/ui/src/app/components/action-button/action-button.scss b/ui/src/app/components/action-button/action-button.scss new file mode 100644 index 0000000000..ee63848158 --- /dev/null +++ b/ui/src/app/components/action-button/action-button.scss @@ -0,0 +1,74 @@ +@import '../../shared/styles/colors.scss'; + +.action-button { + padding: 10px 14px; + color: white; + flex-shrink: 0; + flex-wrap: nowrap; + cursor: pointer; + margin-right: 7px; + display: flex; + box-sizing: border-box; + align-items: center; + + &--dark { + color: $shine; + &:hover { + color: white; + } + } + + @mixin dark-background { + border: 1px solid $silver-lining; + background-color: $fog; + } + + &--dark > &__background { + @include dark-background; + } + + &__background { + border-radius: 20px; + border: 1px solid $argo-color-gray-6; + background-color: $argo-color-gray-6; + + &--dark { + @include dark-background; + } + } + + &:hover > &__background, + &--selected > &__background { + background-color: $sherbert; + border-color: $sherbert; + transform: scale(1.02); + } + + &--dark:hover > &__background, + &--selected#{&}--dark > &__background { + background-color: $spray-tan; + border-color: $sherbert; + } + + &--disabled { + color: $argo-color-gray-4; + cursor: not-allowed; + } + + &--disabled:hover > &__background { + background-color: $argo-color-gray-6; + border-color: $argo-color-gray-6; + } + + &--disabled#{&}--dark { + color: $dull-shine; + &:hover { + color: $dull-shine; + } + } + + &--disabled#{&}--dark:hover > &__background { + border-color: $silver-lining; + background-color: $fog; + } +} diff --git a/ui/src/app/components/action-button/action-button.tsx b/ui/src/app/components/action-button/action-button.tsx new file mode 100644 index 0000000000..968751ae7f --- /dev/null +++ b/ui/src/app/components/action-button/action-button.tsx @@ -0,0 +1,89 @@ +import {faCheck, faCircleNotch, IconDefinition} from '@fortawesome/free-solid-svg-icons'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {Key, useKeyListener} from 'react-keyhooks'; +import * as React from 'react'; +import {useClickOutside} from '../../shared/utils/utils'; +import {EffectDiv} from '../effect-div/effect-div'; +import {Tooltip} from '../tooltip/tooltip'; + +import './action-button.scss'; + +export interface ActionButtonProps { + action?: Function; // What do you want this button to do when clicked? + label?: string; // The text shown in the button + icon?: IconDefinition; // Icon shown on left side of text, or centered if no text. Should be faSomething + indicateLoading?: boolean; // If set, button's icon (if exists) is briefly replaced with spinner after clicking + dark?: boolean; // If set, button is always dark + disabled?: boolean; // If set, button is, and appears, unclickable + short?: boolean; // If set, button only displays icon (no label) + style?: React.CSSProperties; // CSS styles + tooltip?: React.ReactNode; // If set, a tooltip is shown on hover with this content + shouldConfirm?: boolean; // If set, user must confirm action by clicking again, after clicking the first time +} + +export const ActionButton = (props: ActionButtonProps) => { + const {label, action, icon, indicateLoading, short, shouldConfirm} = props; + const [loading, setLoading] = React.useState(false); + const [confirmed, confirm] = React.useState(false); + const [displayLabel, setDisplayLabel] = React.useState(label); + const [displayIcon, setDisplayIcon] = React.useState(icon); + const ref = React.useRef(null); + + React.useEffect(() => { + setDisplayIcon(props.icon); + setDisplayLabel(props.label); + }, [props.icon, props.label]); + + const unconfirm = React.useCallback(() => { + if (props.shouldConfirm) { + setDisplayIcon(icon); + setDisplayLabel(label); + confirm(false); + } + }, [icon, label, props.shouldConfirm]); + useClickOutside(ref, unconfirm); + React.useEffect(() => { + const to = setTimeout(() => setLoading(false), 1000); + return () => clearInterval(to); + }, [loading]); + + const listen = useKeyListener(); + listen(Key.ESCAPE, () => { + unconfirm(); + return confirmed; + }); + const button = ( + { + if (props.disabled) { + e.preventDefault(); + return; + } + if (shouldConfirm) { + if (!confirmed) { + setDisplayLabel('SURE?'); + setDisplayIcon(faCheck); + confirm(true); + e.preventDefault(); + return; + } else { + confirm(false); + setDisplayLabel(props.label); + setDisplayIcon(props.icon); + } + } + if (action && (shouldConfirm ? confirmed : true)) { + action(); + setLoading(true); + e.preventDefault(); + } + }}> + {icon && } + {label && !short && {displayLabel}} + + ); + return props.tooltip ? {button} : button; +}; diff --git a/ui/src/app/components/autocomplete/autocomplete.scss b/ui/src/app/components/autocomplete/autocomplete.scss new file mode 100644 index 0000000000..c66fdb80be --- /dev/null +++ b/ui/src/app/components/autocomplete/autocomplete.scss @@ -0,0 +1,49 @@ +@import '../../shared/styles/colors.scss'; + +.autocomplete { + min-width: 0; + width: 100%; + position: relative; + box-sizing: border-box; + $autocompleteClass: &; + + &__items { + z-index: 3; + position: absolute; + white-space: nowrap; + max-height: 6em; + overflow-y: auto; + margin-top: 0.5em; + border-radius: 3px; + background-color: white; + border: 1px solid $argo-color-gray-4; + padding: 10px; + box-shadow: 1px 2px 2px rgba(0, 0, 0, 0.05); + + &__item { + z-index: 2; + padding: 0.75em 0; + padding-right: 30px; + padding-left: 5px; + cursor: pointer; + border-bottom: 1px solid $argo-color-gray-4; + box-sizing: border-box; + + &--selected { + border-bottom: 1px solid $sky; + box-shadow: 0px 1px 0px 0px $sky; + } + } + + &--dark { + background-color: $space; + border: 1px solid $silver-lining; + box-shadow: 1px 2px 3px 1px $space; + color: $shine; + + #{$autocompleteClass}__items__item { + border-bottom: 1px solid $silver-lining; + } + } + } +} diff --git a/ui/src/app/components/autocomplete/autocomplete.tsx b/ui/src/app/components/autocomplete/autocomplete.tsx new file mode 100644 index 0000000000..9cb7ca0494 --- /dev/null +++ b/ui/src/app/components/autocomplete/autocomplete.tsx @@ -0,0 +1,128 @@ +import {Key, useKeyListener, useNav} from 'react-keyhooks'; +import * as React from 'react'; +import {Input, useDebounce} from '../input/input'; +import ThemeDiv from '../theme-div/theme-div'; + +import './autocomplete.scss'; + +export const Autocomplete = ( + props: React.InputHTMLAttributes & { + items: string[]; + inputStyle?: React.CSSProperties; + onItemClick?: (item: string) => void; + inputref?: React.MutableRefObject; + } +) => { + const [value, setValue] = React.useState((props.value as string) || ''); + const [curItems, setCurItems] = React.useState(props.items || []); + const inputRef = React.useRef(null); + const autocompleteRef = React.useRef(null); + const [showSuggestions, setShowSuggestions] = React.useState(false); + const [pos, nav, reset] = useNav(props.items.length); + + React.useEffect(() => { + function unfocus(e: any) { + if (autocompleteRef.current && !autocompleteRef.current.contains(e.target)) { + setShowSuggestions(false); + } + } + + document.addEventListener('mousedown', unfocus); + return () => document.removeEventListener('mousedown', unfocus); + }, [autocompleteRef]); + + const debouncedVal = useDebounce(value, 350); + + React.useEffect(() => { + const filtered = (props.items || []).filter((i) => { + return i.includes(debouncedVal); + }); + setCurItems(filtered.length > 0 ? filtered : props.items); + }, [debouncedVal, props.items]); + + const listen = useKeyListener(); + listen(Key.TAB, (e) => { + if (showSuggestions) { + if (pos === curItems.length - 1) { + reset(); + } + nav(1); + return true; + } + return false; + }); + + listen(Key.ESCAPE, (e) => { + if (showSuggestions) { + reset(); + setShowSuggestions(false); + return true; + } + return false; + }); + + listen(Key.ENTER, () => { + if (showSuggestions && props.onItemClick) { + props.onItemClick(curItems[pos]); + return true; + } + return false; + }); + + listen(Key.UP, () => { + if (showSuggestions) { + nav(-1); + return false; + } + return true; + }); + + listen(Key.DOWN, () => { + if (showSuggestions) { + nav(1); + return false; + } + return true; + }); + + const style = props.style; + const trimmedProps = {...props}; + delete trimmedProps.style; + delete trimmedProps.inputStyle; + + return ( +
    + { + setValue(e.target.value); + if (props.onChange) { + props.onChange(e); + } + }} + onFocus={() => setShowSuggestions(true)} + /> + +
    + ); +}; diff --git a/ui/src/app/components/effect-div/effect-div.scss b/ui/src/app/components/effect-div/effect-div.scss new file mode 100644 index 0000000000..d662b97b8d --- /dev/null +++ b/ui/src/app/components/effect-div/effect-div.scss @@ -0,0 +1,19 @@ +@import '../../shared/styles/colors.scss'; + +.effect-div { + position: relative; + &__background { + width: 100%; + height: 100%; + position: absolute; + box-sizing: border-box; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-size: cover; + will-change: transform; + transition: transform 0.1s ease-out; + pointer-events: none; + } +} diff --git a/ui/src/app/components/effect-div/effect-div.tsx b/ui/src/app/components/effect-div/effect-div.tsx new file mode 100644 index 0000000000..78d9fbff47 --- /dev/null +++ b/ui/src/app/components/effect-div/effect-div.tsx @@ -0,0 +1,26 @@ +import * as React from 'react'; +import {appendSuffixToClasses} from '../../shared/utils/utils'; +import ThemeDiv from '../theme-div/theme-div'; + +import './effect-div.scss'; + +/* EffectDiv is a component that attaches a background a div, that can be animated with CSS transitions or otherwise. + * It was designed to avoid text artifacts when scaling a div; an EffectDiv allows you to easily scale JUST its background, and not its contents. + * + * You can drop in replace a div with an EffectDiv, but to add a background effect, you need to: + * - Remove background styles from the main div (including border and border-radius) + * - Add the styles you removed to the &__background element + * - Add transitions to the &__background element + */ + +export const EffectDiv = ( + props: {children?: React.ReactNode; innerref?: React.MutableRefObject} & React.DetailedHTMLProps, HTMLDivElement> +) => { + const backgroundCl = appendSuffixToClasses(props.className, '__background'); + return ( + + +
    {props.children}
    +
    + ); +}; diff --git a/ui/src/app/components/header/header.scss b/ui/src/app/components/header/header.scss new file mode 100644 index 0000000000..7cd9047f7f --- /dev/null +++ b/ui/src/app/components/header/header.scss @@ -0,0 +1,66 @@ +@import '../../shared/styles/colors.scss'; + +.rollouts-header { + display: flex; + background: $slate; + color: white; + align-items: center; + padding: 10px 0; + + &__brand { + color: $shine; + display: flex; + align-items: center; + text-decoration: none; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + } + + &__welcome { + position: absolute; + transform-origin: left; + display: block; + overflow: hidden; + width: 174px; + white-space: nowrap; + transition: transform 1s ease 1s, opacity 1s ease; + } + + &__title { + position: absolute; + transform: translateX(174px); + transition: transform 500ms ease 750ms; + display: flex; + align-items: center; + } + + h1 { + position: relative; + font-size: 22px; + font-weight: 400; + margin: 0; + display: flex; + align-items: center; + } + + h2 { + font-size: 18px; + color: $sherbert; + margin: 0; + margin-left: 10px; + flex-grow: 1; + white-space: nowrap; + } + + &__info { + margin-left: auto; + display: flex; + align-items: center; + } + &__version { + color: $shine; + margin: 0 15px; + } +} diff --git a/ui/src/app/components/header/header.tsx b/ui/src/app/components/header/header.tsx new file mode 100644 index 0000000000..a9d07a2d00 --- /dev/null +++ b/ui/src/app/components/header/header.tsx @@ -0,0 +1,60 @@ +import * as React from 'react'; +import {Link, useParams} from 'react-router-dom'; +import {RolloutNamespaceInfo, RolloutServiceApi} from '../../../models/rollout/generated'; +import {RolloutAPIContext} from '../../shared/context/api'; +import {useServerData} from '../../shared/utils/utils'; +import {InfoItemRow} from '../info-item/info-item'; +import {ThemeToggle} from '../theme-toggle/theme-toggle'; + +import './header.scss'; + +export const Logo = () => Argo Logo; + +const Brand = (props: {path?: string}) => { + const [loading, setLoading] = React.useState(true); + React.useEffect(() => { + setTimeout(() => setLoading(false), 500); + }, []); + + const showWelcome = loading && !props.path; + return ( + + +

    +
    + Welcome to Argo +
    +
    + Rollouts {props.path &&

    / {props.path}

    } +
    +

    + + ); +}; + +export const Header = () => { + const getNs = React.useCallback(() => new RolloutServiceApi().rolloutServiceGetNamespace(), []); + const nsData = useServerData(getNs); + const {name} = useParams<{name: string}>(); + const api = React.useContext(RolloutAPIContext); + const [version, setVersion] = React.useState('v?'); + React.useEffect(() => { + const getVersion = async () => { + const v = await api.rolloutServiceVersion(); + setVersion(v.rolloutsVersion); + }; + getVersion(); + }); + return ( +
    + +
    + + + + +
    {version}
    +
    +
    + ); +}; diff --git a/ui/src/app/components/info-item/info-item.scss b/ui/src/app/components/info-item/info-item.scss new file mode 100644 index 0000000000..cc46963145 --- /dev/null +++ b/ui/src/app/components/info-item/info-item.scss @@ -0,0 +1,54 @@ +@import '../../shared/styles/colors.scss'; + +.info-item { + background-color: $argo-color-gray-4; + border-radius: 3px; + border: 1px solid $argo-color-gray-5; + padding: 5px 7px; + margin-left: auto; + margin-right: 5px; + color: $argo-color-gray-8; + display: flex; + align-items: center; + + &--dark { + background-color: $fog; + border: 1px solid $silver-lining; + color: $dull-shine; + } + + &--colored { + background-color: $sherbert; + border: 1px solid $sherbert; + color: white; + } + + &--dark#{&}--colored { + background-color: $spray-tan; + border: 1px solid $sherbert; + color: white; + } + + &--canary { + background-color: $canary; + border: 1px solid $canary; + color: $space; + } + + &--bluegreen { + background-color: $sea; + border: 1px solid $sea; + color: white; + } + + &--row { + display: flex; + align-items: center; + margin: 0.5em 0; + flex-grow: 1; + label { + margin-right: auto; + padding-right: 5px; + } + } +} diff --git a/ui/src/app/components/info-item/info-item.tsx b/ui/src/app/components/info-item/info-item.tsx new file mode 100644 index 0000000000..6694f3e8ac --- /dev/null +++ b/ui/src/app/components/info-item/info-item.tsx @@ -0,0 +1,46 @@ +import {IconDefinition} from '@fortawesome/fontawesome-svg-core'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import * as React from 'react'; +import {ThemeDiv} from '../theme-div/theme-div'; +import './info-item.scss'; + +export enum InfoItemKind { + Default = 'default', + Colored = 'colored', + Canary = 'canary', + BlueGreen = 'bluegreen', +} + +export interface InfoItemProps { + content?: string; + icon?: IconDefinition; + style?: React.CSSProperties; + kind?: InfoItemKind; +} + +export const InfoItem = (props: InfoItemProps) => ( + + {props.icon && ( + + + + )} + {props.content} + +); + +export const InfoItemRow = (props: {label: string | React.ReactNode; items?: InfoItemProps | InfoItemProps[]}) => { + let {label, items} = props; + let itemComponents = null; + if (!Array.isArray(items)) { + items = [items]; + } + itemComponents = items.map((c, i) => ); + + return ( +
    + {props.label && } + {props.items &&
    {itemComponents}
    } +
    + ); +}; diff --git a/ui/src/app/components/input/input.scss b/ui/src/app/components/input/input.scss new file mode 100644 index 0000000000..0a5a8a6fc1 --- /dev/null +++ b/ui/src/app/components/input/input.scss @@ -0,0 +1,33 @@ +@import '../../shared/styles/colors.scss'; + +.input-container { + min-width: 0; + box-sizing: border-box; + .input { + box-sizing: border-box; + width: 100%; + appearance: none; + border-radius: 5px; + padding: 7px 10px; + background-color: $argo-color-gray-3; + border: 1px solid $argo-color-gray-5; + color: $argo-color-gray-7; + min-width: 0; + } + + input::placeholder { + color: $argo-color-gray-6; + } + + &--dark { + .input { + background-color: $space; + border: 1px solid $silver-lining; + color: $shine; + } + + input::placeholder { + color: $dull-shine; + } + } +} diff --git a/ui/src/app/components/input/input.tsx b/ui/src/app/components/input/input.tsx new file mode 100644 index 0000000000..e0b07f93cf --- /dev/null +++ b/ui/src/app/components/input/input.tsx @@ -0,0 +1,54 @@ +import * as React from 'react'; +import {ThemeDiv} from '../theme-div/theme-div'; + +import './input.scss'; + +interface InputProps { + value: string; + ref: React.MutableRefObject; + onChange: (e: React.ChangeEvent) => void; +} + +type SetInputFxn = (val: string) => void; +export const FormResetFactory = (setFxns: SetInputFxn[]) => { + return () => { + setFxns.forEach((reset) => reset('')); + }; +}; + +export const useInput = (init: string, callback?: (val: string) => void): [string, SetInputFxn, InputProps] => { + const [state, setState] = React.useState(init); + const inputRef = React.useRef(null); + + const Input: InputProps = { + value: state, + ref: inputRef, + onChange: (e: React.ChangeEvent) => { + setState(e.target.value); + if (callback) { + callback(e.target.value); + } + }, + }; + + return [state, setState, Input]; +}; + +export const useDebounce = (value: string, debouncems: number): string => { + const [val, setVal] = React.useState(value); + + React.useEffect(() => { + const to = setTimeout(() => { + setVal(value); + }, debouncems); + return () => clearInterval(to); + }, [value, debouncems]); + + return val; +}; + +export const Input = (props: React.InputHTMLAttributes & {innerref?: React.MutableRefObject}) => ( + + + +); diff --git a/ui/src/app/components/menu/menu.scss b/ui/src/app/components/menu/menu.scss new file mode 100644 index 0000000000..ade7c63048 --- /dev/null +++ b/ui/src/app/components/menu/menu.scss @@ -0,0 +1,31 @@ +@import '../../shared/styles/colors.scss'; + +.menu { + position: absolute; + padding: 5px 10px; + border-radius: 3px; + top: 100%; + z-index: 2; + background-color: white; + color: $argo-color-gray-7; + border: 1px solid $argo-color-gray-4; + box-shadow: 1px 2px 2px rgba(0, 0, 0, 0.05); + width: 150px; + + &__item { + width: 100%; + padding: 0.5em 0; + cursor: pointer; + + &__label { + display: inline-block; + margin-left: 10px; + } + } + + &--dark { + border: 1px solid $silver-lining; + background-color: $slate; + color: white; + } +} diff --git a/ui/src/app/components/menu/menu.tsx b/ui/src/app/components/menu/menu.tsx new file mode 100644 index 0000000000..f149f544e8 --- /dev/null +++ b/ui/src/app/components/menu/menu.tsx @@ -0,0 +1,45 @@ +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import * as React from 'react'; +import {ActionButtonProps} from '../action-button/action-button'; +import {ThemeDiv} from '../theme-div/theme-div'; + +import './menu.scss'; + +export const Menu = (props: {children: React.ReactNode; items: ActionButtonProps[]}) => { + const [menuVisible, setMenuVisible] = React.useState(false); + const ref = React.useRef(null); + + const clickHandler = (e: any) => { + if (ref.current && !ref.current.contains(e.target)) { + setMenuVisible(false); + } + }; + + React.useEffect(() => { + document.addEventListener('click', clickHandler); + return () => { + document.removeEventListener('click', clickHandler); + }; + }); + return ( +
    + +
    setMenuVisible(true)}> + {props.children} +
    +
    + ); +}; diff --git a/ui/src/app/components/pods/pods.scss b/ui/src/app/components/pods/pods.scss new file mode 100644 index 0000000000..301a66a3fd --- /dev/null +++ b/ui/src/app/components/pods/pods.scss @@ -0,0 +1,104 @@ +@import '../../shared/styles/colors.scss'; + +$POD_SIZE: 30px; + +.pods { + &__header { + font-size: 16px; + font-weight: 500; + display: flex; + align-items: center; + &__tags { + margin-left: auto; + display: flex; + } + } + &__container { + margin-top: 10px; + // border: 1px solid $argo-color-gray-5; + display: flex; + align-items: center; + border-radius: 3px; + background-color: $argo-color-gray-3; + padding: 7px; + flex-wrap: wrap; + + .pod-icon { + margin: 3px; + } + &--dark { + border-color: $silver-lining; + background-color: $space; + } + } +} + +.pod-icon { + width: $POD_SIZE; + height: $POD_SIZE; + line-height: $POD_SIZE; + font-size: 18px; + text-align: center; + border: 1px solid $silver-lining; + background-color: $fog; + color: $shine; + border-radius: 3px; + cursor: pointer; + + &--success { + background-color: $argo-success-color; + color: white; + border: 1px solid $argo-success-color; + &:hover { + background-color: $argo-success-color-dark; + border-color: $argo-success-color-dark; + } + } + + &--dark#{&}--success { + background-color: $forest; + color: $lime; + border: 1px solid $leaf; + &:hover { + border-color: $lime; + } + } + + &--failure { + background-color: $clay; + color: white; + border: 1px solid $clay; + &:hover { + border-color: $coral; + background-color: $coral; + } + } + + &--dark#{&}--failure { + background-color: $dirt; + color: $coral; + border: 1px solid $clay; + &:hover { + border-color: $coral; + } + } + + &--pending { + background-color: $sky; + color: white; + border: 1px solid $sky; + &:hover { + border-color: $sea; + background-color: $sea; + } + } + + &--dark#{&}--pending { + background-color: $deep-sea; + color: $sky; + border: 1px solid $sea; + &:hover { + border-color: $sky; + } + } +} diff --git a/ui/src/app/components/pods/pods.tsx b/ui/src/app/components/pods/pods.tsx new file mode 100644 index 0000000000..d3242c7230 --- /dev/null +++ b/ui/src/app/components/pods/pods.tsx @@ -0,0 +1,145 @@ +import {faQuestionCircle} from '@fortawesome/free-regular-svg-icons'; +import {faCheck, faCircleNotch, faClipboard, faExclamationTriangle, faTimes} from '@fortawesome/free-solid-svg-icons'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import * as React from 'react'; +import {RolloutReplicaSetInfo} from '../../../models/rollout/generated'; +import {Pod} from '../../../models/rollout/rollout'; +import {Menu} from '../menu/menu'; +import {ReplicaSetStatus, ReplicaSetStatusIcon} from '../status-icon/status-icon'; +import {ThemeDiv} from '../theme-div/theme-div'; +import {Tooltip} from '../tooltip/tooltip'; +import {WaitFor} from '../wait-for/wait-for'; + +import './pods.scss'; + +export enum PodStatus { + Pending = 'pending', + Success = 'success', + Failed = 'failure', + Warning = 'warning', + Unknown = 'unknown', +} + +export const ParsePodStatus = (status: string): PodStatus => { + switch (status) { + case 'Pending': + case 'Terminating': + case 'ContainerCreating': + return PodStatus.Pending; + case 'Running': + case 'Completed': + return PodStatus.Success; + case 'Failed': + case 'InvalidImageName': + case 'CrashLoopBackOff': + return PodStatus.Failed; + case 'ImagePullBackOff': + case 'RegistryUnavailable': + return PodStatus.Warning; + default: + return PodStatus.Unknown; + } +}; + +export const PodIcon = (props: {status: string}) => { + const {status} = props; + let icon; + let spin = false; + if (status.startsWith('Init:')) { + icon = faCircleNotch; + spin = true; + } + if (status.startsWith('Signal:') || status.startsWith('ExitCode:')) { + icon = faTimes; + } + if (status.endsWith('Error') || status.startsWith('Err')) { + icon = faExclamationTriangle; + } + + const className = ParsePodStatus(status); + + switch (className) { + case PodStatus.Pending: + icon = faCircleNotch; + spin = true; + break; + case PodStatus.Success: + icon = faCheck; + break; + case PodStatus.Failed: + icon = faTimes; + break; + case PodStatus.Warning: + icon = faExclamationTriangle; + break; + default: + spin = false; + icon = faQuestionCircle; + break; + } + + return ( + + + + ); +}; + +export const ReplicaSets = (props: {replicaSets: RolloutReplicaSetInfo[]; showRevisions?: boolean}) => { + const {replicaSets} = props; + if (!replicaSets || replicaSets.length < 1) { + return
    No replica sets!
    ; + } + + return ( +
    + {replicaSets?.map( + (rsInfo) => + rsInfo.pods && + rsInfo.pods.length > 0 && ( +
    + +
    + ) + )} +
    + ); +}; + +export const ReplicaSet = (props: {rs: RolloutReplicaSetInfo; showRevision?: boolean}) => { + const rsName = props.rs.objectMeta.name; + return ( + + {rsName && ( + + {rsName} + {props.showRevision &&
    Revision {props.rs.revision}
    } +
    + )} + + {props.rs.pods && props.rs.pods.length > 0 && ( + + + {props.rs.pods.map((pod, i) => ( + + ))} + + + )} +
    + ); +}; + +export const PodWidget = (props: {pod: Pod}) => ( + navigator.clipboard.writeText(props.pod.objectMeta?.name), icon: faClipboard}]}> + +
    Status: {props.pod.status}
    +
    {props.pod.objectMeta?.name}
    + + }> + +
    +
    +); diff --git a/ui/src/app/components/rollout-actions/rollout-actions.tsx b/ui/src/app/components/rollout-actions/rollout-actions.tsx new file mode 100644 index 0000000000..67249aea54 --- /dev/null +++ b/ui/src/app/components/rollout-actions/rollout-actions.tsx @@ -0,0 +1,87 @@ +import {faArrowCircleUp, faExclamationCircle, faRedoAlt, faSync} from '@fortawesome/free-solid-svg-icons'; +import * as React from 'react'; +import {RolloutInfo} from '../../../models/rollout/rollout'; +import {NamespaceContext, RolloutAPIContext} from '../../shared/context/api'; +import {formatTimestamp} from '../../shared/utils/utils'; +import {ActionButton, ActionButtonProps} from '../action-button/action-button'; +import {RolloutStatus} from '../status-icon/status-icon'; + +export enum RolloutAction { + Restart = 'Restart', + Retry = 'Retry', + Abort = 'Abort', + PromoteFull = 'PromoteFull', +} + +export const RolloutActionButton = (props: {action: RolloutAction; rollout: RolloutInfo; callback?: Function; indicateLoading: boolean; disabled?: boolean}) => { + const api = React.useContext(RolloutAPIContext); + const namespace = React.useContext(NamespaceContext); + + const restartedAt = formatTimestamp(props.rollout.restartedAt || ''); + + const actionMap = new Map([ + [ + RolloutAction.Restart, + { + label: 'RESTART', + icon: faSync, + action: api.rolloutServiceRestartRollout, + tooltip: restartedAt === 'Never' ? 'Never restarted' : `Last restarted ${restartedAt}`, + shouldConfirm: true, + }, + ], + [ + RolloutAction.Retry, + { + label: 'RETRY', + icon: faRedoAlt, + action: api.rolloutServiceRetryRollout, + shouldConfirm: true, + }, + ], + [ + RolloutAction.Abort, + { + label: 'ABORT', + icon: faExclamationCircle, + action: api.rolloutServiceAbortRollout, + shouldConfirm: true, + }, + ], + [ + RolloutAction.PromoteFull, + { + label: 'PROMOTE-FULL', + icon: faArrowCircleUp, + action: api.rolloutServicePromoteRollout, + disabled: props.rollout.status !== RolloutStatus.Paused, + shouldConfirm: true, + }, + ], + ]); + + const ap = actionMap.get(props.action); + + return ( + { + ap.action({}, namespace, props.rollout.objectMeta?.name || ''); + if (props.callback) { + props.callback(); + } + }} + indicateLoading={props.indicateLoading} + /> + ); +}; + +export const RolloutActions = (props: {rollout: RolloutInfo}) => ( +
    + {Object.values(RolloutAction).map((action) => ( + + ))} +
    +); + +export default RolloutActions; diff --git a/ui/src/app/components/rollout/rollout.scss b/ui/src/app/components/rollout/rollout.scss new file mode 100644 index 0000000000..afb5fc67db --- /dev/null +++ b/ui/src/app/components/rollout/rollout.scss @@ -0,0 +1,283 @@ +@import '../../shared/styles/colors.scss'; + +.revision { + padding: 15px; + margin-bottom: 1em; + background: none; + + &__background { + background: $argo-color-gray-2; + border: 1px solid $argo-color-gray-4; + border-radius: 5px; + } + + &--dark > &__background { + border: none; + background: $slate; + } + + &:hover > &__background { + transform: scale(1.02); + box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.1); + } + + &__header { + display: flex; + align-items: center; + margin-bottom: 1em; + font-size: 18px; + font-weight: 500; + &__button { + cursor: pointer; + &:hover { + color: $sea; + } + &--dark:hover { + color: $sky; + } + } + } +} + +.steps { + width: 250px; + flex-shrink: 0; + max-height: 500px; + overflow-y: auto; + + &__step { + padding: 15px 18px; + + &__background { + border-radius: 10px; + border: 1px solid $argo-color-gray-4; + &--dark { + border: 1px solid $silver-lining; + } + } + + &:hover > &__background { + border: 1px solid $sherbert; + } + + &--complete > &__background { + border: 2px solid $argo-success-color; + } + + &--complete:hover > &__background { + border: 2px solid $argo-success-color; + } + + &--current > &__background { + border: 2px solid $sherbert; + } + + &--current:hover > &__background { + border: 2px solid $sherbert; + } + + &:hover > &__background { + transform: scale(1.02); + } + } + + &__connector { + height: 1em; + width: 2px; + background-color: $argo-color-gray-4; + margin: 0 auto; + &--dark { + background-color: $silver-lining; + } + } +} + +.image { + &--red { + color: $clay; + } + &--blue { + color: $sea; + } + &--orange { + color: $spray-tan; + } + + &--red#{&}--dark { + color: $coral; + } + &--blue#{&}--dark { + color: $sky; + } + &--orange#{&}--dark { + color: $sherbert; + } +} + +.info { + border: 1px solid $argo-color-gray-4; + border-radius: 5px; + padding: 20px; + background-color: white; + height: max-content; + box-sizing: border-box; + + &__section { + margin-bottom: 0.5em; + padding-bottom: 0.5em; + border-bottom: 1px solid $argo-color-gray-4; + + &--dark { + border-bottom: 1px solid $silver-lining; + } + } + + &__title { + font-size: 18px; + font-weight: 600; + margin-bottom: 0.5em; + } + + &--dark { + background-color: $space; + border-color: $silver-lining; + } +} + +.analysis { + padding-top: 1em; + border-top: 1px solid $argo-color-gray-4; + &__runs { + margin-top: 1em; + display: flex; + } + &--dark { + border-top: 1px solid $silver-lining; + } + &__run { + width: 40px; + margin-right: 5px; + height: 10px; + border-radius: 3px; + background-color: $argo-color-gray-4; + &--successful { + background-color: $argo-success-color; + } + + &--failed { + background-color: $coral; + } + + &--running { + background-color: $sky; + } + } +} + +.containers { + &__few { + box-sizing: border-box; + font-size: 18px; + text-align: center; + color: $argo-color-gray-5; + margin-top: 2em; + i { + margin-right: 5px; + } + &--dark { + color: $dull-shine; + } + } +} + +.rollout { + padding-bottom: 5em; + &__row { + display: flex; + width: 100%; + margin-bottom: 1.5em; + justify-content: center; + + .info { + height: auto; + } + + &--bottom { + .info { + height: max-content; + } + } + } + + &__info { + width: 400px; + margin-right: 15px; + + &:last-child { + margin-right: 0; + } + } + + &__header { + color: $argo-color-gray-8; + font-size: 22px; + margin-left: 12px; + margin-right: auto; + flex-shrink: 0; + height: 2em; + display: flex; + align-items: center; + &--dark { + color: $shine; + } + } + &__toolbar { + box-sizing: border-box; + font-size: 14px; + display: flex; + align-items: center; + padding: 0 10px; + padding-bottom: 1em; + margin-bottom: 1.5em; + border-bottom: 1px solid $argo-color-gray-4; + background-color: white; + padding-top: 1em; + flex-wrap: wrap; + &--dark { + background-color: $space; + border-bottom: 1px solid $silver-lining; + } + + &__actions { + @media screen and (max-width: 750px) { + width: 100%; + margin-top: 1em; + margin-left: 7px; + } + } + } + + &__revisions { + width: 550px; + } + + &__body { + padding: 0 20px; + color: $argo-color-gray-8; + display: flex; + flex-wrap: wrap; + h3 { + margin-bottom: 0px; + font-size: 12px; + font-weight: 500; + color: $argo-color-gray-6; + } + + &--dark { + color: $shine; + h3 { + color: $dull-shine; + } + } + } +} diff --git a/ui/src/app/components/rollout/rollout.tsx b/ui/src/app/components/rollout/rollout.tsx new file mode 100644 index 0000000000..c3ba91772a --- /dev/null +++ b/ui/src/app/components/rollout/rollout.tsx @@ -0,0 +1,499 @@ +import * as React from 'react'; +import {useHistory, useParams} from 'react-router-dom'; +import {Helmet} from 'react-helmet'; + +import './rollout.scss'; +import {RolloutStatus, StatusIcon} from '../status-icon/status-icon'; +import {ThemeDiv} from '../theme-div/theme-div'; +import {useWatchRollout} from '../../shared/services/rollout'; +import {InfoItem, InfoItemKind, InfoItemProps, InfoItemRow} from '../info-item/info-item'; +import {RolloutInfo} from '../../../models/rollout/rollout'; +import { + faBalanceScale, + faBalanceScaleRight, + faBoxes, + faChevronCircleDown, + faChevronCircleUp, + faDove, + faExclamationCircle, + faFlask, + faPalette, + faPauseCircle, + faPencilAlt, + faSave, + faShoePrints, + faTimes, + faUndoAlt, + faWeight, + IconDefinition, +} from '@fortawesome/free-solid-svg-icons'; +import {ReplicaSets} from '../pods/pods'; +import {formatTimestamp, IconForTag, ImageTag} from '../../shared/utils/utils'; +import {NamespaceContext, RolloutAPIContext} from '../../shared/context/api'; +import {useInput} from '../input/input'; +import {ActionButton} from '../action-button/action-button'; +import {Spinner, WaitFor} from '../wait-for/wait-for'; +import { + RolloutAnalysisRunInfo, + GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep, + RolloutContainerInfo, + RolloutExperimentInfo, + RolloutReplicaSetInfo, +} from '../../../models/rollout/generated'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {Autocomplete} from '../autocomplete/autocomplete'; +import {faChartBar} from '@fortawesome/free-regular-svg-icons'; +import {EffectDiv} from '../effect-div/effect-div'; +import {Tooltip} from '../tooltip/tooltip'; +import {Key, useKeyListener} from 'react-keyhooks'; +const RolloutActions = React.lazy(() => import('../rollout-actions/rollout-actions')); +interface ImageInfo { + image: string; + tags: ImageTag[]; + color?: ImageColor; +} + +enum ImageColor { + Red = 'red', + Blue = 'blue', + Green = 'green', + Orange = 'orange', + Purple = 'purple', +} + +enum Strategy { + Canary = 'Canary', + BlueGreen = 'BlueGreen', +} + +const parseImages = (replicaSets: RolloutReplicaSetInfo[]): ImageInfo[] => { + const images: {[key: string]: ImageInfo} = {}; + const unknownImages: {[key: string]: boolean} = {}; + (replicaSets || []).forEach((rs) => { + (rs.images || []).forEach((img) => { + const tags: ImageTag[] = []; + + if (rs.canary) { + tags.push(ImageTag.Canary); + } + if (rs.stable) { + tags.push(ImageTag.Stable); + } + if (rs.active) { + tags.push(ImageTag.Active); + } + if (rs.preview) { + tags.push(ImageTag.Preview); + } + + if (images[img]) { + images[img].tags = [...tags, ...images[img].tags]; + } else { + images[img] = { + image: img, + tags: tags, + }; + } + + if (images[img].tags.length === 0) { + unknownImages[img] = true; + } else { + unknownImages[img] = false; + } + }); + }); + + const imgArray = Object.values(images); + imgArray.sort((a, b) => { + return unknownImages[a.image] ? 1 : -1; + }); + return imgArray; +}; + +export const Rollout = () => { + const {name} = useParams<{name: string}>(); + + const [rollout, loading] = useWatchRollout(name, true); + const api = React.useContext(RolloutAPIContext); + const namespace = React.useContext(NamespaceContext); + const images = parseImages(rollout.replicaSets || []); + + for (const img of images) { + for (const container of rollout.containers) { + if (img.image === container.image) { + img.color = ImageColor.Blue; + } + } + } + const curStep = parseInt(rollout.step, 10) || (rollout.steps || []).length; + const revisions = ProcessRevisions(rollout); + + const useKeyPress = useKeyListener(); + const [editing, setEditing] = React.useState(false); + const history = useHistory(); + + useKeyPress(Key.L, () => { + if (editing) { + return false; + } + history.push('/rollouts'); + return true; + }); + + return ( +
    + + {name} / Argo Rollouts + + + +
    {name}
    +
    +
    + }> + + +
    +
    + + + +
    + +
    Summary
    + + + + {rollout.strategy === Strategy.Canary && ( + + + + {' '} + + )} + +
    + + { + api.rolloutServiceSetRolloutImage({}, namespace, name, container, image, tag); + }} + editing={editing} + setEditing={setEditing} + /> + +
    + +
    + {rollout.replicaSets && rollout.replicaSets.length > 0 && ( + +
    Revisions
    +
    + {revisions.map((r, i) => ( + api.rolloutServiceUndoRollout({}, namespace, name, `${r}`)} + current={i === 0} + /> + ))} +
    +
    + )} + {(rollout.strategy || '').toLowerCase() === 'canary' && rollout.steps && rollout.steps.length > 0 && ( + + Steps +
    + {rollout.steps.map((step, i) => ( + + ))} +
    +
    + )} +
    +
    +
    +
    + ); +}; + +const iconForStrategy = (s: Strategy) => { + switch (s) { + case Strategy.Canary: + return faDove; + case Strategy.BlueGreen: + return faPalette; + } +}; + +const ImageItems = (props: {images: ImageInfo[]}) => { + return ( +
    + {props.images.map((img) => { + let imageItems = img.tags.map((t) => { + return {content: t, icon: IconForTag(t)} as InfoItemProps; + }); + if (imageItems.length === 0) { + imageItems = null; + } + return {img.image}} items={imageItems} />; + })} +
    + ); +}; + +interface Revision { + number: number; + replicaSets: RolloutReplicaSetInfo[]; + experiments: RolloutExperimentInfo[]; + analysisRuns: RolloutAnalysisRunInfo[]; +} + +const ProcessRevisions = (ri: RolloutInfo): Revision[] => { + if (!ri) { + return; + } + const map: {[key: number]: Revision} = {}; + + const emptyRevision = {replicaSets: [], experiments: [], analysisRuns: []} as Revision; + + for (const rs of ri.replicaSets || []) { + if (!map[rs.revision]) { + map[rs.revision] = {...emptyRevision}; + } + map[rs.revision].number = rs.revision; + map[rs.revision].replicaSets = [...map[rs.revision].replicaSets, rs]; + } + + for (const ar of ri.analysisRuns || []) { + if (!map[ar.revision]) { + map[ar.revision] = {...emptyRevision}; + } + map[ar.revision].number = ar.revision; + map[ar.revision].analysisRuns = [...map[ar.revision].analysisRuns, ar]; + } + + const revisions: Revision[] = []; + const prevRn = 0; + Object.keys(map).forEach((key) => { + const rn = parseInt(key); + if (rn > prevRn) { + revisions.unshift(map[rn]); + } else { + revisions.push(map[rn]); + } + }); + + return revisions; +}; + +const RevisionWidget = (props: {revision: Revision; initCollapsed?: boolean; rollback: (revision: number) => void; current: boolean}) => { + const {revision, initCollapsed} = props; + const [collapsed, setCollapsed] = React.useState(initCollapsed); + const icon = collapsed ? faChevronCircleDown : faChevronCircleUp; + const images = parseImages(revision.replicaSets); + return ( + + + Revision {revision.number} +
    + {!props.current && ( + props.rollback(revision.number)} label='ROLLBACK' icon={faUndoAlt} style={{fontSize: '13px'}} indicateLoading shouldConfirm /> + )} + setCollapsed(!collapsed)}> + + +
    +
    + + + + + {!collapsed && ( + + + {(revision.analysisRuns || []).length > 0 && ( + +
    + +
    +
    + )} +
    + )} +
    + ); +}; + +const AnalysisRunWidget = (props: {analysisRuns: RolloutAnalysisRunInfo[]}) => { + const {analysisRuns} = props; + return ( + +
    Analysis Runs
    +
    + {analysisRuns.map((ar) => ( + +
    {ar.objectMeta.name}
    +
    Created at {formatTimestamp(JSON.stringify(ar.objectMeta.creationTimestamp))}
    + + }> + +
    + ))} +
    +
    + ); +}; + +const ContainersWidget = (props: { + containers: RolloutContainerInfo[]; + images: ImageInfo[]; + setImage: (container: string, image: string, tag: string) => void; + editing: boolean; + setEditing: (e: boolean) => void; +}) => { + const {containers, images, setImage, editing, setEditing} = props; + const inputMap: {[key: string]: string} = {}; + for (const container of containers) { + inputMap[container.name] = ''; + } + const [inputs, setInputs] = React.useState(inputMap); + const [error, setError] = React.useState(false); + + return ( + +
    + + Containers + + + {editing ? ( +
    + { + setEditing(false); + setError(false); + }} + /> + { + for (const container of Object.keys(inputs)) { + const split = inputs[container].split(':'); + if (split.length > 1) { + const image = split[0]; + const tag = split[1]; + setImage(container, image, tag); + setTimeout(() => { + setEditing(false); + }, 350); + } else { + setError(true); + } + } + }} + shouldConfirm + indicateLoading={!error} + /> +
    + ) : ( + setEditing(true)} style={{cursor: 'pointer', marginLeft: 'auto'}} /> + )} +
    + {containers.map((c, i) => ( + { + const update = {...inputs}; + update[c.name] = img; + setInputs(update); + }} + /> + ))} + {containers.length < 2 && ( + + + + + Add more containers to fill this space! + + )} +
    + ); +}; + +const ContainerWidget = (props: {container: RolloutContainerInfo; images: ImageInfo[]; setInput: (image: string) => void; editing: boolean}) => { + const {container, editing} = props; + const [, , newImageInput] = useInput(container.image, (val) => props.setInput(val)); + + return ( +
    +
    {container.name}
    +
    + {!editing ? : img.image)} placeholder='New Image' {...newImageInput} />} +
    +
    + ); +}; + +const parseDuration = (duration: string): string => { + const lastChar = duration[duration.length - 1]; + if (lastChar === 's' || lastChar === 'm' || lastChar === 'h') { + return `${duration}`; + } + return `${duration}s`; +}; + +const Step = (props: {step: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep; complete?: boolean; current?: boolean; last?: boolean}) => { + let icon: IconDefinition; + let content = ''; + let unit = ''; + if (props.step.setWeight) { + icon = faWeight; + content = `Set Weight: ${props.step.setWeight}`; + unit = '%'; + } + if (props.step.pause) { + icon = faPauseCircle; + if (props.step.pause.duration) { + content = `Pause: ${parseDuration(`${props.step.pause.duration}`)}`; + } else { + content = 'Pause'; + } + } + if (props.step.analysis) { + content = 'Analysis'; + icon = faChartBar; + } + if (props.step.setCanaryScale) { + content = 'Canary Scale'; + } + if (props.step.experiment) { + content = 'Experiment'; + icon = faFlask; + } + + return ( + + + {content} + {unit} + + {!props.last && } + + ); +}; diff --git a/ui/src/app/components/rollouts-list/rollouts-list.scss b/ui/src/app/components/rollouts-list/rollouts-list.scss new file mode 100644 index 0000000000..8a70e2f7e0 --- /dev/null +++ b/ui/src/app/components/rollouts-list/rollouts-list.scss @@ -0,0 +1,139 @@ +@import '../../shared/styles/colors.scss'; + +$WIDGET_WIDTH: 400px; + +$widgetPadding: 17px; +$widgetMarginRight: 20px; +$colWidth: ($WIDGET_WIDTH + (2 * $widgetPadding)) + $widgetMarginRight; + +.rollouts-list { + display: flex; + box-sizing: border-box; + flex-wrap: wrap; + + &__search-container { + width: 60% !important; + margin: 0 auto; + } + + &__rollouts-container { + padding: 20px; + display: flex; + flex-wrap: wrap; + + width: 3 * $colWidth; + margin: 0 auto; + + @media screen and (max-width: 3 * $colWidth) { + width: 2 * $colWidth; + margin: 0 auto; + } + + @media screen and (max-width: 2 * $colWidth) { + width: $colWidth; + + .rollouts-list__widget { + margin: 0 inherit; + width: 100%; + } + + .rollouts-list__search-container { + width: 100% !important; + } + } + } + + &__toolbar { + width: 100%; + padding-top: 1.5em; + background-color: white; + } + + &__widget { + position: relative; + box-sizing: border-box; + padding: 17px; + font-size: 14px; + margin: 0 10px; + color: $argo-color-gray-7; + width: $WIDGET_WIDTH; + height: max-content; + flex-shrink: 0; + margin-bottom: 1.5em; + border-radius: 5px; + + &__pods { + margin-bottom: 1em; + } + + &__background { + background-color: white; + box-shadow: 1px 2px 2px rgba(0, 0, 0, 0.05); + border: 1px solid $argo-color-gray-4; + + border-radius: 5px; + &--dark { + border-color: $silver-lining; + box-shadow: 1px 2px 3px 1px $space; + background: none; + } + } + + &:hover > &__background, + &--selected > &__background { + transform: scale(1.01); + border-color: $sherbert; + } + + &--dark:hover > &__background, + &--dark#{&}--selected > &__background { + border-color: $spray-tan; + } + + &--dark { + color: $dull-shine; + } + + &__container { + position: relative; + display: block; + z-index: 2; + } + + &__refresh { + &:hover { + color: $sherbert; + } + } + + &__body { + margin-bottom: 1em; + padding-bottom: 0.75em; + border-bottom: 1px solid $argo-color-gray-4; + &--dark { + border-bottom: 1px solid $silver-lining; + } + } + + header { + color: $argo-color-gray-8; + display: flex; + align-items: center; + font-weight: 500; + font-size: 18px; + border-bottom: 1px solid $argo-color-gray-4; + padding-bottom: 1em; + margin-bottom: 1em; + } + + &--dark header { + color: $shine; + border-bottom: 1px solid $silver-lining; + } + &__actions { + display: flex; + align-items: center; + margin-top: 1.5em; + } + } +} diff --git a/ui/src/app/components/rollouts-list/rollouts-list.tsx b/ui/src/app/components/rollouts-list/rollouts-list.tsx new file mode 100644 index 0000000000..7d6176fbb7 --- /dev/null +++ b/ui/src/app/components/rollouts-list/rollouts-list.tsx @@ -0,0 +1,190 @@ +import {faCircleNotch, faDove, faPalette, faRedoAlt, faWeight} from '@fortawesome/free-solid-svg-icons'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import * as React from 'react'; +import {Link, useHistory} from 'react-router-dom'; +import {RolloutInfo} from '../../../models/rollout/rollout'; +import {useWatchRollout, useWatchRollouts} from '../../shared/services/rollout'; +import {InfoItemKind, InfoItemRow} from '../info-item/info-item'; +import {RolloutStatus, StatusIcon} from '../status-icon/status-icon'; +import {Spinner, WaitFor} from '../wait-for/wait-for'; +import {Key, useKeyListener, useNav} from 'react-keyhooks'; +import './rollouts-list.scss'; +import {ThemeDiv} from '../theme-div/theme-div'; +import {RolloutAction, RolloutActionButton} from '../rollout-actions/rollout-actions'; +import {ParsePodStatus, PodStatus, ReplicaSets} from '../pods/pods'; +import {EffectDiv} from '../effect-div/effect-div'; +import {Autocomplete} from '../autocomplete/autocomplete'; +import {useInput} from '../input/input'; +import {useClickOutside} from '../../shared/utils/utils'; + +const useRolloutNames = (rollouts: RolloutInfo[]) => { + const parseNames = (rl: RolloutInfo[]) => (rl || []).map((r) => r.objectMeta?.name || ''); + + const [rolloutNames, setRolloutNames] = React.useState(parseNames(rollouts)); + React.useEffect(() => { + setRolloutNames(parseNames(rollouts)); + }, [rollouts]); + + return rolloutNames; +}; + +export const RolloutsList = () => { + const rolloutsList = useWatchRollouts(); + const rollouts = rolloutsList.items; + const loading = rolloutsList.loading; + const [filteredRollouts, setFilteredRollouts] = React.useState(rollouts); + const [pos, nav, reset] = useNav(filteredRollouts.length); + const [searchString, setSearchString, searchInput] = useInput(''); + + const useKeyPress = useKeyListener(); + + useKeyPress(Key.RIGHT, () => nav(1)); + useKeyPress(Key.LEFT, () => nav(-1)); + useKeyPress(Key.ESCAPE, () => { + reset(); + setSearchString(''); + return true; + }); + + const rolloutNames = useRolloutNames(rollouts); + const history = useHistory(); + + useKeyPress(Key.SLASH, () => { + if (!searchString) { + if (searchInput.ref.current) { + searchInput.ref.current.focus(); + } + return true; + } + return false; + }); + + useKeyPress(Key.ENTER, () => { + if (pos > -1) { + history.push(`/rollout/${filteredRollouts[pos].objectMeta?.name}`); + return true; + } + return false; + }); + + React.useEffect(() => { + const filtered = (rollouts || []).filter((r) => (r.objectMeta?.name || '').includes(searchString)); + if ((filtered || []).length > 0) { + setFilteredRollouts(filtered); + } + }, [searchString, rollouts]); + + return ( +
    + +
    +
    + history.push(`/rollout/${item}`)} + inputref={searchInput.ref} + {...searchInput} + /> +
    +
    +
    + {(filteredRollouts.sort((a, b) => (a.objectMeta.name < b.objectMeta.name ? -1 : 1)) || []).map((rollout, i) => ( + reset()} /> + ))} +
    +
    +
    + ); +}; + +export const isInProgress = (rollout: RolloutInfo): boolean => { + for (const rs of rollout.replicaSets || []) { + for (const p of rs.pods || []) { + const status = ParsePodStatus(p.status); + if (status === PodStatus.Pending) { + return true; + } + } + } + return false; +}; + +export const RolloutWidget = (props: {rollout: RolloutInfo; deselect: () => void; selected?: boolean}) => { + const [watching, subscribe] = React.useState(false); + let rollout = props.rollout; + useWatchRollout(props.rollout?.objectMeta?.name, watching, null, (r: RolloutInfo) => (rollout = r)); + const ref = React.useRef(null); + useClickOutside(ref, props.deselect); + + React.useEffect(() => { + if (watching) { + const to = setTimeout(() => { + if (!isInProgress(rollout)) { + subscribe(false); + } + }, 5000); + return () => clearTimeout(to); + } + }, [watching, rollout]); + + return ( + + + { + subscribe(true); + setTimeout(() => { + subscribe(false); + }, 1000); + }} + /> + + + {(rollout.strategy || '').toLocaleLowerCase() === 'canary' && } + + }> + + +
    + subscribe(true)} indicateLoading /> + subscribe(true)} indicateLoading /> +
    + +
    + ); +}; + +const WidgetHeader = (props: {rollout: RolloutInfo; refresh: () => void}) => { + const {rollout} = props; + const [loading, setLoading] = React.useState(false); + React.useEffect(() => { + setTimeout(() => setLoading(false), 500); + }, [loading]); + return ( +
    + {rollout.objectMeta?.name} + + { + props.refresh(); + setLoading(true); + e.preventDefault(); + }} + spin={loading} + /> + + +
    + ); +}; diff --git a/ui/src/app/components/status-icon/status-icon.scss b/ui/src/app/components/status-icon/status-icon.scss new file mode 100644 index 0000000000..0308f3bfc3 --- /dev/null +++ b/ui/src/app/components/status-icon/status-icon.scss @@ -0,0 +1,17 @@ +@import '../../shared/styles/colors.scss'; + +.status-icon, +.condition-icon { + &--progressing { + color: $sky; + } + &--healthy { + color: $argo-success-color; + } + &--degraded { + color: $coral; + } + &--paused { + color: $peach; + } +} diff --git a/ui/src/app/components/status-icon/status-icon.tsx b/ui/src/app/components/status-icon/status-icon.tsx new file mode 100644 index 0000000000..9da3773b94 --- /dev/null +++ b/ui/src/app/components/status-icon/status-icon.tsx @@ -0,0 +1,96 @@ +import * as React from 'react'; + +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faArrowAltCircleDown, faCircleNotch} from '@fortawesome/free-solid-svg-icons'; +import {faCheckCircle, faPauseCircle, faQuestionCircle, faTimesCircle} from '@fortawesome/free-regular-svg-icons'; + +import './status-icon.scss'; +import {Tooltip} from '../tooltip/tooltip'; + +export enum RolloutStatus { + Progressing = 'Progressing', + Degraded = 'Degraded', + Paused = 'Paused', + Healthy = 'Healthy', +} + +export const StatusIcon = (props: {status: RolloutStatus}): JSX.Element => { + let icon, className; + let spin = false; + const {status} = props; + switch (status) { + case 'Progressing': { + icon = faCircleNotch; + className = 'progressing'; + spin = true; + break; + } + case 'Healthy': { + icon = faCheckCircle; + className = 'healthy'; + break; + } + case 'Paused': { + icon = faPauseCircle; + className = 'paused'; + break; + } + case 'Degraded': { + icon = faTimesCircle; + className = 'degraded'; + break; + } + default: { + icon = faQuestionCircle; + className = 'unknown'; + } + } + return ; +}; + +export enum ReplicaSetStatus { + Running = 'Running', + Degraded = 'Degraded', + ScaledDown = 'ScaledDown', + Healthy = 'Healthy', + Progressing = 'Progressing', +} + +export const ReplicaSetStatusIcon = (props: {status: ReplicaSetStatus}) => { + let icon, className; + let spin = false; + const {status} = props; + switch (status) { + case 'Healthy': + case 'Running': { + icon = faCheckCircle; + className = 'healthy'; + break; + } + case 'ScaledDown': { + icon = faArrowAltCircleDown; + className = 'paused'; + break; + } + case 'Degraded': { + icon = faTimesCircle; + className = 'degraded'; + break; + } + case 'Progressing': { + icon = faCircleNotch; + spin = true; + className = 'progressing'; + break; + } + default: { + icon = faQuestionCircle; + className = 'unknown'; + } + } + return ( + + + + ); +}; diff --git a/ui/src/app/components/theme-div/theme-div.tsx b/ui/src/app/components/theme-div/theme-div.tsx new file mode 100644 index 0000000000..b1f3ef1986 --- /dev/null +++ b/ui/src/app/components/theme-div/theme-div.tsx @@ -0,0 +1,28 @@ +import * as React from 'react'; +import {Theme, useTheme} from '../../shared/context/theme'; + +export const ThemeDiv = ( + props: {children?: React.ReactNode; disabled?: boolean; innerref?: React.MutableRefObject} & React.DetailedHTMLProps, HTMLDivElement> +) => { + const theme = useTheme(); + let clString = props.className; + + if (theme === Theme.Dark && !props.disabled) { + const cl = (clString || '').split(' ') || []; + const darkCl = []; + for (const c of cl) { + if (!c.endsWith('--dark')) { + darkCl.push(c + '--dark'); + } + } + clString = `${cl.join(' ')} ${darkCl.join(' ')}`; + } + + return ( +
    + {props.children} +
    + ); +}; + +export default ThemeDiv; diff --git a/ui/src/app/components/theme-toggle/theme-toggle.tsx b/ui/src/app/components/theme-toggle/theme-toggle.tsx new file mode 100644 index 0000000000..96464c01d9 --- /dev/null +++ b/ui/src/app/components/theme-toggle/theme-toggle.tsx @@ -0,0 +1,12 @@ +import {faMoon} from '@fortawesome/free-regular-svg-icons'; +import {faSun} from '@fortawesome/free-solid-svg-icons'; +import * as React from 'react'; +import {Theme, ThemeContext} from '../../shared/context/theme'; +import {ActionButton} from '../action-button/action-button'; + +export const ThemeToggle = () => { + const dmCtx = React.useContext(ThemeContext); + const isDark = dmCtx.theme === Theme.Dark; + const icon = isDark ? faSun : faMoon; + return dmCtx.set(isDark ? Theme.Light : Theme.Dark)} icon={icon} dark />; +}; diff --git a/ui/src/app/components/tooltip/tooltip.scss b/ui/src/app/components/tooltip/tooltip.scss new file mode 100644 index 0000000000..503f75faf3 --- /dev/null +++ b/ui/src/app/components/tooltip/tooltip.scss @@ -0,0 +1,15 @@ +@import '../../shared/styles/colors.scss'; + +.tooltip { + position: absolute; + padding: 5px 10px; + border-radius: 3px; + bottom: 100%; + z-index: 2; + background-color: $slate; + white-space: nowrap; + color: white; + &--dark { + border: 1px solid $dull-shine; + } +} diff --git a/ui/src/app/components/tooltip/tooltip.tsx b/ui/src/app/components/tooltip/tooltip.tsx new file mode 100644 index 0000000000..ce91cc8b7f --- /dev/null +++ b/ui/src/app/components/tooltip/tooltip.tsx @@ -0,0 +1,40 @@ +import * as React from 'react'; +import {ThemeDiv} from '../theme-div/theme-div'; + +import './tooltip.scss'; + +export const useHover = (): [React.MutableRefObject, boolean] => { + const [show, setShow] = React.useState(false); + const ref = React.useRef(null); + + const handleMouseOver = () => setShow(true); + const handleMouseOut = () => setShow(false); + + React.useEffect(() => { + const cur = ref.current; + + if (cur) { + cur.addEventListener('mouseover', handleMouseOver); + cur.addEventListener('mouseout', handleMouseOut); + + return () => { + cur.removeEventListener('mouseover', handleMouseOver); + cur.removeEventListener('mouseout', handleMouseOut); + }; + } + }, []); + + return [ref, show]; +}; + +export const Tooltip = (props: {content: React.ReactNode | string} & React.PropsWithRef) => { + const [tooltip, showTooltip] = useHover(); + return ( +
    + +
    {props.children}
    +
    + ); +}; diff --git a/ui/src/app/components/wait-for/loading-bar.scss b/ui/src/app/components/wait-for/loading-bar.scss new file mode 100644 index 0000000000..5c459d25ae --- /dev/null +++ b/ui/src/app/components/wait-for/loading-bar.scss @@ -0,0 +1,27 @@ +@import '../../shared/styles/colors.scss'; + +.loading-bar { + background-color: $argo-color-gray-4; + border-radius: 3px; + height: 7px; + overflow: hidden; + width: 350px; + will-change: opacity; + &--dark { + background-color: $slate; + } + &__fill { + transform-origin: left; + background-color: $sherbert; + height: 100%; + width: 1px; + + &--loaded { + transform: scaleX(350); + } + } + + &--loaded { + opacity: 0; + } +} diff --git a/ui/src/app/components/wait-for/spinner.scss b/ui/src/app/components/wait-for/spinner.scss new file mode 100644 index 0000000000..ad9ef376fa --- /dev/null +++ b/ui/src/app/components/wait-for/spinner.scss @@ -0,0 +1,10 @@ +@import '../../shared/styles/colors.scss'; + +.spinner { + color: $slate; + font-size: 25px; + + &--dark { + color: white; + } +} diff --git a/ui/src/app/components/wait-for/wait-for.tsx b/ui/src/app/components/wait-for/wait-for.tsx new file mode 100644 index 0000000000..40d075f9c4 --- /dev/null +++ b/ui/src/app/components/wait-for/wait-for.tsx @@ -0,0 +1,31 @@ +import {faCircleNotch} from '@fortawesome/free-solid-svg-icons'; +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import * as React from 'react'; +import {ThemeDiv} from '../theme-div/theme-div'; +import './spinner.scss'; +import './loading-bar.scss'; + +export const Spinner = () => ( + + + +); + +export const LoadingBar = (props: {loadms?: string | number}) => { + const [loading, setLoading] = React.useState(true); + + const loadms = props.loadms || 400; + + React.useEffect(() => { + setLoading(false); + }, []); + return ( + setLoading(false)}> +
    + + ); +}; + +export const WaitFor = (props: {loading: boolean; loader?: React.ReactNode; loadms?: string | number} & React.ComponentProps): JSX.Element => ( + {props.loading ? props.loader || : props.children} +); diff --git a/ui/src/app/index.html b/ui/src/app/index.html new file mode 100644 index 0000000000..92ddb91acd --- /dev/null +++ b/ui/src/app/index.html @@ -0,0 +1,13 @@ + + + + + + + Argo Rollouts + + + +
    + + diff --git a/ui/src/app/index.tsx b/ui/src/app/index.tsx new file mode 100644 index 0000000000..3bc5d04223 --- /dev/null +++ b/ui/src/app/index.tsx @@ -0,0 +1,10 @@ +import * as React from 'react'; +import * as ReactDOM from 'react-dom'; +import App from './App'; + +ReactDOM.render( + + + , + document.getElementById('root') +); diff --git a/ui/src/app/shared/context/api.tsx b/ui/src/app/shared/context/api.tsx new file mode 100644 index 0000000000..a593093645 --- /dev/null +++ b/ui/src/app/shared/context/api.tsx @@ -0,0 +1,23 @@ +import * as React from 'react'; +import {RolloutServiceApi} from '../../../models/rollout/generated'; + +export const RolloutAPI = new RolloutServiceApi(); +export const RolloutAPIContext = React.createContext(RolloutAPI); + +export const APIProvider = (props: {children: React.ReactNode}) => { + return {props.children}; +}; + +export const NamespaceContext = React.createContext(''); + +export const NamespaceProvider = (props: {children: React.ReactNode}) => { + const [namespace, setNamespace] = React.useState(''); + React.useEffect(() => { + const getNs = async () => { + const nsInfo = await RolloutAPI.rolloutServiceGetNamespace(); + setNamespace(nsInfo.namespace); + }; + getNs(); + }) + return {props.children} +} diff --git a/ui/src/app/shared/context/theme.tsx b/ui/src/app/shared/context/theme.tsx new file mode 100644 index 0000000000..af9eb4ead9 --- /dev/null +++ b/ui/src/app/shared/context/theme.tsx @@ -0,0 +1,31 @@ +import * as React from 'react'; + +export const THEME_KEY = 'theme'; + +export enum Theme { + Dark = 'dark', + Light = 'light', +} + +const init = (JSON.parse(window.localStorage.getItem(THEME_KEY)) as Theme) || Theme.Light; + +interface ThemeContextProps { + theme: Theme; + set: (th: Theme) => void; +} + +export const ThemeContext = React.createContext({theme: init} as ThemeContextProps); + +export const ThemeProvider = (props: {children: React.ReactNode}) => { + const [theme, setTheme] = React.useState(init); + React.useEffect(() => { + window.localStorage.setItem(THEME_KEY, JSON.stringify(theme)); + }, [theme]); + + return setTheme(th)}}>{props.children}; +}; + +export const useTheme = () => { + const dmCtx = React.useContext(ThemeContext); + return dmCtx.theme; +}; diff --git a/ui/src/app/shared/services/rollout.ts b/ui/src/app/shared/services/rollout.ts new file mode 100644 index 0000000000..49625c3613 --- /dev/null +++ b/ui/src/app/shared/services/rollout.ts @@ -0,0 +1,65 @@ +import {RolloutRolloutWatchEvent, RolloutServiceApiFetchParamCreator} from '../../../models/rollout/generated'; +import {ListState, useLoading, useWatch, useWatchList} from '../utils/watch'; +import {RolloutInfo} from '../../../models/rollout/rollout'; +import * as React from 'react'; +import {NamespaceContext, RolloutAPIContext} from '../context/api'; + +export const useRollouts = (): RolloutInfo[] => { + const api = React.useContext(RolloutAPIContext); + const namespace = React.useContext(NamespaceContext); + const [rollouts, setRollouts] = React.useState([]); + + React.useEffect(() => { + const fetchList = async () => { + const list = await api.rolloutServiceListRolloutInfos(namespace); + setRollouts(list.rollouts || []); + }; + fetchList(); + }, [api, namespace]); + + return rollouts; +}; + +export const useWatchRollouts = (): ListState => { + const findRollout = React.useCallback((ri: RolloutInfo, change: RolloutRolloutWatchEvent) => ri.objectMeta.name === change.rolloutInfo?.objectMeta?.name, []); + const getRollout = React.useCallback((c) => c.rolloutInfo as RolloutInfo, []); + const namespace = React.useContext(NamespaceContext); + const streamUrl = RolloutServiceApiFetchParamCreator().rolloutServiceWatchRolloutInfos(namespace).url; + + const init = useRollouts(); + const loading = useLoading(init); + + const [rollouts, setRollouts] = React.useState(init); + const liveList = useWatchList(streamUrl, findRollout, getRollout, rollouts); + + React.useEffect(() => { + setRollouts(init); + }, [init, loading]); + + return { + items: liveList, + loading, + } as ListState; +}; + +export const useWatchRollout = (name: string, subscribe: boolean, timeoutAfter?: number, callback?: (ri: RolloutInfo) => void): [RolloutInfo, boolean] => { + const namespace = React.useContext(NamespaceContext); + name = name || ''; + const isEqual = React.useCallback((a, b) => { + if (!a.objectMeta || !b.objectMeta) { + return false; + } + + return JSON.parse(a.objectMeta.resourceVersion) === JSON.parse(b.objectMeta.resourceVersion); + }, []); + const streamUrl = RolloutServiceApiFetchParamCreator().rolloutServiceWatchRolloutInfo(namespace, name).url; + const ri = useWatch(streamUrl, subscribe, isEqual, timeoutAfter); + if (callback && ri.objectMeta) { + callback(ri); + } + const [loading, setLoading] = React.useState(true); + if (ri.objectMeta && loading) { + setLoading(false); + } + return [ri, loading]; +}; diff --git a/ui/src/app/shared/styles/colors.scss b/ui/src/app/shared/styles/colors.scss new file mode 100644 index 0000000000..aa23d8ae18 --- /dev/null +++ b/ui/src/app/shared/styles/colors.scss @@ -0,0 +1,77 @@ +$argo-color-gray-1: #f8fbfb; +$argo-color-gray-2: #eff3f5; +$argo-color-gray-3: #dee6eb; +$argo-color-gray-4: #ccd6dd; +$argo-color-gray-5: #8fa4b1; +$argo-color-gray-6: #6d7f8b; +$argo-color-gray-7: #495763; +$argo-color-gray-8: #363c4a; +$argo-color-gray-9: #000000; + +$argo-color-teal-1: #f5fbfd; +$argo-color-teal-2: #dff6f9; +$argo-color-teal-3: #bdecf2; +$argo-color-teal-4: #99e1ea; +$argo-color-teal-5: #1fbdd0; +$argo-color-teal-6: #00a2b3; +$argo-color-teal-7: #006f8a; +$argo-color-teal-8: #004c67; + +$white-color: #ffffff; + +// Status colors +$argo-failed-color: #e96d76; +$argo-failed-color-dark: #c04b4f; +$argo-failed-color-light: #ff6262; +$argo-status-failed-color: #ef0b28; +$argo-color-red: #f00052; + +$argo-success-color: #18be94; +$argo-success-color-dark: #3f946d; +$argo-success-color-light: #95d58f; +$argo-status-success-color: #0d8d38; +$argo-color-green: #7ed321; + +$argo-status-warning-color: #f4c030; +$argo-color-yellow: #ffd100; + +$argo-running-color-dark: #378398; +$argo-running-color-light: #02c4d3; +$argo-running-color: #0dadea; + +$argo-waiting-color-dark: $argo-color-gray-6; +$argo-waiting-color-light: $argo-color-gray-5; +$argo-waiting-color: $argo-color-gray-5; +$argo-cancelled-color: $argo-color-gray-5; +$argo-init-color: $argo-color-gray-5; + +// Dark Mode +$space: #09090f; +$midnight-sky: #0e0e14; +$slate: #191826; +$shine: #dad6e7; +$dull-shine: #abb2b9; +$silver-lining: #30303d; +$fog: #22212d; +$glow: #434355; + +// Highlights +$spray-tan: #8b4329; +$sherbert: #f07548; +$peach: #fd8a5f; + +// Statuses +$lime: #3eb74f; +$grass: #339440; +$leaf: #246b2d; +$forest: #12221e; + +$sky: #58a6fe; +$sea: #3a5e88; +$deep-sea: #172636; + +$coral: #f85149; +$clay: #9e3d38; +$dirt: #22141a; + +$canary: #e4aa37; diff --git a/ui/src/app/shared/utils/utils.tsx b/ui/src/app/shared/utils/utils.tsx new file mode 100644 index 0000000000..d62628485d --- /dev/null +++ b/ui/src/app/shared/utils/utils.tsx @@ -0,0 +1,98 @@ +import * as React from 'react'; +import * as moment from 'moment'; +import {faDove, faQuestion, faRunning, faSearch, faThumbsUp} from '@fortawesome/free-solid-svg-icons'; +import {RolloutReplicaSetInfo} from '../../../models/rollout/generated'; + +export function useServerData(getData: () => Promise) { + const [data, setData] = React.useState({} as T); + React.useEffect(() => { + const fx = async () => { + const data = await getData(); + setData(data); + }; + fx(); + }, [getData]); + return data as T; +} + +export function formatTimestamp(ts: string): string { + const inputFormat = 'YYYY-MM-DD HH:mm:ss Z z'; + const m = moment(ts, inputFormat); + if (!ts || !m.isValid()) { + return 'Never'; + } + return m.format('MMM D YYYY [at] hh:mm:ss'); +} + +export enum ImageTag { + Canary = 'canary', + Stable = 'stable', + Active = 'active', + Preview = 'preview', + Unknown = 'unknown', +} + +export const IconForTag = (t?: ImageTag) => { + switch (t) { + case ImageTag.Canary: + return faDove; + case ImageTag.Stable: + return faThumbsUp; + case ImageTag.Preview: + return faSearch; + case ImageTag.Active: + return faRunning; + default: + return faQuestion; + } +}; + +export const ParseTagsFromReplicaSet = (rs: RolloutReplicaSetInfo): ImageTag[] => { + const tags = [] as ImageTag[]; + if (rs.canary) { + tags.push(ImageTag.Canary); + } + if (rs.stable) { + tags.push(ImageTag.Stable); + } + if (rs.active) { + tags.push(ImageTag.Active); + } + if (rs.preview) { + tags.push(ImageTag.Preview); + } + return tags; +}; + +export const appendSuffixToClasses = (classNames: string, suffix: string): string => { + let clString = classNames; + const cl = (clString || '').split(' ') || []; + const suffixed = []; + for (const c of cl) { + if (!c.endsWith(suffix) && c !== ' ' && c !== '') { + suffixed.push(c + suffix); + } + } + return suffixed.join(' '); +}; + +export const useClickOutside = (ref: any, callback: () => void) => { + React.useEffect(() => { + const handler = (e: any) => { + if (ref.current && !ref.current.contains(e.target)) { + callback(); + } + }; + + document.addEventListener('mousedown', handler); + return () => document.removeEventListener('mousedown', handler); + }, [ref, callback]); +}; + +export const useWidth = (ref: any): number => { + const [width, setWidth] = React.useState(0); + React.useEffect(() => { + setWidth(ref.current ? ref.current.offsetWidth : 0); + }, [ref]); + return width; +}; diff --git a/ui/src/app/shared/utils/watch.ts b/ui/src/app/shared/utils/watch.ts new file mode 100644 index 0000000000..a537afc2b2 --- /dev/null +++ b/ui/src/app/shared/utils/watch.ts @@ -0,0 +1,184 @@ +import * as React from 'react'; +import {fromEvent, Observable, Observer, Subscription} from 'rxjs'; +import {bufferTime, debounceTime, delay, filter, map, mergeMap, repeat, retryWhen, scan, timeout} from 'rxjs/operators'; + +enum ReadyState { + CONNECTING = 0, + OPEN = 1, + CLOSED = 2, + DONE = 4, +} + +export interface ListState { + loading: boolean; + items: T[]; +} + +export const useLoading = (list: any[], minLength?: number) => { + const [loading, setLoading] = React.useState(true); + React.useEffect(() => { + if (!list) { + return; + } + if (list.length > (minLength || 0)) { + setLoading(false); + } + }, [list, minLength]); + return loading; +}; + +function fromEventSource(url: string): Observable { + return Observable.create((observer: Observer) => { + let eventSource = new EventSource(url); + eventSource.onmessage = (msg) => observer.next(msg.data); + eventSource.onerror = (e) => () => { + observer.error(e); + }; + + const interval = setInterval(() => { + if (eventSource && eventSource.readyState === ReadyState.CLOSED) { + observer.error('connection got closed unexpectedly'); + } + }, 500); + return () => { + clearInterval(interval); + eventSource.close(); + eventSource = null; + }; + }); +} + +const BUFFER_TIME = 500; + +export function handlePageVisibility(src: () => Observable): Observable { + return new Observable((observer: Observer) => { + let subscription: Subscription; + const ensureUnsubscribed = () => { + if (subscription) { + subscription.unsubscribe(); + subscription = null; + } + }; + const start = () => { + ensureUnsubscribed(); + subscription = src().subscribe( + (item: T) => observer.next(item), + (err) => observer.error(err), + () => observer.complete() + ); + }; + + if (!document.hidden) { + start(); + } + + const visibilityChangeSubscription = fromEvent(document, 'visibilitychange') + .pipe(debounceTime(500)) + .subscribe(() => { + if (document.hidden && subscription) { + ensureUnsubscribed(); + } else if (!document.hidden && !subscription) { + start(); + } + }); + + return () => { + visibilityChangeSubscription.unsubscribe(); + ensureUnsubscribed(); + }; + }); +} + +interface WatchEvent { + type?: string; +} + +// NOTE: findItem and getItem must be React.useCallback functions +export function useWatchList(url: string, findItem: (item: T, change: E) => boolean, getItem: (change: E) => T, init?: T[]): T[] { + const [items, setItems] = React.useState(init as T[]); + + React.useEffect(() => { + setItems(init); + const stream = fromEventSource(url).pipe(map((res) => JSON.parse(res).result as E)); + let watch = stream.pipe( + repeat(), + retryWhen((errors) => errors.pipe(delay(500))), + scan((items, change) => { + const index = items.findIndex((i) => findItem(i, change)); + switch (change.type) { + case 'Deleted': + if (index > -1) { + items.splice(index, 1); + } + break; + case 'Updated': + if (index > -1) { + const updated = {...items[index], ...getItem(change)}; + items[index] = updated as T; + } + break; + default: + if (index > -1) { + items[index] = getItem(change) as T; + } else { + items.unshift(getItem(change) as T); + } + break; + } + return items; + }, init || []), + bufferTime(BUFFER_TIME), + mergeMap((l) => l) + ); + + const sub = handlePageVisibility(() => watch).subscribe((l) => { + setItems([...l]); + }); + + return () => { + sub.unsubscribe(); + watch = null; + }; + }, [init, url, findItem, getItem]); + return items; +} + +export function useWatch(url: string, subscribe: boolean, isEqual: (a: T, b: T) => boolean, timeoutAfter?: number) { + const [item, setItem] = React.useState({} as T); + React.useEffect(() => { + if (!subscribe) { + return; + } + const stream = fromEventSource(url).pipe(map((res) => JSON.parse(res).result as T)); + let watch = stream.pipe( + repeat(), + retryWhen((errors) => errors.pipe(delay(500))), + scan( + (acc, update) => { + return {data: update, updated: !isEqual(update, acc.data)}; + }, + {data: {} as T, updated: true} + ), + filter((i) => i.updated), + map((i) => i.data) + ); + + let liveStream = handlePageVisibility(() => + watch.pipe( + bufferTime(BUFFER_TIME), + mergeMap((r) => r) + ) + ); + + if (timeoutAfter > 0) { + liveStream = liveStream.pipe(timeout(timeoutAfter)); + } + + const sub = liveStream.subscribe((i) => setItem(i)); + return () => { + liveStream = null; + sub.unsubscribe(); + }; + }, [url, subscribe, timeoutAfter, isEqual]); + return item; +} diff --git a/ui/src/app/tsconfig.json b/ui/src/app/tsconfig.json new file mode 100644 index 0000000000..130f3aadcd --- /dev/null +++ b/ui/src/app/tsconfig.json @@ -0,0 +1,16 @@ +{ + "compilerOptions": { + "outDir": "./../../dist/app", + "sourceMap": true, + "noImplicitAny": true, + "module": "commonjs", + "target": "es6", + "jsx": "react", + "experimentalDecorators": true, + "noUnusedLocals": true, + "declaration": false, + "lib": ["es2017", "dom"] + }, + "include": ["./**/*"], + "exclude": ["node_modules", "./**/*.test.ts", "./**/*.test.tsx"] +} diff --git a/ui/src/app/webpack.common.js b/ui/src/app/webpack.common.js new file mode 100644 index 0000000000..1ddea01e16 --- /dev/null +++ b/ui/src/app/webpack.common.js @@ -0,0 +1,66 @@ +'use strict;'; + +const CopyWebpackPlugin = require('copy-webpack-plugin'); +const HtmlWebpackPlugin = require('html-webpack-plugin'); + +const webpack = require('webpack'); +const path = require('path'); + +const config = { + entry: { + main: './src/app/index.tsx', + }, + output: { + filename: '[name].[chunkhash].js', + path: __dirname + '/../../dist/app', + }, + + devtool: 'source-map', + + resolve: { + extensions: ['.ts', '.tsx', '.js', '.json', '.ttf'], + }, + + module: { + rules: [ + { + test: /\.tsx?$/, + loaders: [`ts-loader?allowTsInNodeModules=true&configFile=${path.resolve('./src/app/tsconfig.json')}`], + }, + { + test: /\.scss$/, + loader: 'style-loader!raw-loader!sass-loader', + }, + { + test: /\.css$/, + loader: 'style-loader!raw-loader', + }, + { + test: /\.ttf$/, + use: ['file-loader'], + }, + ], + }, + node: { + fs: 'empty', + }, + plugins: [ + new webpack.DefinePlugin({ + SYSTEM_INFO: JSON.stringify({ + version: process.env.VERSION || 'latest', + }), + }), + new HtmlWebpackPlugin({template: 'src/app/index.html'}), + new CopyWebpackPlugin({ + patterns: [ + {from: 'src/assets', to: 'assets'}, + { + from: 'node_modules/@fortawesome/fontawesome-free/webfonts', + to: 'assets/fonts', + }, + ], + }), + ], +}; + +module.exports = config; diff --git a/ui/src/app/webpack.dev.js b/ui/src/app/webpack.dev.js new file mode 100644 index 0000000000..88977f2c0a --- /dev/null +++ b/ui/src/app/webpack.dev.js @@ -0,0 +1,33 @@ +const {merge} = require('webpack-merge'); +const common = require('./webpack.common.js'); +const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; +const webpack = require('webpack'); + +module.exports = merge(common, { + mode: 'development', + plugins: [ + new BundleAnalyzerPlugin(), + new webpack.DefinePlugin({ + 'process.env.NODE_ENV': JSON.stringify('development'), + }), + ], + devServer: { + historyApiFallback: { + disableDotRule: true, + }, + watchOptions: { + ignored: [/dist/, /node_modules/], + }, + headers: { + 'X-Frame-Options': 'SAMEORIGIN', + }, + host: 'localhost', + port: 3101, + proxy: { + '/api/v1': { + target: 'http://localhost:3100', + secure: false, + }, + }, + }, +}); diff --git a/ui/src/app/webpack.prod.js b/ui/src/app/webpack.prod.js new file mode 100644 index 0000000000..da8dc9c2c1 --- /dev/null +++ b/ui/src/app/webpack.prod.js @@ -0,0 +1,23 @@ +const {merge} = require('webpack-merge'); +const common = require('./webpack.common.js'); +const MiniCssExtractPlugin = require('mini-css-extract-plugin'); +const webpack = require('webpack'); + +module.exports = merge(common, { + mode: 'production', + devtool: 'source-map', + plugins: [ + new MiniCssExtractPlugin(), + new webpack.DefinePlugin({ + 'process.env.NODE_ENV': JSON.stringify('production'), + }), + ], + module: { + rules: [ + { + test: /\.css$/i, + use: [MiniCssExtractPlugin.loader, 'css-loader'], + }, + ], + }, +}); diff --git a/ui/src/assets/images/argo-icon-color-square.png b/ui/src/assets/images/argo-icon-color-square.png new file mode 100644 index 0000000000000000000000000000000000000000..bb79c736d634410ab41e8444b0c7afbe74048785 GIT binary patch literal 102248 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
    $WRolEUD-TLONE|{FNkVrN&Dyk#L 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 + + Slice 1 + + + + + + + + + + + \ No newline at end of file diff --git a/ui/src/assets/images/argo-icon-white.svg b/ui/src/assets/images/argo-icon-white.svg new file mode 100644 index 0000000000..41902c62be --- /dev/null +++ b/ui/src/assets/images/argo-icon-white.svg @@ -0,0 +1 @@ +cloudevents-icon-white \ No newline at end of file diff --git a/ui/src/models/rollout/generated/.gitignore b/ui/src/models/rollout/generated/.gitignore new file mode 100644 index 0000000000..35e2fb2b02 --- /dev/null +++ b/ui/src/models/rollout/generated/.gitignore @@ -0,0 +1,3 @@ +wwwroot/*.js +node_modules +typings diff --git a/ui/src/models/rollout/generated/.swagger-codegen-ignore b/ui/src/models/rollout/generated/.swagger-codegen-ignore new file mode 100644 index 0000000000..c5fa491b4c --- /dev/null +++ b/ui/src/models/rollout/generated/.swagger-codegen-ignore @@ -0,0 +1,23 @@ +# Swagger Codegen Ignore +# Generated by swagger-codegen https://github.com/swagger-api/swagger-codegen + +# Use this file to prevent files from being overwritten by the generator. +# The patterns follow closely to .gitignore or .dockerignore. + +# As an example, the C# client generator defines ApiClient.cs. +# You can make changes and tell Swagger Codgen to ignore just this file by uncommenting the following line: +#ApiClient.cs + +# You can match any string of characters against a directory, file or extension with a single asterisk (*): +#foo/*/qux +# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux + +# You can recursively match patterns against a directory, file or extension with a double asterisk (**): +#foo/**/qux +# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux + +# You can also negate patterns with an exclamation (!). +# For example, you can ignore all files in a docs folder with the file extension .md: +#docs/*.md +# Then explicitly reverse the ignore rule for a single file: +#!docs/README.md diff --git a/ui/src/models/rollout/generated/.swagger-codegen/VERSION b/ui/src/models/rollout/generated/.swagger-codegen/VERSION new file mode 100644 index 0000000000..9b77657dc7 --- /dev/null +++ b/ui/src/models/rollout/generated/.swagger-codegen/VERSION @@ -0,0 +1 @@ +3.0.25 \ No newline at end of file diff --git a/ui/src/models/rollout/generated/api.ts b/ui/src/models/rollout/generated/api.ts new file mode 100644 index 0000000000..65dd22e713 --- /dev/null +++ b/ui/src/models/rollout/generated/api.ts @@ -0,0 +1,6209 @@ +/// +// tslint:disable +/** + * pkg/apiclient/rollout/rollout.proto + * No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) + * + * OpenAPI spec version: version not set + * + * + * NOTE: This file is auto generated by the swagger code generator program. + * https://github.com/swagger-api/swagger-codegen.git + * Do not edit the file manually. + */ + +import * as url from "url"; +import * as portableFetch from "portable-fetch"; +import { Configuration } from "./configuration"; + +const BASE_PATH = "/".replace(/\/+$/, ""); + +/** + * + * @export + */ +export const COLLECTION_FORMATS = { + csv: ",", + ssv: " ", + tsv: "\t", + pipes: "|", +}; + +/** + * + * @export + * @interface FetchAPI + */ +export interface FetchAPI { + (url: string, init?: any): Promise; +} + +/** + * + * @export + * @interface FetchArgs + */ +export interface FetchArgs { + url: string; + options: any; +} + +/** + * + * @export + * @class BaseAPI + */ +export class BaseAPI { + protected configuration: Configuration; + + constructor(configuration?: Configuration, protected basePath: string = BASE_PATH, protected fetch: FetchAPI = portableFetch) { + if (configuration) { + this.configuration = configuration; + this.basePath = configuration.basePath || this.basePath; + } + } +}; + +/** + * + * @export + * @class RequiredError + * @extends {Error} + */ +export class RequiredError extends Error { + name: "RequiredError" + constructor(public field: string, msg?: string) { + super(msg); + } +} + +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting + */ + ingress?: string; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting + */ + servicePort?: number; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting + */ + rootService?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting + */ + annotationPrefix?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AnalysisRunArgument + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AnalysisRunArgument { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AnalysisRunArgument + */ + name?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AnalysisRunArgument + */ + value?: string; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AnalysisRunArgument + */ + valueFrom?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PreferredDuringSchedulingIgnoredDuringExecution} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity + */ + preferredDuringSchedulingIgnoredDuringExecution?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PreferredDuringSchedulingIgnoredDuringExecution; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RequiredDuringSchedulingIgnoredDuringExecution} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity + */ + requiredDuringSchedulingIgnoredDuringExecution?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RequiredDuringSchedulingIgnoredDuringExecution; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom + */ + podTemplateHashValue?: string; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1FieldRef} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ArgumentValueFrom + */ + fieldRef?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1FieldRef; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ + previewSelector?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ + activeSelector?: string; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ + scaleUpPreviewCheckPoint?: boolean; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ + prePromotionAnalysisRunStatus?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus + */ + postPromotionAnalysisRunStatus?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy { + /** + * Name of the service that the rollout modifies as the active service. + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + activeService?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + previewService?: string; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + previewReplicaCount?: number; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + autoPromotionEnabled?: boolean; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + autoPromotionSeconds?: number; + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + maxUnavailable?: K8sIoApimachineryPkgUtilIntstrIntOrString; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + scaleDownDelaySeconds?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + scaleDownDelayRevisionLimit?: number; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + prePromotionAnalysis?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + antiAffinity?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + postPromotionAnalysis?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + previewMetadata?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy + */ + activeMetadata?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus + */ + currentStepAnalysisRunStatus?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus + */ + currentBackgroundAnalysisRunStatus?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus + */ + currentExperiment?: string; +} +/** + * CanaryStep defines a step of a canary deployment. + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep { + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ + setWeight?: number; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutPause} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ + pause?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutPause; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ + experiment?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ + analysis?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStep + */ + setCanaryScale?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + canaryService?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + stableService?: string; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + steps?: Array; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + trafficRouting?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting; + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + maxUnavailable?: K8sIoApimachineryPkgUtilIntstrIntOrString; + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + maxSurge?: K8sIoApimachineryPkgUtilIntstrIntOrString; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + analysis?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + antiAffinity?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1AntiAffinity; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + canaryMetadata?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy + */ + stableMetadata?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1FieldRef + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1FieldRef { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1FieldRef + */ + fieldPath?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule + */ + name?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule + */ + canarySubsetName?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule + */ + stableSubsetName?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting + */ + virtualService?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting + */ + destinationRule?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioDestinationRule; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService + */ + name?: string; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioVirtualService + */ + routes?: Array; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting + */ + annotationPrefix?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting + */ + stableIngress?: string; + /** + * + * @type {{ [key: string]: string; }} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting + */ + additionalIngressAnnotations?: { [key: string]: string; }; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PauseCondition + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PauseCondition { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PauseCondition + */ + reason?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PauseCondition + */ + startTime?: K8sIoApimachineryPkgApisMetaV1Time; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata { + /** + * + * @type {{ [key: string]: string; }} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata + */ + labels?: { [key: string]: string; }; + /** + * + * @type {{ [key: string]: string; }} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata + */ + annotations?: { [key: string]: string; }; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PreferredDuringSchedulingIgnoredDuringExecution + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PreferredDuringSchedulingIgnoredDuringExecution { + /** + * Weight associated with matching the corresponding podAffinityTerm, in the range 1-100. + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PreferredDuringSchedulingIgnoredDuringExecution + */ + weight?: number; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RequiredDuringSchedulingIgnoredDuringExecution + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RequiredDuringSchedulingIgnoredDuringExecution { +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1Rollout + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1Rollout { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1Rollout + */ + metadata?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1Rollout + */ + spec?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1Rollout + */ + status?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis { + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis + */ + templates?: Array; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis + */ + args?: Array; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground + */ + rolloutAnalysis?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysis; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisBackground + */ + startingStep?: number; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus + */ + name?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus + */ + status?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisRunStatus + */ + message?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisTemplate + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisTemplate { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisTemplate + */ + templateName?: string; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutAnalysisTemplate + */ + clusterScope?: boolean; +} +/** + * RolloutCondition describes the state of a rollout at a certain point. + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition { + /** + * Type of deployment condition. + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + type?: string; + /** + * Phase of the condition, one of True, False, Unknown. + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + status?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + lastUpdateTime?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + lastTransitionTime?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * The reason for the condition's last transition. + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + reason?: string; + /** + * A human readable message indicating details about the transition. + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutCondition + */ + message?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep { + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep + */ + templates?: Array; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep + */ + duration?: string; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStep + */ + analyses?: Array; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ + name?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ + templateName?: string; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ + clusterScope?: boolean; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ + args?: Array; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentStepAnalysisTemplateRef + */ + requiredForCompletion?: boolean; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ + name?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ + specRef?: string; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ + replicas?: number; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ + metadata?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1PodTemplateMetadata; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1LabelSelector} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutExperimentTemplate + */ + selector?: K8sIoApimachineryPkgApisMetaV1LabelSelector; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutPause + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutPause { + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutPause + */ + duration?: K8sIoApimachineryPkgUtilIntstrIntOrString; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec { + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + replicas?: number; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1LabelSelector} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + selector?: K8sIoApimachineryPkgApisMetaV1LabelSelector; + /** + * + * @type {K8sIoApiCoreV1PodTemplateSpec} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + template?: K8sIoApiCoreV1PodTemplateSpec; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + minReadySeconds?: number; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + strategy?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + revisionHistoryLimit?: number; + /** + * Paused pauses the rollout at its current step. + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + paused?: boolean; + /** + * ProgressDeadlineSeconds The maximum time in seconds for a rollout to make progress before it is considered to be failed. Argo Rollouts will continue to process failed rollouts and a condition with a ProgressDeadlineExceeded reason will be surfaced in the rollout status. Note that progress will not be estimated during the time a rollout is paused. Defaults to 600s. + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + progressDeadlineSeconds?: number; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutSpec + */ + restartAt?: K8sIoApimachineryPkgApisMetaV1Time; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus { + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + abort?: boolean; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + pauseConditions?: Array; + /** + * ControllerPause indicates the controller has paused the rollout. It is set to true when the controller adds a pause condition. This field helps to discern the scenario where a rollout was resumed after being paused by the controller (e.g. via the plugin). In that situation, the pauseConditions would have been cleared , but controllerPause would still be set to true. + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + controllerPause?: boolean; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + abortedAt?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + currentPodHash?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + currentStepHash?: string; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + replicas?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + updatedReplicas?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + readyReplicas?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + availableReplicas?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + currentStepIndex?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + collisionCount?: number; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + observedGeneration?: string; + /** + * + * @type {Array} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + conditions?: Array; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + canary?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStatus; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + blueGreen?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStatus; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + hPAReplicas?: number; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + selector?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + stableRS?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + restartedAt?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * PromoteFull indicates if the rollout should perform a full promotion, skipping analysis and pauses. + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStatus + */ + promoteFull?: boolean; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy + */ + blueGreen?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1BlueGreenStrategy; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutStrategy + */ + canary?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1CanaryStrategy; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting { + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting + */ + istio?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1IstioTrafficRouting; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting + */ + nginx?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1NginxTrafficRouting; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting + */ + alb?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1ALBTrafficRouting; + /** + * + * @type {GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1RolloutTrafficRouting + */ + smi?: GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting { + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting + */ + rootService?: string; + /** + * + * @type {string} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SMITrafficRouting + */ + trafficSplitName?: string; +} +/** + * + * @export + * @interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale + */ +export interface GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale { + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale + */ + weight?: number; + /** + * + * @type {number} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale + */ + replicas?: number; + /** + * + * @type {boolean} + * @memberof GithubComArgoprojArgoRolloutsPkgApisRolloutsV1alpha1SetCanaryScale + */ + matchTrafficWeight?: boolean; +} +/** + * + * @export + * @interface GoogleProtobufAny + */ +export interface GoogleProtobufAny { + /** + * + * @type {string} + * @memberof GoogleProtobufAny + */ + typeUrl?: string; + /** + * + * @type {string} + * @memberof GoogleProtobufAny + */ + value?: string; +} +/** + * + * @export + * @interface GrpcGatewayRuntimeError + */ +export interface GrpcGatewayRuntimeError { + /** + * + * @type {string} + * @memberof GrpcGatewayRuntimeError + */ + error?: string; + /** + * + * @type {number} + * @memberof GrpcGatewayRuntimeError + */ + code?: number; + /** + * + * @type {string} + * @memberof GrpcGatewayRuntimeError + */ + message?: string; + /** + * + * @type {Array} + * @memberof GrpcGatewayRuntimeError + */ + details?: Array; +} +/** + * + * @export + * @interface GrpcGatewayRuntimeStreamError + */ +export interface GrpcGatewayRuntimeStreamError { + /** + * + * @type {number} + * @memberof GrpcGatewayRuntimeStreamError + */ + grpcCode?: number; + /** + * + * @type {number} + * @memberof GrpcGatewayRuntimeStreamError + */ + httpCode?: number; + /** + * + * @type {string} + * @memberof GrpcGatewayRuntimeStreamError + */ + message?: string; + /** + * + * @type {string} + * @memberof GrpcGatewayRuntimeStreamError + */ + httpStatus?: string; + /** + * + * @type {Array} + * @memberof GrpcGatewayRuntimeStreamError + */ + details?: Array; +} +/** + * Represents a Persistent Disk resource in AWS. An AWS EBS disk must exist before mounting to a container. The disk must also be in the same AWS zone as the kubelet. An AWS EBS disk can only be mounted as read/write once. AWS EBS volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource + */ +export interface K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource + */ + volumeID?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource + */ + fsType?: string; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource + */ + partition?: number; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource + */ + readOnly?: boolean; +} +/** + * Affinity is a group of affinity scheduling rules. + * @export + * @interface K8sIoApiCoreV1Affinity + */ +export interface K8sIoApiCoreV1Affinity { + /** + * + * @type {K8sIoApiCoreV1NodeAffinity} + * @memberof K8sIoApiCoreV1Affinity + */ + nodeAffinity?: K8sIoApiCoreV1NodeAffinity; + /** + * + * @type {K8sIoApiCoreV1PodAffinity} + * @memberof K8sIoApiCoreV1Affinity + */ + podAffinity?: K8sIoApiCoreV1PodAffinity; + /** + * + * @type {K8sIoApiCoreV1PodAntiAffinity} + * @memberof K8sIoApiCoreV1Affinity + */ + podAntiAffinity?: K8sIoApiCoreV1PodAntiAffinity; +} +/** + * AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + * @export + * @interface K8sIoApiCoreV1AzureDiskVolumeSource + */ +export interface K8sIoApiCoreV1AzureDiskVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + diskName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + diskURI?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + cachingMode?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureDiskVolumeSource + */ + kind?: string; +} +/** + * AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + * @export + * @interface K8sIoApiCoreV1AzureFileVolumeSource + */ +export interface K8sIoApiCoreV1AzureFileVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureFileVolumeSource + */ + secretName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1AzureFileVolumeSource + */ + shareName?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1AzureFileVolumeSource + */ + readOnly?: boolean; +} +/** + * + * @export + * @interface K8sIoApiCoreV1CSIVolumeSource + */ +export interface K8sIoApiCoreV1CSIVolumeSource { + /** + * Driver is the name of the CSI driver that handles this volume. Consult with your admin for the correct name as registered in the cluster. + * @type {string} + * @memberof K8sIoApiCoreV1CSIVolumeSource + */ + driver?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1CSIVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CSIVolumeSource + */ + fsType?: string; + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApiCoreV1CSIVolumeSource + */ + volumeAttributes?: { [key: string]: string; }; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1CSIVolumeSource + */ + nodePublishSecretRef?: K8sIoApiCoreV1LocalObjectReference; +} +/** + * Adds and removes POSIX capabilities from running containers. + * @export + * @interface K8sIoApiCoreV1Capabilities + */ +export interface K8sIoApiCoreV1Capabilities { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Capabilities + */ + add?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Capabilities + */ + drop?: Array; +} +/** + * Represents a Ceph Filesystem mount that lasts the lifetime of a pod Cephfs volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1CephFSVolumeSource + */ +export interface K8sIoApiCoreV1CephFSVolumeSource { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + monitors?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + path?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + user?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + secretFile?: string; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1CephFSVolumeSource + */ + readOnly?: boolean; +} +/** + * Represents a cinder volume resource in Openstack. A Cinder volume must exist before mounting to a container. The volume must also be in the same region as the kubelet. Cinder volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1CinderVolumeSource + */ +export interface K8sIoApiCoreV1CinderVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CinderVolumeSource + */ + volumeID?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1CinderVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1CinderVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1CinderVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; +} +/** + * ConfigMapEnvSource selects a ConfigMap to populate the environment variables with. The contents of the target ConfigMap's Data field will represent the key-value pairs as environment variables. + * @export + * @interface K8sIoApiCoreV1ConfigMapEnvSource + */ +export interface K8sIoApiCoreV1ConfigMapEnvSource { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ConfigMapEnvSource + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ConfigMapEnvSource + */ + optional?: boolean; +} +/** + * Selects a key from a ConfigMap. + * @export + * @interface K8sIoApiCoreV1ConfigMapKeySelector + */ +export interface K8sIoApiCoreV1ConfigMapKeySelector { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ConfigMapKeySelector + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * The key to select. + * @type {string} + * @memberof K8sIoApiCoreV1ConfigMapKeySelector + */ + key?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ConfigMapKeySelector + */ + optional?: boolean; +} +/** + * Adapts a ConfigMap into a projected volume. The contents of the target ConfigMap's Data field will be presented in a projected volume as files using the keys in the Data field as the file names, unless the items element is populated with specific mappings of keys to paths. Note that this is identical to a configmap volume source without the default mode. + * @export + * @interface K8sIoApiCoreV1ConfigMapProjection + */ +export interface K8sIoApiCoreV1ConfigMapProjection { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ConfigMapProjection + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1ConfigMapProjection + */ + items?: Array; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ConfigMapProjection + */ + optional?: boolean; +} +/** + * Adapts a ConfigMap into a volume. The contents of the target ConfigMap's Data field will be presented in a volume as files using the keys in the Data field as the file names, unless the items element is populated with specific mappings of keys to paths. ConfigMap volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1ConfigMapVolumeSource + */ +export interface K8sIoApiCoreV1ConfigMapVolumeSource { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ConfigMapVolumeSource + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1ConfigMapVolumeSource + */ + items?: Array; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1ConfigMapVolumeSource + */ + defaultMode?: number; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ConfigMapVolumeSource + */ + optional?: boolean; +} +/** + * A single application container that you want to run within a pod. + * @export + * @interface K8sIoApiCoreV1Container + */ +export interface K8sIoApiCoreV1Container { + /** + * Name of the container specified as a DNS_LABEL. Each container in a pod must have a unique name (DNS_LABEL). Cannot be updated. + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + image?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + command?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + args?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + workingDir?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + ports?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + envFrom?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + env?: Array; + /** + * + * @type {K8sIoApiCoreV1ResourceRequirements} + * @memberof K8sIoApiCoreV1Container + */ + resources?: K8sIoApiCoreV1ResourceRequirements; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + volumeMounts?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1Container + */ + volumeDevices?: Array; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1Container + */ + livenessProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1Container + */ + readinessProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1Container + */ + startupProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Lifecycle} + * @memberof K8sIoApiCoreV1Container + */ + lifecycle?: K8sIoApiCoreV1Lifecycle; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + terminationMessagePath?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + terminationMessagePolicy?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Container + */ + imagePullPolicy?: string; + /** + * + * @type {K8sIoApiCoreV1SecurityContext} + * @memberof K8sIoApiCoreV1Container + */ + securityContext?: K8sIoApiCoreV1SecurityContext; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1Container + */ + stdin?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1Container + */ + stdinOnce?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1Container + */ + tty?: boolean; +} +/** + * ContainerPort represents a network port in a single container. + * @export + * @interface K8sIoApiCoreV1ContainerPort + */ +export interface K8sIoApiCoreV1ContainerPort { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ContainerPort + */ + name?: string; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1ContainerPort + */ + hostPort?: number; + /** + * Number of port to expose on the pod's IP address. This must be a valid port number, 0 < x < 65536. + * @type {number} + * @memberof K8sIoApiCoreV1ContainerPort + */ + containerPort?: number; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ContainerPort + */ + protocol?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ContainerPort + */ + hostIP?: string; +} +/** + * Represents downward API info for projecting into a projected volume. Note that this is identical to a downwardAPI volume source without the default mode. + * @export + * @interface K8sIoApiCoreV1DownwardAPIProjection + */ +export interface K8sIoApiCoreV1DownwardAPIProjection { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1DownwardAPIProjection + */ + items?: Array; +} +/** + * + * @export + * @interface K8sIoApiCoreV1DownwardAPIVolumeFile + */ +export interface K8sIoApiCoreV1DownwardAPIVolumeFile { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeFile + */ + path?: string; + /** + * + * @type {K8sIoApiCoreV1ObjectFieldSelector} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeFile + */ + fieldRef?: K8sIoApiCoreV1ObjectFieldSelector; + /** + * + * @type {K8sIoApiCoreV1ResourceFieldSelector} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeFile + */ + resourceFieldRef?: K8sIoApiCoreV1ResourceFieldSelector; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeFile + */ + mode?: number; +} +/** + * DownwardAPIVolumeSource represents a volume containing downward API info. Downward API volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1DownwardAPIVolumeSource + */ +export interface K8sIoApiCoreV1DownwardAPIVolumeSource { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeSource + */ + items?: Array; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1DownwardAPIVolumeSource + */ + defaultMode?: number; +} +/** + * Represents an empty directory for a pod. Empty directory volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1EmptyDirVolumeSource + */ +export interface K8sIoApiCoreV1EmptyDirVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EmptyDirVolumeSource + */ + medium?: string; + /** + * + * @type {K8sIoApimachineryPkgApiResourceQuantity} + * @memberof K8sIoApiCoreV1EmptyDirVolumeSource + */ + sizeLimit?: K8sIoApimachineryPkgApiResourceQuantity; +} +/** + * + * @export + * @interface K8sIoApiCoreV1EnvFromSource + */ +export interface K8sIoApiCoreV1EnvFromSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EnvFromSource + */ + prefix?: string; + /** + * + * @type {K8sIoApiCoreV1ConfigMapEnvSource} + * @memberof K8sIoApiCoreV1EnvFromSource + */ + configMapRef?: K8sIoApiCoreV1ConfigMapEnvSource; + /** + * + * @type {K8sIoApiCoreV1SecretEnvSource} + * @memberof K8sIoApiCoreV1EnvFromSource + */ + secretRef?: K8sIoApiCoreV1SecretEnvSource; +} +/** + * EnvVar represents an environment variable present in a Container. + * @export + * @interface K8sIoApiCoreV1EnvVar + */ +export interface K8sIoApiCoreV1EnvVar { + /** + * Name of the environment variable. Must be a C_IDENTIFIER. + * @type {string} + * @memberof K8sIoApiCoreV1EnvVar + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EnvVar + */ + value?: string; + /** + * + * @type {K8sIoApiCoreV1EnvVarSource} + * @memberof K8sIoApiCoreV1EnvVar + */ + valueFrom?: K8sIoApiCoreV1EnvVarSource; +} +/** + * EnvVarSource represents a source for the value of an EnvVar. + * @export + * @interface K8sIoApiCoreV1EnvVarSource + */ +export interface K8sIoApiCoreV1EnvVarSource { + /** + * + * @type {K8sIoApiCoreV1ObjectFieldSelector} + * @memberof K8sIoApiCoreV1EnvVarSource + */ + fieldRef?: K8sIoApiCoreV1ObjectFieldSelector; + /** + * + * @type {K8sIoApiCoreV1ResourceFieldSelector} + * @memberof K8sIoApiCoreV1EnvVarSource + */ + resourceFieldRef?: K8sIoApiCoreV1ResourceFieldSelector; + /** + * + * @type {K8sIoApiCoreV1ConfigMapKeySelector} + * @memberof K8sIoApiCoreV1EnvVarSource + */ + configMapKeyRef?: K8sIoApiCoreV1ConfigMapKeySelector; + /** + * + * @type {K8sIoApiCoreV1SecretKeySelector} + * @memberof K8sIoApiCoreV1EnvVarSource + */ + secretKeyRef?: K8sIoApiCoreV1SecretKeySelector; +} +/** + * An EphemeralContainer is a container that may be added temporarily to an existing pod for user-initiated activities such as debugging. Ephemeral containers have no resource or scheduling guarantees, and they will not be restarted when they exit or when a pod is removed or restarted. If an ephemeral container causes a pod to exceed its resource allocation, the pod may be evicted. Ephemeral containers may not be added by directly updating the pod spec. They must be added via the pod's ephemeralcontainers subresource, and they will appear in the pod spec once added. This is an alpha feature enabled by the EphemeralContainers feature flag. + * @export + * @interface K8sIoApiCoreV1EphemeralContainer + */ +export interface K8sIoApiCoreV1EphemeralContainer { + /** + * + * @type {K8sIoApiCoreV1EphemeralContainerCommon} + * @memberof K8sIoApiCoreV1EphemeralContainer + */ + ephemeralContainerCommon?: K8sIoApiCoreV1EphemeralContainerCommon; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainer + */ + targetContainerName?: string; +} +/** + * EphemeralContainerCommon is a copy of all fields in Container to be inlined in EphemeralContainer. This separate type allows easy conversion from EphemeralContainer to Container and allows separate documentation for the fields of EphemeralContainer. When a new field is added to Container it must be added here as well. + * @export + * @interface K8sIoApiCoreV1EphemeralContainerCommon + */ +export interface K8sIoApiCoreV1EphemeralContainerCommon { + /** + * Name of the ephemeral container specified as a DNS_LABEL. This name must be unique among all containers, init containers and ephemeral containers. + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + image?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + command?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + args?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + workingDir?: string; + /** + * Ports are not allowed for ephemeral containers. + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + ports?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + envFrom?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + env?: Array; + /** + * + * @type {K8sIoApiCoreV1ResourceRequirements} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + resources?: K8sIoApiCoreV1ResourceRequirements; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + volumeMounts?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + volumeDevices?: Array; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + livenessProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + readinessProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Probe} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + startupProbe?: K8sIoApiCoreV1Probe; + /** + * + * @type {K8sIoApiCoreV1Lifecycle} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + lifecycle?: K8sIoApiCoreV1Lifecycle; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + terminationMessagePath?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + terminationMessagePolicy?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + imagePullPolicy?: string; + /** + * + * @type {K8sIoApiCoreV1SecurityContext} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + securityContext?: K8sIoApiCoreV1SecurityContext; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + stdin?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + stdinOnce?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1EphemeralContainerCommon + */ + tty?: boolean; +} +/** + * Represents an ephemeral volume that is handled by a normal storage driver. + * @export + * @interface K8sIoApiCoreV1EphemeralVolumeSource + */ +export interface K8sIoApiCoreV1EphemeralVolumeSource { + /** + * + * @type {K8sIoApiCoreV1PersistentVolumeClaimTemplate} + * @memberof K8sIoApiCoreV1EphemeralVolumeSource + */ + volumeClaimTemplate?: K8sIoApiCoreV1PersistentVolumeClaimTemplate; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1EphemeralVolumeSource + */ + readOnly?: boolean; +} +/** + * ExecAction describes a \"run in container\" action. + * @export + * @interface K8sIoApiCoreV1ExecAction + */ +export interface K8sIoApiCoreV1ExecAction { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1ExecAction + */ + command?: Array; +} +/** + * Represents a Fibre Channel volume. Fibre Channel volumes can only be mounted as read/write once. Fibre Channel volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1FCVolumeSource + */ +export interface K8sIoApiCoreV1FCVolumeSource { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1FCVolumeSource + */ + targetWWNs?: Array; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1FCVolumeSource + */ + lun?: number; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1FCVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1FCVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1FCVolumeSource + */ + wwids?: Array; +} +/** + * FlexVolume represents a generic volume resource that is provisioned/attached using an exec based plugin. + * @export + * @interface K8sIoApiCoreV1FlexVolumeSource + */ +export interface K8sIoApiCoreV1FlexVolumeSource { + /** + * Driver is the name of the driver to use for this volume. + * @type {string} + * @memberof K8sIoApiCoreV1FlexVolumeSource + */ + driver?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1FlexVolumeSource + */ + fsType?: string; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1FlexVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1FlexVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApiCoreV1FlexVolumeSource + */ + options?: { [key: string]: string; }; +} +/** + * Represents a Flocker volume mounted by the Flocker agent. One and only one of datasetName and datasetUUID should be set. Flocker volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1FlockerVolumeSource + */ +export interface K8sIoApiCoreV1FlockerVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1FlockerVolumeSource + */ + datasetName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1FlockerVolumeSource + */ + datasetUUID?: string; +} +/** + * Represents a Persistent Disk resource in Google Compute Engine. A GCE PD must exist before mounting to a container. The disk must also be in the same GCE project and zone as the kubelet. A GCE PD can only be mounted as read/write once or read-only many times. GCE PDs support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1GCEPersistentDiskVolumeSource + */ +export interface K8sIoApiCoreV1GCEPersistentDiskVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GCEPersistentDiskVolumeSource + */ + pdName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GCEPersistentDiskVolumeSource + */ + fsType?: string; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1GCEPersistentDiskVolumeSource + */ + partition?: number; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1GCEPersistentDiskVolumeSource + */ + readOnly?: boolean; +} +/** + * Represents a volume that is populated with the contents of a git repository. Git repo volumes do not support ownership management. Git repo volumes support SELinux relabeling. DEPRECATED: GitRepo is deprecated. To provision a container with a git repo, mount an EmptyDir into an InitContainer that clones the repo using git, then mount the EmptyDir into the Pod's container. + * @export + * @interface K8sIoApiCoreV1GitRepoVolumeSource + */ +export interface K8sIoApiCoreV1GitRepoVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GitRepoVolumeSource + */ + repository?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GitRepoVolumeSource + */ + revision?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GitRepoVolumeSource + */ + directory?: string; +} +/** + * Represents a Glusterfs mount that lasts the lifetime of a pod. Glusterfs volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1GlusterfsVolumeSource + */ +export interface K8sIoApiCoreV1GlusterfsVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GlusterfsVolumeSource + */ + endpoints?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1GlusterfsVolumeSource + */ + path?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1GlusterfsVolumeSource + */ + readOnly?: boolean; +} +/** + * HTTPGetAction describes an action based on HTTP Get requests. + * @export + * @interface K8sIoApiCoreV1HTTPGetAction + */ +export interface K8sIoApiCoreV1HTTPGetAction { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HTTPGetAction + */ + path?: string; + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof K8sIoApiCoreV1HTTPGetAction + */ + port?: K8sIoApimachineryPkgUtilIntstrIntOrString; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HTTPGetAction + */ + host?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HTTPGetAction + */ + scheme?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1HTTPGetAction + */ + httpHeaders?: Array; +} +/** + * + * @export + * @interface K8sIoApiCoreV1HTTPHeader + */ +export interface K8sIoApiCoreV1HTTPHeader { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HTTPHeader + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HTTPHeader + */ + value?: string; +} +/** + * Handler defines a specific action that should be taken TODO: pass structured data to these actions, and document that data here. + * @export + * @interface K8sIoApiCoreV1Handler + */ +export interface K8sIoApiCoreV1Handler { + /** + * + * @type {K8sIoApiCoreV1ExecAction} + * @memberof K8sIoApiCoreV1Handler + */ + exec?: K8sIoApiCoreV1ExecAction; + /** + * + * @type {K8sIoApiCoreV1HTTPGetAction} + * @memberof K8sIoApiCoreV1Handler + */ + httpGet?: K8sIoApiCoreV1HTTPGetAction; + /** + * + * @type {K8sIoApiCoreV1TCPSocketAction} + * @memberof K8sIoApiCoreV1Handler + */ + tcpSocket?: K8sIoApiCoreV1TCPSocketAction; +} +/** + * HostAlias holds the mapping between IP and hostnames that will be injected as an entry in the pod's hosts file. + * @export + * @interface K8sIoApiCoreV1HostAlias + */ +export interface K8sIoApiCoreV1HostAlias { + /** + * IP address of the host file entry. + * @type {string} + * @memberof K8sIoApiCoreV1HostAlias + */ + ip?: string; + /** + * Hostnames for the above IP address. + * @type {Array} + * @memberof K8sIoApiCoreV1HostAlias + */ + hostnames?: Array; +} +/** + * Represents a host path mapped into a pod. Host path volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1HostPathVolumeSource + */ +export interface K8sIoApiCoreV1HostPathVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HostPathVolumeSource + */ + path?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1HostPathVolumeSource + */ + type?: string; +} +/** + * Represents an ISCSI disk. ISCSI volumes can only be mounted as read/write once. ISCSI volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1ISCSIVolumeSource + */ +export interface K8sIoApiCoreV1ISCSIVolumeSource { + /** + * iSCSI Target Portal. The Portal is either an IP or ip_addr:port if the port is other than default (typically TCP ports 860 and 3260). + * @type {string} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + targetPortal?: string; + /** + * Target iSCSI Qualified Name. + * @type {string} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + iqn?: string; + /** + * iSCSI Target Lun number. + * @type {number} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + lun?: number; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + iscsiInterface?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + portals?: Array; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + chapAuthDiscovery?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + chapAuthSession?: boolean; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ISCSIVolumeSource + */ + initiatorName?: string; +} +/** + * Maps a string key to a path within a volume. + * @export + * @interface K8sIoApiCoreV1KeyToPath + */ +export interface K8sIoApiCoreV1KeyToPath { + /** + * The key to project. + * @type {string} + * @memberof K8sIoApiCoreV1KeyToPath + */ + key?: string; + /** + * The relative path of the file to map the key to. May not be an absolute path. May not contain the path element '..'. May not start with the string '..'. + * @type {string} + * @memberof K8sIoApiCoreV1KeyToPath + */ + path?: string; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1KeyToPath + */ + mode?: number; +} +/** + * Lifecycle describes actions that the management system should take in response to container lifecycle events. For the PostStart and PreStop lifecycle handlers, management of the container blocks until the action is complete, unless the container process fails, in which case the handler is aborted. + * @export + * @interface K8sIoApiCoreV1Lifecycle + */ +export interface K8sIoApiCoreV1Lifecycle { + /** + * + * @type {K8sIoApiCoreV1Handler} + * @memberof K8sIoApiCoreV1Lifecycle + */ + postStart?: K8sIoApiCoreV1Handler; + /** + * + * @type {K8sIoApiCoreV1Handler} + * @memberof K8sIoApiCoreV1Lifecycle + */ + preStop?: K8sIoApiCoreV1Handler; +} +/** + * LocalObjectReference contains enough information to let you locate the referenced object inside the same namespace. + * @export + * @interface K8sIoApiCoreV1LocalObjectReference + */ +export interface K8sIoApiCoreV1LocalObjectReference { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1LocalObjectReference + */ + name?: string; +} +/** + * Represents an NFS mount that lasts the lifetime of a pod. NFS volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1NFSVolumeSource + */ +export interface K8sIoApiCoreV1NFSVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1NFSVolumeSource + */ + server?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1NFSVolumeSource + */ + path?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1NFSVolumeSource + */ + readOnly?: boolean; +} +/** + * Node affinity is a group of node affinity scheduling rules. + * @export + * @interface K8sIoApiCoreV1NodeAffinity + */ +export interface K8sIoApiCoreV1NodeAffinity { + /** + * + * @type {K8sIoApiCoreV1NodeSelector} + * @memberof K8sIoApiCoreV1NodeAffinity + */ + requiredDuringSchedulingIgnoredDuringExecution?: K8sIoApiCoreV1NodeSelector; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1NodeAffinity + */ + preferredDuringSchedulingIgnoredDuringExecution?: Array; +} +/** + * A node selector represents the union of the results of one or more label queries over a set of nodes; that is, it represents the OR of the selectors represented by the node selector terms. + * @export + * @interface K8sIoApiCoreV1NodeSelector + */ +export interface K8sIoApiCoreV1NodeSelector { + /** + * Required. A list of node selector terms. The terms are ORed. + * @type {Array} + * @memberof K8sIoApiCoreV1NodeSelector + */ + nodeSelectorTerms?: Array; +} +/** + * A node selector requirement is a selector that contains values, a key, and an operator that relates the key and values. + * @export + * @interface K8sIoApiCoreV1NodeSelectorRequirement + */ +export interface K8sIoApiCoreV1NodeSelectorRequirement { + /** + * The label key that the selector applies to. + * @type {string} + * @memberof K8sIoApiCoreV1NodeSelectorRequirement + */ + key?: string; + /** + * Represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt. + * @type {string} + * @memberof K8sIoApiCoreV1NodeSelectorRequirement + */ + operator?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1NodeSelectorRequirement + */ + values?: Array; +} +/** + * A null or empty node selector term matches no objects. The requirements of them are ANDed. The TopologySelectorTerm type implements a subset of the NodeSelectorTerm. + * @export + * @interface K8sIoApiCoreV1NodeSelectorTerm + */ +export interface K8sIoApiCoreV1NodeSelectorTerm { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1NodeSelectorTerm + */ + matchExpressions?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1NodeSelectorTerm + */ + matchFields?: Array; +} +/** + * ObjectFieldSelector selects an APIVersioned field of an object. + * @export + * @interface K8sIoApiCoreV1ObjectFieldSelector + */ +export interface K8sIoApiCoreV1ObjectFieldSelector { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ObjectFieldSelector + */ + apiVersion?: string; + /** + * Path of the field to select in the specified API version. + * @type {string} + * @memberof K8sIoApiCoreV1ObjectFieldSelector + */ + fieldPath?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1PersistentVolumeClaimSpec + */ +export interface K8sIoApiCoreV1PersistentVolumeClaimSpec { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + accessModes?: Array; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1LabelSelector} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + selector?: K8sIoApimachineryPkgApisMetaV1LabelSelector; + /** + * + * @type {K8sIoApiCoreV1ResourceRequirements} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + resources?: K8sIoApiCoreV1ResourceRequirements; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + volumeName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + storageClassName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + volumeMode?: string; + /** + * + * @type {K8sIoApiCoreV1TypedLocalObjectReference} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimSpec + */ + dataSource?: K8sIoApiCoreV1TypedLocalObjectReference; +} +/** + * PersistentVolumeClaimTemplate is used to produce PersistentVolumeClaim objects as part of an EphemeralVolumeSource. + * @export + * @interface K8sIoApiCoreV1PersistentVolumeClaimTemplate + */ +export interface K8sIoApiCoreV1PersistentVolumeClaimTemplate { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimTemplate + */ + metadata?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {K8sIoApiCoreV1PersistentVolumeClaimSpec} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimTemplate + */ + spec?: K8sIoApiCoreV1PersistentVolumeClaimSpec; +} +/** + * PersistentVolumeClaimVolumeSource references the user's PVC in the same namespace. This volume finds the bound PV and mounts that volume for the pod. A PersistentVolumeClaimVolumeSource is, essentially, a wrapper around another type of volume that is owned by someone else (the system). + * @export + * @interface K8sIoApiCoreV1PersistentVolumeClaimVolumeSource + */ +export interface K8sIoApiCoreV1PersistentVolumeClaimVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimVolumeSource + */ + claimName?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PersistentVolumeClaimVolumeSource + */ + readOnly?: boolean; +} +/** + * Represents a Photon Controller persistent disk resource. + * @export + * @interface K8sIoApiCoreV1PhotonPersistentDiskVolumeSource + */ +export interface K8sIoApiCoreV1PhotonPersistentDiskVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PhotonPersistentDiskVolumeSource + */ + pdID?: string; + /** + * Filesystem type to mount. Must be a filesystem type supported by the host operating system. Ex. \"ext4\", \"xfs\", \"ntfs\". Implicitly inferred to be \"ext4\" if unspecified. + * @type {string} + * @memberof K8sIoApiCoreV1PhotonPersistentDiskVolumeSource + */ + fsType?: string; +} +/** + * Pod affinity is a group of inter pod affinity scheduling rules. + * @export + * @interface K8sIoApiCoreV1PodAffinity + */ +export interface K8sIoApiCoreV1PodAffinity { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodAffinity + */ + requiredDuringSchedulingIgnoredDuringExecution?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodAffinity + */ + preferredDuringSchedulingIgnoredDuringExecution?: Array; +} +/** + * + * @export + * @interface K8sIoApiCoreV1PodAffinityTerm + */ +export interface K8sIoApiCoreV1PodAffinityTerm { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1LabelSelector} + * @memberof K8sIoApiCoreV1PodAffinityTerm + */ + labelSelector?: K8sIoApimachineryPkgApisMetaV1LabelSelector; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodAffinityTerm + */ + namespaces?: Array; + /** + * This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching the labelSelector in the specified namespaces, where co-located is defined as running on a node whose value of the label with key topologyKey matches that of any node on which any of the selected pods is running. Empty topologyKey is not allowed. + * @type {string} + * @memberof K8sIoApiCoreV1PodAffinityTerm + */ + topologyKey?: string; +} +/** + * Pod anti affinity is a group of inter pod anti affinity scheduling rules. + * @export + * @interface K8sIoApiCoreV1PodAntiAffinity + */ +export interface K8sIoApiCoreV1PodAntiAffinity { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodAntiAffinity + */ + requiredDuringSchedulingIgnoredDuringExecution?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodAntiAffinity + */ + preferredDuringSchedulingIgnoredDuringExecution?: Array; +} +/** + * PodDNSConfig defines the DNS parameters of a pod in addition to those generated from DNSPolicy. + * @export + * @interface K8sIoApiCoreV1PodDNSConfig + */ +export interface K8sIoApiCoreV1PodDNSConfig { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodDNSConfig + */ + nameservers?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodDNSConfig + */ + searches?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodDNSConfig + */ + options?: Array; +} +/** + * PodDNSConfigOption defines DNS resolver options of a pod. + * @export + * @interface K8sIoApiCoreV1PodDNSConfigOption + */ +export interface K8sIoApiCoreV1PodDNSConfigOption { + /** + * Required. + * @type {string} + * @memberof K8sIoApiCoreV1PodDNSConfigOption + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodDNSConfigOption + */ + value?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1PodReadinessGate + */ +export interface K8sIoApiCoreV1PodReadinessGate { + /** + * ConditionType refers to a condition in the pod's condition list with matching type. + * @type {string} + * @memberof K8sIoApiCoreV1PodReadinessGate + */ + conditionType?: string; +} +/** + * PodSecurityContext holds pod-level security attributes and common container settings. Some fields are also present in container.securityContext. Field values of container.securityContext take precedence over field values of PodSecurityContext. + * @export + * @interface K8sIoApiCoreV1PodSecurityContext + */ +export interface K8sIoApiCoreV1PodSecurityContext { + /** + * + * @type {K8sIoApiCoreV1SELinuxOptions} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + seLinuxOptions?: K8sIoApiCoreV1SELinuxOptions; + /** + * + * @type {K8sIoApiCoreV1WindowsSecurityContextOptions} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + windowsOptions?: K8sIoApiCoreV1WindowsSecurityContextOptions; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + runAsUser?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + runAsGroup?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + runAsNonRoot?: boolean; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + supplementalGroups?: Array; + /** + * 1. The owning GID will be the FSGroup 2. The setgid bit is set (new files created in the volume will be owned by FSGroup) 3. The permission bits are OR'd with rw-rw---- If unset, the Kubelet will not modify the ownership and permissions of any volume. +optional + * @type {string} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + fsGroup?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + sysctls?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + fsGroupChangePolicy?: string; + /** + * + * @type {K8sIoApiCoreV1SeccompProfile} + * @memberof K8sIoApiCoreV1PodSecurityContext + */ + seccompProfile?: K8sIoApiCoreV1SeccompProfile; +} +/** + * PodSpec is a description of a pod. + * @export + * @interface K8sIoApiCoreV1PodSpec + */ +export interface K8sIoApiCoreV1PodSpec { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + volumes?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + initContainers?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + containers?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + ephemeralContainers?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + restartPolicy?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + terminationGracePeriodSeconds?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + activeDeadlineSeconds?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + dnsPolicy?: string; + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApiCoreV1PodSpec + */ + nodeSelector?: { [key: string]: string; }; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + serviceAccountName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + serviceAccount?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + automountServiceAccountToken?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + nodeName?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + hostNetwork?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + hostPID?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + hostIPC?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + shareProcessNamespace?: boolean; + /** + * + * @type {K8sIoApiCoreV1PodSecurityContext} + * @memberof K8sIoApiCoreV1PodSpec + */ + securityContext?: K8sIoApiCoreV1PodSecurityContext; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + imagePullSecrets?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + hostname?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + subdomain?: string; + /** + * + * @type {K8sIoApiCoreV1Affinity} + * @memberof K8sIoApiCoreV1PodSpec + */ + affinity?: K8sIoApiCoreV1Affinity; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + schedulerName?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + tolerations?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + hostAliases?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + priorityClassName?: string; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1PodSpec + */ + priority?: number; + /** + * + * @type {K8sIoApiCoreV1PodDNSConfig} + * @memberof K8sIoApiCoreV1PodSpec + */ + dnsConfig?: K8sIoApiCoreV1PodDNSConfig; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + readinessGates?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + runtimeClassName?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + enableServiceLinks?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PodSpec + */ + preemptionPolicy?: string; + /** + * + * @type {{ [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }} + * @memberof K8sIoApiCoreV1PodSpec + */ + overhead?: { [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1PodSpec + */ + topologySpreadConstraints?: Array; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PodSpec + */ + setHostnameAsFQDN?: boolean; +} +/** + * + * @export + * @interface K8sIoApiCoreV1PodTemplateSpec + */ +export interface K8sIoApiCoreV1PodTemplateSpec { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof K8sIoApiCoreV1PodTemplateSpec + */ + metadata?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {K8sIoApiCoreV1PodSpec} + * @memberof K8sIoApiCoreV1PodTemplateSpec + */ + spec?: K8sIoApiCoreV1PodSpec; +} +/** + * PortworxVolumeSource represents a Portworx volume resource. + * @export + * @interface K8sIoApiCoreV1PortworxVolumeSource + */ +export interface K8sIoApiCoreV1PortworxVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1PortworxVolumeSource + */ + volumeID?: string; + /** + * FSType represents the filesystem type to mount Must be a filesystem type supported by the host operating system. Ex. \"ext4\", \"xfs\". Implicitly inferred to be \"ext4\" if unspecified. + * @type {string} + * @memberof K8sIoApiCoreV1PortworxVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1PortworxVolumeSource + */ + readOnly?: boolean; +} +/** + * An empty preferred scheduling term matches all objects with implicit weight 0 (i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op). + * @export + * @interface K8sIoApiCoreV1PreferredSchedulingTerm + */ +export interface K8sIoApiCoreV1PreferredSchedulingTerm { + /** + * Weight associated with matching the corresponding nodeSelectorTerm, in the range 1-100. + * @type {number} + * @memberof K8sIoApiCoreV1PreferredSchedulingTerm + */ + weight?: number; + /** + * + * @type {K8sIoApiCoreV1NodeSelectorTerm} + * @memberof K8sIoApiCoreV1PreferredSchedulingTerm + */ + preference?: K8sIoApiCoreV1NodeSelectorTerm; +} +/** + * Probe describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic. + * @export + * @interface K8sIoApiCoreV1Probe + */ +export interface K8sIoApiCoreV1Probe { + /** + * + * @type {K8sIoApiCoreV1Handler} + * @memberof K8sIoApiCoreV1Probe + */ + handler?: K8sIoApiCoreV1Handler; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1Probe + */ + initialDelaySeconds?: number; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1Probe + */ + timeoutSeconds?: number; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1Probe + */ + periodSeconds?: number; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1Probe + */ + successThreshold?: number; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1Probe + */ + failureThreshold?: number; +} +/** + * + * @export + * @interface K8sIoApiCoreV1ProjectedVolumeSource + */ +export interface K8sIoApiCoreV1ProjectedVolumeSource { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1ProjectedVolumeSource + */ + sources?: Array; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1ProjectedVolumeSource + */ + defaultMode?: number; +} +/** + * Represents a Quobyte mount that lasts the lifetime of a pod. Quobyte volumes do not support ownership management or SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1QuobyteVolumeSource + */ +export interface K8sIoApiCoreV1QuobyteVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + registry?: string; + /** + * Volume is a string that references an already created Quobyte volume by name. + * @type {string} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + volume?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + user?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + group?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1QuobyteVolumeSource + */ + tenant?: string; +} +/** + * Represents a Rados Block Device mount that lasts the lifetime of a pod. RBD volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1RBDVolumeSource + */ +export interface K8sIoApiCoreV1RBDVolumeSource { + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + monitors?: Array; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + image?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + fsType?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + pool?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + user?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + keyring?: string; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1RBDVolumeSource + */ + readOnly?: boolean; +} +/** + * + * @export + * @interface K8sIoApiCoreV1ResourceFieldSelector + */ +export interface K8sIoApiCoreV1ResourceFieldSelector { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ResourceFieldSelector + */ + containerName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ResourceFieldSelector + */ + resource?: string; + /** + * + * @type {K8sIoApimachineryPkgApiResourceQuantity} + * @memberof K8sIoApiCoreV1ResourceFieldSelector + */ + divisor?: K8sIoApimachineryPkgApiResourceQuantity; +} +/** + * ResourceRequirements describes the compute resource requirements. + * @export + * @interface K8sIoApiCoreV1ResourceRequirements + */ +export interface K8sIoApiCoreV1ResourceRequirements { + /** + * + * @type {{ [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }} + * @memberof K8sIoApiCoreV1ResourceRequirements + */ + limits?: { [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }; + /** + * + * @type {{ [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }} + * @memberof K8sIoApiCoreV1ResourceRequirements + */ + requests?: { [key: string]: K8sIoApimachineryPkgApiResourceQuantity; }; +} +/** + * + * @export + * @interface K8sIoApiCoreV1SELinuxOptions + */ +export interface K8sIoApiCoreV1SELinuxOptions { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SELinuxOptions + */ + user?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SELinuxOptions + */ + role?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SELinuxOptions + */ + type?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SELinuxOptions + */ + level?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1ScaleIOVolumeSource + */ +export interface K8sIoApiCoreV1ScaleIOVolumeSource { + /** + * The host address of the ScaleIO API Gateway. + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + gateway?: string; + /** + * The name of the storage system as configured in ScaleIO. + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + system?: string; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + sslEnabled?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + protectionDomain?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + storagePool?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + storageMode?: string; + /** + * The name of a volume already created in the ScaleIO system that is associated with this volume source. + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + volumeName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1ScaleIOVolumeSource + */ + readOnly?: boolean; +} +/** + * + * @export + * @interface K8sIoApiCoreV1SeccompProfile + */ +export interface K8sIoApiCoreV1SeccompProfile { + /** + * Localhost - a profile defined in a file on the node should be used. RuntimeDefault - the container runtime default profile should be used. Unconfined - no profile should be applied. +unionDiscriminator + * @type {string} + * @memberof K8sIoApiCoreV1SeccompProfile + */ + type?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SeccompProfile + */ + localhostProfile?: string; +} +/** + * SecretEnvSource selects a Secret to populate the environment variables with. The contents of the target Secret's Data field will represent the key-value pairs as environment variables. + * @export + * @interface K8sIoApiCoreV1SecretEnvSource + */ +export interface K8sIoApiCoreV1SecretEnvSource { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1SecretEnvSource + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecretEnvSource + */ + optional?: boolean; +} +/** + * SecretKeySelector selects a key of a Secret. + * @export + * @interface K8sIoApiCoreV1SecretKeySelector + */ +export interface K8sIoApiCoreV1SecretKeySelector { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1SecretKeySelector + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * The key of the secret to select from. Must be a valid secret key. + * @type {string} + * @memberof K8sIoApiCoreV1SecretKeySelector + */ + key?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecretKeySelector + */ + optional?: boolean; +} +/** + * Adapts a secret into a projected volume. The contents of the target Secret's Data field will be presented in a projected volume as files using the keys in the Data field as the file names. Note that this is identical to a secret volume source without the default mode. + * @export + * @interface K8sIoApiCoreV1SecretProjection + */ +export interface K8sIoApiCoreV1SecretProjection { + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1SecretProjection + */ + localObjectReference?: K8sIoApiCoreV1LocalObjectReference; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1SecretProjection + */ + items?: Array; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecretProjection + */ + optional?: boolean; +} +/** + * Adapts a Secret into a volume. The contents of the target Secret's Data field will be presented in a volume as files using the keys in the Data field as the file names. Secret volumes support ownership management and SELinux relabeling. + * @export + * @interface K8sIoApiCoreV1SecretVolumeSource + */ +export interface K8sIoApiCoreV1SecretVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SecretVolumeSource + */ + secretName?: string; + /** + * + * @type {Array} + * @memberof K8sIoApiCoreV1SecretVolumeSource + */ + items?: Array; + /** + * + * @type {number} + * @memberof K8sIoApiCoreV1SecretVolumeSource + */ + defaultMode?: number; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecretVolumeSource + */ + optional?: boolean; +} +/** + * SecurityContext holds security configuration that will be applied to a container. Some fields are present in both SecurityContext and PodSecurityContext. When both are set, the values in SecurityContext take precedence. + * @export + * @interface K8sIoApiCoreV1SecurityContext + */ +export interface K8sIoApiCoreV1SecurityContext { + /** + * + * @type {K8sIoApiCoreV1Capabilities} + * @memberof K8sIoApiCoreV1SecurityContext + */ + capabilities?: K8sIoApiCoreV1Capabilities; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecurityContext + */ + privileged?: boolean; + /** + * + * @type {K8sIoApiCoreV1SELinuxOptions} + * @memberof K8sIoApiCoreV1SecurityContext + */ + seLinuxOptions?: K8sIoApiCoreV1SELinuxOptions; + /** + * + * @type {K8sIoApiCoreV1WindowsSecurityContextOptions} + * @memberof K8sIoApiCoreV1SecurityContext + */ + windowsOptions?: K8sIoApiCoreV1WindowsSecurityContextOptions; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SecurityContext + */ + runAsUser?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SecurityContext + */ + runAsGroup?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecurityContext + */ + runAsNonRoot?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecurityContext + */ + readOnlyRootFilesystem?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1SecurityContext + */ + allowPrivilegeEscalation?: boolean; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1SecurityContext + */ + procMount?: string; + /** + * + * @type {K8sIoApiCoreV1SeccompProfile} + * @memberof K8sIoApiCoreV1SecurityContext + */ + seccompProfile?: K8sIoApiCoreV1SeccompProfile; +} +/** + * ServiceAccountTokenProjection represents a projected service account token volume. This projection can be used to insert a service account token into the pods runtime filesystem for use against APIs (Kubernetes API Server or otherwise). + * @export + * @interface K8sIoApiCoreV1ServiceAccountTokenProjection + */ +export interface K8sIoApiCoreV1ServiceAccountTokenProjection { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ServiceAccountTokenProjection + */ + audience?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1ServiceAccountTokenProjection + */ + expirationSeconds?: string; + /** + * Path is the path relative to the mount point of the file to project the token into. + * @type {string} + * @memberof K8sIoApiCoreV1ServiceAccountTokenProjection + */ + path?: string; +} +/** + * Represents a StorageOS persistent volume resource. + * @export + * @interface K8sIoApiCoreV1StorageOSVolumeSource + */ +export interface K8sIoApiCoreV1StorageOSVolumeSource { + /** + * VolumeName is the human-readable name of the StorageOS volume. Volume names are only unique within a namespace. + * @type {string} + * @memberof K8sIoApiCoreV1StorageOSVolumeSource + */ + volumeName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1StorageOSVolumeSource + */ + volumeNamespace?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1StorageOSVolumeSource + */ + fsType?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1StorageOSVolumeSource + */ + readOnly?: boolean; + /** + * + * @type {K8sIoApiCoreV1LocalObjectReference} + * @memberof K8sIoApiCoreV1StorageOSVolumeSource + */ + secretRef?: K8sIoApiCoreV1LocalObjectReference; +} +/** + * + * @export + * @interface K8sIoApiCoreV1Sysctl + */ +export interface K8sIoApiCoreV1Sysctl { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Sysctl + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Sysctl + */ + value?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1TCPSocketAction + */ +export interface K8sIoApiCoreV1TCPSocketAction { + /** + * + * @type {K8sIoApimachineryPkgUtilIntstrIntOrString} + * @memberof K8sIoApiCoreV1TCPSocketAction + */ + port?: K8sIoApimachineryPkgUtilIntstrIntOrString; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1TCPSocketAction + */ + host?: string; +} +/** + * The pod this Toleration is attached to tolerates any taint that matches the triple using the matching operator . + * @export + * @interface K8sIoApiCoreV1Toleration + */ +export interface K8sIoApiCoreV1Toleration { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Toleration + */ + key?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Toleration + */ + operator?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Toleration + */ + value?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Toleration + */ + effect?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Toleration + */ + tolerationSeconds?: string; +} +/** + * TopologySpreadConstraint specifies how to spread matching pods among the given topology. + * @export + * @interface K8sIoApiCoreV1TopologySpreadConstraint + */ +export interface K8sIoApiCoreV1TopologySpreadConstraint { + /** + * MaxSkew describes the degree to which pods may be unevenly distributed. When `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference between the number of matching pods in the target topology and the global minimum. For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same labelSelector spread as 1/1/0: +-------+-------+-------+ | zone1 | zone2 | zone3 | +-------+-------+-------+ | P | P | | +-------+-------+-------+ - if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1; scheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2) violate MaxSkew(1). - if MaxSkew is 2, incoming pod can be scheduled onto any zone. When `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence to topologies that satisfy it. It's a required field. Default value is 1 and 0 is not allowed. + * @type {number} + * @memberof K8sIoApiCoreV1TopologySpreadConstraint + */ + maxSkew?: number; + /** + * TopologyKey is the key of node labels. Nodes that have a label with this key and identical values are considered to be in the same topology. We consider each as a \"bucket\", and try to put balanced number of pods into each bucket. It's a required field. + * @type {string} + * @memberof K8sIoApiCoreV1TopologySpreadConstraint + */ + topologyKey?: string; + /** + * WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy the spread constraint. - DoNotSchedule (default) tells the scheduler not to schedule it. - ScheduleAnyway tells the scheduler to schedule the pod in any location, but giving higher precedence to topologies that would help reduce the skew. A constraint is considered \"Unsatisfiable\" for an incoming pod if and only if every possible node assigment for that pod would violate \"MaxSkew\" on some topology. For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same labelSelector spread as 3/1/1: +-------+-------+-------+ | zone1 | zone2 | zone3 | +-------+-------+-------+ | P P P | P | P | +-------+-------+-------+ If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler won't make it *more* imbalanced. It's a required field. + * @type {string} + * @memberof K8sIoApiCoreV1TopologySpreadConstraint + */ + whenUnsatisfiable?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1LabelSelector} + * @memberof K8sIoApiCoreV1TopologySpreadConstraint + */ + labelSelector?: K8sIoApimachineryPkgApisMetaV1LabelSelector; +} +/** + * TypedLocalObjectReference contains enough information to let you locate the typed referenced object inside the same namespace. + * @export + * @interface K8sIoApiCoreV1TypedLocalObjectReference + */ +export interface K8sIoApiCoreV1TypedLocalObjectReference { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1TypedLocalObjectReference + */ + apiGroup?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1TypedLocalObjectReference + */ + kind?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1TypedLocalObjectReference + */ + name?: string; +} +/** + * Volume represents a named volume in a pod that may be accessed by any container in the pod. + * @export + * @interface K8sIoApiCoreV1Volume + */ +export interface K8sIoApiCoreV1Volume { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1Volume + */ + name?: string; + /** + * + * @type {K8sIoApiCoreV1VolumeSource} + * @memberof K8sIoApiCoreV1Volume + */ + volumeSource?: K8sIoApiCoreV1VolumeSource; +} +/** + * volumeDevice describes a mapping of a raw block device within a container. + * @export + * @interface K8sIoApiCoreV1VolumeDevice + */ +export interface K8sIoApiCoreV1VolumeDevice { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VolumeDevice + */ + name?: string; + /** + * devicePath is the path inside of the container that the device will be mapped to. + * @type {string} + * @memberof K8sIoApiCoreV1VolumeDevice + */ + devicePath?: string; +} +/** + * VolumeMount describes a mounting of a Volume within a container. + * @export + * @interface K8sIoApiCoreV1VolumeMount + */ +export interface K8sIoApiCoreV1VolumeMount { + /** + * This must match the Name of a Volume. + * @type {string} + * @memberof K8sIoApiCoreV1VolumeMount + */ + name?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApiCoreV1VolumeMount + */ + readOnly?: boolean; + /** + * Path within the container at which the volume should be mounted. Must not contain ':'. + * @type {string} + * @memberof K8sIoApiCoreV1VolumeMount + */ + mountPath?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VolumeMount + */ + subPath?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VolumeMount + */ + mountPropagation?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VolumeMount + */ + subPathExpr?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1VolumeProjection + */ +export interface K8sIoApiCoreV1VolumeProjection { + /** + * + * @type {K8sIoApiCoreV1SecretProjection} + * @memberof K8sIoApiCoreV1VolumeProjection + */ + secret?: K8sIoApiCoreV1SecretProjection; + /** + * + * @type {K8sIoApiCoreV1DownwardAPIProjection} + * @memberof K8sIoApiCoreV1VolumeProjection + */ + downwardAPI?: K8sIoApiCoreV1DownwardAPIProjection; + /** + * + * @type {K8sIoApiCoreV1ConfigMapProjection} + * @memberof K8sIoApiCoreV1VolumeProjection + */ + configMap?: K8sIoApiCoreV1ConfigMapProjection; + /** + * + * @type {K8sIoApiCoreV1ServiceAccountTokenProjection} + * @memberof K8sIoApiCoreV1VolumeProjection + */ + serviceAccountToken?: K8sIoApiCoreV1ServiceAccountTokenProjection; +} +/** + * Represents the source of a volume to mount. Only one of its members may be specified. + * @export + * @interface K8sIoApiCoreV1VolumeSource + */ +export interface K8sIoApiCoreV1VolumeSource { + /** + * + * @type {K8sIoApiCoreV1HostPathVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + hostPath?: K8sIoApiCoreV1HostPathVolumeSource; + /** + * + * @type {K8sIoApiCoreV1EmptyDirVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + emptyDir?: K8sIoApiCoreV1EmptyDirVolumeSource; + /** + * + * @type {K8sIoApiCoreV1GCEPersistentDiskVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + gcePersistentDisk?: K8sIoApiCoreV1GCEPersistentDiskVolumeSource; + /** + * + * @type {K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + awsElasticBlockStore?: K8sIoApiCoreV1AWSElasticBlockStoreVolumeSource; + /** + * + * @type {K8sIoApiCoreV1GitRepoVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + gitRepo?: K8sIoApiCoreV1GitRepoVolumeSource; + /** + * + * @type {K8sIoApiCoreV1SecretVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + secret?: K8sIoApiCoreV1SecretVolumeSource; + /** + * + * @type {K8sIoApiCoreV1NFSVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + nfs?: K8sIoApiCoreV1NFSVolumeSource; + /** + * + * @type {K8sIoApiCoreV1ISCSIVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + iscsi?: K8sIoApiCoreV1ISCSIVolumeSource; + /** + * + * @type {K8sIoApiCoreV1GlusterfsVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + glusterfs?: K8sIoApiCoreV1GlusterfsVolumeSource; + /** + * + * @type {K8sIoApiCoreV1PersistentVolumeClaimVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + persistentVolumeClaim?: K8sIoApiCoreV1PersistentVolumeClaimVolumeSource; + /** + * + * @type {K8sIoApiCoreV1RBDVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + rbd?: K8sIoApiCoreV1RBDVolumeSource; + /** + * + * @type {K8sIoApiCoreV1FlexVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + flexVolume?: K8sIoApiCoreV1FlexVolumeSource; + /** + * + * @type {K8sIoApiCoreV1CinderVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + cinder?: K8sIoApiCoreV1CinderVolumeSource; + /** + * + * @type {K8sIoApiCoreV1CephFSVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + cephfs?: K8sIoApiCoreV1CephFSVolumeSource; + /** + * + * @type {K8sIoApiCoreV1FlockerVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + flocker?: K8sIoApiCoreV1FlockerVolumeSource; + /** + * + * @type {K8sIoApiCoreV1DownwardAPIVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + downwardAPI?: K8sIoApiCoreV1DownwardAPIVolumeSource; + /** + * + * @type {K8sIoApiCoreV1FCVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + fc?: K8sIoApiCoreV1FCVolumeSource; + /** + * + * @type {K8sIoApiCoreV1AzureFileVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + azureFile?: K8sIoApiCoreV1AzureFileVolumeSource; + /** + * + * @type {K8sIoApiCoreV1ConfigMapVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + configMap?: K8sIoApiCoreV1ConfigMapVolumeSource; + /** + * + * @type {K8sIoApiCoreV1VsphereVirtualDiskVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + vsphereVolume?: K8sIoApiCoreV1VsphereVirtualDiskVolumeSource; + /** + * + * @type {K8sIoApiCoreV1QuobyteVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + quobyte?: K8sIoApiCoreV1QuobyteVolumeSource; + /** + * + * @type {K8sIoApiCoreV1AzureDiskVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + azureDisk?: K8sIoApiCoreV1AzureDiskVolumeSource; + /** + * + * @type {K8sIoApiCoreV1PhotonPersistentDiskVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + photonPersistentDisk?: K8sIoApiCoreV1PhotonPersistentDiskVolumeSource; + /** + * + * @type {K8sIoApiCoreV1ProjectedVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + projected?: K8sIoApiCoreV1ProjectedVolumeSource; + /** + * + * @type {K8sIoApiCoreV1PortworxVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + portworxVolume?: K8sIoApiCoreV1PortworxVolumeSource; + /** + * + * @type {K8sIoApiCoreV1ScaleIOVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + scaleIO?: K8sIoApiCoreV1ScaleIOVolumeSource; + /** + * + * @type {K8sIoApiCoreV1StorageOSVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + storageos?: K8sIoApiCoreV1StorageOSVolumeSource; + /** + * + * @type {K8sIoApiCoreV1CSIVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + csi?: K8sIoApiCoreV1CSIVolumeSource; + /** + * + * @type {K8sIoApiCoreV1EphemeralVolumeSource} + * @memberof K8sIoApiCoreV1VolumeSource + */ + ephemeral?: K8sIoApiCoreV1EphemeralVolumeSource; +} +/** + * Represents a vSphere volume resource. + * @export + * @interface K8sIoApiCoreV1VsphereVirtualDiskVolumeSource + */ +export interface K8sIoApiCoreV1VsphereVirtualDiskVolumeSource { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VsphereVirtualDiskVolumeSource + */ + volumePath?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VsphereVirtualDiskVolumeSource + */ + fsType?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VsphereVirtualDiskVolumeSource + */ + storagePolicyName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1VsphereVirtualDiskVolumeSource + */ + storagePolicyID?: string; +} +/** + * + * @export + * @interface K8sIoApiCoreV1WeightedPodAffinityTerm + */ +export interface K8sIoApiCoreV1WeightedPodAffinityTerm { + /** + * weight associated with matching the corresponding podAffinityTerm, in the range 1-100. + * @type {number} + * @memberof K8sIoApiCoreV1WeightedPodAffinityTerm + */ + weight?: number; + /** + * + * @type {K8sIoApiCoreV1PodAffinityTerm} + * @memberof K8sIoApiCoreV1WeightedPodAffinityTerm + */ + podAffinityTerm?: K8sIoApiCoreV1PodAffinityTerm; +} +/** + * WindowsSecurityContextOptions contain Windows-specific options and credentials. + * @export + * @interface K8sIoApiCoreV1WindowsSecurityContextOptions + */ +export interface K8sIoApiCoreV1WindowsSecurityContextOptions { + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1WindowsSecurityContextOptions + */ + gmsaCredentialSpecName?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1WindowsSecurityContextOptions + */ + gmsaCredentialSpec?: string; + /** + * + * @type {string} + * @memberof K8sIoApiCoreV1WindowsSecurityContextOptions + */ + runAsUserName?: string; +} +/** + * Quantity is a fixed-point representation of a number. It provides convenient marshaling/unmarshaling in JSON and YAML, in addition to String() and AsInt64() accessors. The serialization format is: ::= (Note that may be empty, from the \"\" case in .) ::= 0 | 1 | ... | 9 ::= | ::= | . | . | . ::= \"+\" | \"-\" ::= | ::= | | ::= Ki | Mi | Gi | Ti | Pi | Ei (International System of units; See: http://physics.nist.gov/cuu/Units/binary.html) ::= m | \"\" | k | M | G | T | P | E (Note that 1024 = 1Ki but 1000 = 1k; I didn't choose the capitalization.) ::= \"e\" | \"E\" No matter which of the three exponent forms is used, no quantity may represent a number greater than 2^63-1 in magnitude, nor may it have more than 3 decimal places. Numbers larger or more precise will be capped or rounded up. (E.g.: 0.1m will rounded up to 1m.) This may be extended in the future if we require larger or smaller quantities. When a Quantity is parsed from a string, it will remember the type of suffix it had, and will use the same type again when it is serialized. Before serializing, Quantity will be put in \"canonical form\". This means that Exponent/suffix will be adjusted up or down (with a corresponding increase or decrease in Mantissa) such that: a. No precision is lost b. No fractional digits will be emitted c. The exponent (or suffix) is as large as possible. The sign will be omitted unless the number is negative. Examples: 1.5 will be serialized as \"1500m\" 1.5Gi will be serialized as \"1536Mi\" Note that the quantity will NEVER be internally represented by a floating point number. That is the whole point of this exercise. Non-canonical values will still parse as long as they are well formed, but will be re-emitted in their canonical form. (So always use canonical form, or don't diff.) This format is intended to make it difficult to use these numbers without writing some sort of special handling code in the hopes that that will cause implementors to also use a fixed point implementation. +protobuf=true +protobuf.embed=string +protobuf.options.marshal=false +protobuf.options.(gogoproto.goproto_stringer)=false +k8s:deepcopy-gen=true +k8s:openapi-gen=true + * @export + * @interface K8sIoApimachineryPkgApiResourceQuantity + */ +export interface K8sIoApimachineryPkgApiResourceQuantity { + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApiResourceQuantity + */ + string?: string; +} +/** + * FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format. Each key is either a '.' representing the field itself, and will always map to an empty set, or a string representing a sub-field or item. The string will follow one of these four formats: 'f:', where is the name of a field in a struct, or key in a map 'v:', where is the exact json formatted value of a list item 'i:', where is position of a item in a list 'k:', where is a map of a list item's key fields to their unique values If a key maps to an empty Fields value, the field that key represents is part of the set. The exact format is defined in sigs.k8s.io/structured-merge-diff +protobuf.options.(gogoproto.goproto_stringer)=false + * @export + * @interface K8sIoApimachineryPkgApisMetaV1FieldsV1 + */ +export interface K8sIoApimachineryPkgApisMetaV1FieldsV1 { + /** + * Raw is the underlying serialization of this object. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1FieldsV1 + */ + raw?: string; +} +/** + * + * @export + * @interface K8sIoApimachineryPkgApisMetaV1LabelSelector + */ +export interface K8sIoApimachineryPkgApisMetaV1LabelSelector { + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApimachineryPkgApisMetaV1LabelSelector + */ + matchLabels?: { [key: string]: string; }; + /** + * + * @type {Array} + * @memberof K8sIoApimachineryPkgApisMetaV1LabelSelector + */ + matchExpressions?: Array; +} +/** + * A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values. + * @export + * @interface K8sIoApimachineryPkgApisMetaV1LabelSelectorRequirement + */ +export interface K8sIoApimachineryPkgApisMetaV1LabelSelectorRequirement { + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1LabelSelectorRequirement + */ + key?: string; + /** + * operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1LabelSelectorRequirement + */ + operator?: string; + /** + * + * @type {Array} + * @memberof K8sIoApimachineryPkgApisMetaV1LabelSelectorRequirement + */ + values?: Array; +} +/** + * ManagedFieldsEntry is a workflow-id, a FieldSet and the group version of the resource that the fieldset applies to. + * @export + * @interface K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ +export interface K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry { + /** + * Manager is an identifier of the workflow managing these fields. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + manager?: string; + /** + * Operation is the type of operation which lead to this ManagedFieldsEntry being created. The only valid values for this field are 'Apply' and 'Update'. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + operation?: string; + /** + * APIVersion defines the version of this resource that this field set applies to. The format is \"group/version\" just like the top-level APIVersion field. It is necessary to track the version of a field set because it cannot be automatically converted. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + apiVersion?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + time?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + fieldsType?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1FieldsV1} + * @memberof K8sIoApimachineryPkgApisMetaV1ManagedFieldsEntry + */ + fieldsV1?: K8sIoApimachineryPkgApisMetaV1FieldsV1; +} +/** + * ObjectMeta is metadata that all persisted resources must have, which includes all objects users must create. + * @export + * @interface K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ +export interface K8sIoApimachineryPkgApisMetaV1ObjectMeta { + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + name?: string; + /** + * GenerateName is an optional prefix, used by the server, to generate a unique name ONLY IF the Name field has not been provided. If this field is used, the name returned to the client will be different than the name passed. This value will also be combined with a unique suffix. The provided value has the same validation rules as the Name field, and may be truncated by the length of the suffix required to make the value unique on the server. If this field is specified and the generated name exists, the server will NOT return a 409 - instead, it will either return 201 Created or 500 with Reason ServerTimeout indicating a unique name could not be found in the time allotted, and the client should retry (optionally after the time indicated in the Retry-After header). Applied only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency +optional + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + generateName?: string; + /** + * Namespace defines the space within which each name must be unique. An empty namespace is equivalent to the \"default\" namespace, but \"default\" is the canonical representation. Not all objects are required to be scoped to a namespace - the value of this field for those objects will be empty. Must be a DNS_LABEL. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/namespaces +optional + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + namespace?: string; + /** + * SelfLink is a URL representing this object. Populated by the system. Read-only. DEPRECATED Kubernetes will stop propagating this field in 1.20 release and the field is planned to be removed in 1.21 release. +optional + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + selfLink?: string; + /** + * UID is the unique in time and space value for this object. It is typically generated by the server on successful creation of a resource and is not allowed to change on PUT operations. Populated by the system. Read-only. More info: http://kubernetes.io/docs/user-guide/identifiers#uids +optional + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + uid?: string; + /** + * An opaque value that represents the internal version of this object that can be used by clients to determine when objects have changed. May be used for optimistic concurrency, change detection, and the watch operation on a resource or set of resources. Clients must treat these values as opaque and passed unmodified back to the server. They may only be valid for a particular resource or set of resources. Populated by the system. Read-only. Value must be treated as opaque by clients and . More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency +optional + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + resourceVersion?: string; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + generation?: string; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + creationTimestamp?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1Time} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + deletionTimestamp?: K8sIoApimachineryPkgApisMetaV1Time; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + deletionGracePeriodSeconds?: string; + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + labels?: { [key: string]: string; }; + /** + * + * @type {{ [key: string]: string; }} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + annotations?: { [key: string]: string; }; + /** + * + * @type {Array} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + ownerReferences?: Array; + /** + * + * @type {Array} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + finalizers?: Array; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + clusterName?: string; + /** + * ManagedFields maps workflow-id and version to the set of fields that are managed by that workflow. This is mostly for internal housekeeping, and users typically shouldn't need to set or understand this field. A workflow can be the user's name, a controller's name, or the name of a specific apply path like \"ci-cd\". The set of fields is always in the version that the workflow used when modifying the object. +optional + * @type {Array} + * @memberof K8sIoApimachineryPkgApisMetaV1ObjectMeta + */ + managedFields?: Array; +} +/** + * OwnerReference contains enough information to let you identify an owning object. An owning object must be in the same namespace as the dependent, or be cluster-scoped, so there is no namespace field. + * @export + * @interface K8sIoApimachineryPkgApisMetaV1OwnerReference + */ +export interface K8sIoApimachineryPkgApisMetaV1OwnerReference { + /** + * API version of the referent. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + apiVersion?: string; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + kind?: string; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + name?: string; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + uid?: string; + /** + * + * @type {boolean} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + controller?: boolean; + /** + * + * @type {boolean} + * @memberof K8sIoApimachineryPkgApisMetaV1OwnerReference + */ + blockOwnerDeletion?: boolean; +} +/** + * Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers. +protobuf.options.marshal=false +protobuf.as=Timestamp +protobuf.options.(gogoproto.goproto_stringer)=false + * @export + * @interface K8sIoApimachineryPkgApisMetaV1Time + */ +export interface K8sIoApimachineryPkgApisMetaV1Time { + /** + * Represents seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive. + * @type {string} + * @memberof K8sIoApimachineryPkgApisMetaV1Time + */ + seconds?: string; + /** + * Non-negative fractions of a second at nanosecond resolution. Negative second values with fractions must still have non-negative nanos values that count forward in time. Must be from 0 to 999,999,999 inclusive. This field may be limited in precision depending on context. + * @type {number} + * @memberof K8sIoApimachineryPkgApisMetaV1Time + */ + nanos?: number; +} +/** + * +protobuf=true +protobuf.options.(gogoproto.goproto_stringer)=false +k8s:openapi-gen=true + * @export + * @interface K8sIoApimachineryPkgUtilIntstrIntOrString + */ +export interface K8sIoApimachineryPkgUtilIntstrIntOrString { + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgUtilIntstrIntOrString + */ + type?: string; + /** + * + * @type {number} + * @memberof K8sIoApimachineryPkgUtilIntstrIntOrString + */ + intVal?: number; + /** + * + * @type {string} + * @memberof K8sIoApimachineryPkgUtilIntstrIntOrString + */ + strVal?: string; +} +/** + * + * @export + * @interface RolloutAbortRolloutRequest + */ +export interface RolloutAbortRolloutRequest { + /** + * + * @type {string} + * @memberof RolloutAbortRolloutRequest + */ + name?: string; + /** + * + * @type {string} + * @memberof RolloutAbortRolloutRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutAnalysisRunInfo + */ +export interface RolloutAnalysisRunInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutAnalysisRunInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutAnalysisRunInfo + */ + icon?: string; + /** + * + * @type {number} + * @memberof RolloutAnalysisRunInfo + */ + revision?: number; + /** + * + * @type {string} + * @memberof RolloutAnalysisRunInfo + */ + status?: string; + /** + * + * @type {number} + * @memberof RolloutAnalysisRunInfo + */ + successful?: number; + /** + * + * @type {number} + * @memberof RolloutAnalysisRunInfo + */ + failed?: number; + /** + * + * @type {number} + * @memberof RolloutAnalysisRunInfo + */ + inconclusive?: number; + /** + * + * @type {number} + * @memberof RolloutAnalysisRunInfo + */ + error?: number; + /** + * + * @type {Array} + * @memberof RolloutAnalysisRunInfo + */ + jobs?: Array; +} +/** + * + * @export + * @interface RolloutContainerInfo + */ +export interface RolloutContainerInfo { + /** + * + * @type {string} + * @memberof RolloutContainerInfo + */ + name?: string; + /** + * + * @type {string} + * @memberof RolloutContainerInfo + */ + image?: string; +} +/** + * + * @export + * @interface RolloutExperimentInfo + */ +export interface RolloutExperimentInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutExperimentInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutExperimentInfo + */ + icon?: string; + /** + * + * @type {number} + * @memberof RolloutExperimentInfo + */ + revision?: number; + /** + * + * @type {string} + * @memberof RolloutExperimentInfo + */ + status?: string; + /** + * + * @type {string} + * @memberof RolloutExperimentInfo + */ + message?: string; + /** + * + * @type {Array} + * @memberof RolloutExperimentInfo + */ + replicaSets?: Array; + /** + * + * @type {Array} + * @memberof RolloutExperimentInfo + */ + analysisRuns?: Array; +} +/** + * + * @export + * @interface RolloutJobInfo + */ +export interface RolloutJobInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutJobInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutJobInfo + */ + status?: string; + /** + * + * @type {string} + * @memberof RolloutJobInfo + */ + icon?: string; +} +/** + * + * @export + * @interface RolloutNamespaceInfo + */ +export interface RolloutNamespaceInfo { + /** + * + * @type {string} + * @memberof RolloutNamespaceInfo + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutPodInfo + */ +export interface RolloutPodInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutPodInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutPodInfo + */ + status?: string; + /** + * + * @type {string} + * @memberof RolloutPodInfo + */ + icon?: string; + /** + * + * @type {string} + * @memberof RolloutPodInfo + */ + ready?: string; + /** + * + * @type {number} + * @memberof RolloutPodInfo + */ + restarts?: number; +} +/** + * + * @export + * @interface RolloutPromoteRolloutRequest + */ +export interface RolloutPromoteRolloutRequest { + /** + * + * @type {string} + * @memberof RolloutPromoteRolloutRequest + */ + name?: string; + /** + * + * @type {string} + * @memberof RolloutPromoteRolloutRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutReplicaSetInfo + */ +export interface RolloutReplicaSetInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutReplicaSetInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutReplicaSetInfo + */ + status?: string; + /** + * + * @type {string} + * @memberof RolloutReplicaSetInfo + */ + icon?: string; + /** + * + * @type {number} + * @memberof RolloutReplicaSetInfo + */ + revision?: number; + /** + * + * @type {boolean} + * @memberof RolloutReplicaSetInfo + */ + stable?: boolean; + /** + * + * @type {boolean} + * @memberof RolloutReplicaSetInfo + */ + canary?: boolean; + /** + * + * @type {boolean} + * @memberof RolloutReplicaSetInfo + */ + active?: boolean; + /** + * + * @type {boolean} + * @memberof RolloutReplicaSetInfo + */ + preview?: boolean; + /** + * + * @type {number} + * @memberof RolloutReplicaSetInfo + */ + replicas?: number; + /** + * + * @type {number} + * @memberof RolloutReplicaSetInfo + */ + available?: number; + /** + * + * @type {string} + * @memberof RolloutReplicaSetInfo + */ + template?: string; + /** + * + * @type {string} + * @memberof RolloutReplicaSetInfo + */ + scaleDownDeadline?: string; + /** + * + * @type {Array} + * @memberof RolloutReplicaSetInfo + */ + images?: Array; + /** + * + * @type {Array} + * @memberof RolloutReplicaSetInfo + */ + pods?: Array; +} +/** + * + * @export + * @interface RolloutRestartRolloutRequest + */ +export interface RolloutRestartRolloutRequest { + /** + * + * @type {string} + * @memberof RolloutRestartRolloutRequest + */ + name?: string; + /** + * + * @type {string} + * @memberof RolloutRestartRolloutRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutRetryRolloutRequest + */ +export interface RolloutRetryRolloutRequest { + /** + * + * @type {string} + * @memberof RolloutRetryRolloutRequest + */ + name?: string; + /** + * + * @type {string} + * @memberof RolloutRetryRolloutRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutRolloutInfo + */ +export interface RolloutRolloutInfo { + /** + * + * @type {K8sIoApimachineryPkgApisMetaV1ObjectMeta} + * @memberof RolloutRolloutInfo + */ + objectMeta?: K8sIoApimachineryPkgApisMetaV1ObjectMeta; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + status?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + message?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + icon?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + strategy?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + step?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + setWeight?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + actualWeight?: string; + /** + * + * @type {number} + * @memberof RolloutRolloutInfo + */ + ready?: number; + /** + * + * @type {number} + * @memberof RolloutRolloutInfo + */ + current?: number; + /** + * + * @type {number} + * @memberof RolloutRolloutInfo + */ + desired?: number; + /** + * + * @type {number} + * @memberof RolloutRolloutInfo + */ + updated?: number; + /** + * + * @type {number} + * @memberof RolloutRolloutInfo + */ + available?: number; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + restartedAt?: string; + /** + * + * @type {string} + * @memberof RolloutRolloutInfo + */ + generation?: string; + /** + * + * @type {Array} + * @memberof RolloutRolloutInfo + */ + replicaSets?: Array; + /** + * + * @type {Array} + * @memberof RolloutRolloutInfo + */ + experiments?: Array; + /** + * + * @type {Array} + * @memberof RolloutRolloutInfo + */ + analysisRuns?: Array; + /** + * + * @type {Array} + * @memberof RolloutRolloutInfo + */ + containers?: Array; + /** + * + * @type {Array} + * @memberof RolloutRolloutInfo + */ + steps?: Array; +} +/** + * + * @export + * @interface RolloutRolloutInfoList + */ +export interface RolloutRolloutInfoList { + /** + * + * @type {Array} + * @memberof RolloutRolloutInfoList + */ + rollouts?: Array; +} +/** + * + * @export + * @interface RolloutRolloutWatchEvent + */ +export interface RolloutRolloutWatchEvent { + /** + * + * @type {string} + * @memberof RolloutRolloutWatchEvent + */ + type?: string; + /** + * + * @type {RolloutRolloutInfo} + * @memberof RolloutRolloutWatchEvent + */ + rolloutInfo?: RolloutRolloutInfo; +} +/** + * + * @export + * @interface RolloutSetImageRequest + */ +export interface RolloutSetImageRequest { + /** + * + * @type {string} + * @memberof RolloutSetImageRequest + */ + rollout?: string; + /** + * + * @type {string} + * @memberof RolloutSetImageRequest + */ + container?: string; + /** + * + * @type {string} + * @memberof RolloutSetImageRequest + */ + image?: string; + /** + * + * @type {string} + * @memberof RolloutSetImageRequest + */ + tag?: string; + /** + * + * @type {string} + * @memberof RolloutSetImageRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutUndoRolloutRequest + */ +export interface RolloutUndoRolloutRequest { + /** + * + * @type {string} + * @memberof RolloutUndoRolloutRequest + */ + rollout?: string; + /** + * + * @type {string} + * @memberof RolloutUndoRolloutRequest + */ + revision?: string; + /** + * + * @type {string} + * @memberof RolloutUndoRolloutRequest + */ + namespace?: string; +} +/** + * + * @export + * @interface RolloutVersionInfo + */ +export interface RolloutVersionInfo { + /** + * + * @type {string} + * @memberof RolloutVersionInfo + */ + rolloutsVersion?: string; +} +/** + * + * @export + * @interface StreamResultOfRolloutRolloutInfo + */ +export interface StreamResultOfRolloutRolloutInfo { + /** + * + * @type {RolloutRolloutInfo} + * @memberof StreamResultOfRolloutRolloutInfo + */ + result?: RolloutRolloutInfo; + /** + * + * @type {GrpcGatewayRuntimeStreamError} + * @memberof StreamResultOfRolloutRolloutInfo + */ + error?: GrpcGatewayRuntimeStreamError; +} +/** + * + * @export + * @interface StreamResultOfRolloutRolloutWatchEvent + */ +export interface StreamResultOfRolloutRolloutWatchEvent { + /** + * + * @type {RolloutRolloutWatchEvent} + * @memberof StreamResultOfRolloutRolloutWatchEvent + */ + result?: RolloutRolloutWatchEvent; + /** + * + * @type {GrpcGatewayRuntimeStreamError} + * @memberof StreamResultOfRolloutRolloutWatchEvent + */ + error?: GrpcGatewayRuntimeStreamError; +} +/** + * RolloutServiceApi - fetch parameter creator + * @export + */ +export const RolloutServiceApiFetchParamCreator = function (configuration?: Configuration) { + return { + /** + * + * @param {RolloutAbortRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceAbortRollout(body: RolloutAbortRolloutRequest, namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServiceAbortRollout.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceAbortRollout.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServiceAbortRollout.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/abort` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutAbortRolloutRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetNamespace(options: any = {}): FetchArgs { + const localVarPath = `/api/v1/namespace`; + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetRolloutInfo(namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceGetRolloutInfo.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServiceGetRolloutInfo.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/info` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceListRolloutInfos(namespace: string, options: any = {}): FetchArgs { + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceListRolloutInfos.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/info` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {RolloutPromoteRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServicePromoteRollout(body: RolloutPromoteRolloutRequest, namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServicePromoteRollout.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServicePromoteRollout.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServicePromoteRollout.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/promote` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutPromoteRolloutRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {RolloutRestartRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRestartRollout(body: RolloutRestartRolloutRequest, namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServiceRestartRollout.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceRestartRollout.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServiceRestartRollout.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/restart` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutRestartRolloutRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {RolloutRetryRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRetryRollout(body: RolloutRetryRolloutRequest, namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServiceRetryRollout.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceRetryRollout.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServiceRetryRollout.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/retry` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutRetryRolloutRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {RolloutSetImageRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} container + * @param {string} image + * @param {string} tag + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceSetRolloutImage(body: RolloutSetImageRequest, namespace: string, rollout: string, container: string, image: string, tag: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + // verify required parameter 'rollout' is not null or undefined + if (rollout === null || rollout === undefined) { + throw new RequiredError('rollout','Required parameter rollout was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + // verify required parameter 'container' is not null or undefined + if (container === null || container === undefined) { + throw new RequiredError('container','Required parameter container was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + // verify required parameter 'image' is not null or undefined + if (image === null || image === undefined) { + throw new RequiredError('image','Required parameter image was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + // verify required parameter 'tag' is not null or undefined + if (tag === null || tag === undefined) { + throw new RequiredError('tag','Required parameter tag was null or undefined when calling rolloutServiceSetRolloutImage.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{rollout}/set/{container}/{image}/{tag}` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"rollout"}}`, encodeURIComponent(String(rollout))) + .replace(`{${"container"}}`, encodeURIComponent(String(container))) + .replace(`{${"image"}}`, encodeURIComponent(String(image))) + .replace(`{${"tag"}}`, encodeURIComponent(String(tag))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutSetImageRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {RolloutUndoRolloutRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} revision + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceUndoRollout(body: RolloutUndoRolloutRequest, namespace: string, rollout: string, revision: string, options: any = {}): FetchArgs { + // verify required parameter 'body' is not null or undefined + if (body === null || body === undefined) { + throw new RequiredError('body','Required parameter body was null or undefined when calling rolloutServiceUndoRollout.'); + } + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceUndoRollout.'); + } + // verify required parameter 'rollout' is not null or undefined + if (rollout === null || rollout === undefined) { + throw new RequiredError('rollout','Required parameter rollout was null or undefined when calling rolloutServiceUndoRollout.'); + } + // verify required parameter 'revision' is not null or undefined + if (revision === null || revision === undefined) { + throw new RequiredError('revision','Required parameter revision was null or undefined when calling rolloutServiceUndoRollout.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{rollout}/undo/{revision}` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"rollout"}}`, encodeURIComponent(String(rollout))) + .replace(`{${"revision"}}`, encodeURIComponent(String(revision))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'PUT' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarHeaderParameter['Content-Type'] = 'application/json'; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + const needsSerialization = ("RolloutUndoRolloutRequest" !== "string") || localVarRequestOptions.headers['Content-Type'] === 'application/json'; + localVarRequestOptions.body = needsSerialization ? JSON.stringify(body || {}) : (body || ""); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceVersion(options: any = {}): FetchArgs { + const localVarPath = `/api/v1/version`; + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfo(namespace: string, name: string, options: any = {}): FetchArgs { + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceWatchRolloutInfo.'); + } + // verify required parameter 'name' is not null or undefined + if (name === null || name === undefined) { + throw new RequiredError('name','Required parameter name was null or undefined when calling rolloutServiceWatchRolloutInfo.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/{name}/info/watch` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))) + .replace(`{${"name"}}`, encodeURIComponent(String(name))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfos(namespace: string, options: any = {}): FetchArgs { + // verify required parameter 'namespace' is not null or undefined + if (namespace === null || namespace === undefined) { + throw new RequiredError('namespace','Required parameter namespace was null or undefined when calling rolloutServiceWatchRolloutInfos.'); + } + const localVarPath = `/api/v1/rollouts/{namespace}/info/watch` + .replace(`{${"namespace"}}`, encodeURIComponent(String(namespace))); + const localVarUrlObj = url.parse(localVarPath, true); + const localVarRequestOptions = Object.assign({ method: 'GET' }, options); + const localVarHeaderParameter = {} as any; + const localVarQueryParameter = {} as any; + + localVarUrlObj.query = Object.assign({}, localVarUrlObj.query, localVarQueryParameter, options.query); + // fix override query string Detail: https://stackoverflow.com/a/7517673/1077943 + delete localVarUrlObj.search; + localVarRequestOptions.headers = Object.assign({}, localVarHeaderParameter, options.headers); + + return { + url: url.format(localVarUrlObj), + options: localVarRequestOptions, + }; + }, + } +}; + +/** + * RolloutServiceApi - functional programming interface + * @export + */ +export const RolloutServiceApiFp = function(configuration?: Configuration) { + return { + /** + * + * @param {RolloutAbortRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceAbortRollout(body: RolloutAbortRolloutRequest, namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceAbortRollout(body, namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetNamespace(options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceGetNamespace(options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetRolloutInfo(namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceGetRolloutInfo(namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceListRolloutInfos(namespace: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceListRolloutInfos(namespace, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {RolloutPromoteRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServicePromoteRollout(body: RolloutPromoteRolloutRequest, namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServicePromoteRollout(body, namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {RolloutRestartRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRestartRollout(body: RolloutRestartRolloutRequest, namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceRestartRollout(body, namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {RolloutRetryRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRetryRollout(body: RolloutRetryRolloutRequest, namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceRetryRollout(body, namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {RolloutSetImageRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} container + * @param {string} image + * @param {string} tag + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceSetRolloutImage(body: RolloutSetImageRequest, namespace: string, rollout: string, container: string, image: string, tag: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceSetRolloutImage(body, namespace, rollout, container, image, tag, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {RolloutUndoRolloutRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} revision + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceUndoRollout(body: RolloutUndoRolloutRequest, namespace: string, rollout: string, revision: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceUndoRollout(body, namespace, rollout, revision, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceVersion(options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceVersion(options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfo(namespace: string, name: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceWatchRolloutInfo(namespace, name, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfos(namespace: string, options?: any): (fetch?: FetchAPI, basePath?: string) => Promise { + const localVarFetchArgs = RolloutServiceApiFetchParamCreator(configuration).rolloutServiceWatchRolloutInfos(namespace, options); + return (fetch: FetchAPI = portableFetch, basePath: string = BASE_PATH) => { + return fetch(basePath + localVarFetchArgs.url, localVarFetchArgs.options).then((response) => { + if (response.status >= 200 && response.status < 300) { + return response.json(); + } else { + throw response; + } + }); + }; + }, + } +}; + +/** + * RolloutServiceApi - factory interface + * @export + */ +export const RolloutServiceApiFactory = function (configuration?: Configuration, fetch?: FetchAPI, basePath?: string) { + return { + /** + * + * @param {RolloutAbortRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceAbortRollout(body: RolloutAbortRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceAbortRollout(body, namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetNamespace(options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceGetNamespace(options)(fetch, basePath); + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceGetRolloutInfo(namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceGetRolloutInfo(namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceListRolloutInfos(namespace: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceListRolloutInfos(namespace, options)(fetch, basePath); + }, + /** + * + * @param {RolloutPromoteRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServicePromoteRollout(body: RolloutPromoteRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServicePromoteRollout(body, namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {RolloutRestartRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRestartRollout(body: RolloutRestartRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceRestartRollout(body, namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {RolloutRetryRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceRetryRollout(body: RolloutRetryRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceRetryRollout(body, namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {RolloutSetImageRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} container + * @param {string} image + * @param {string} tag + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceSetRolloutImage(body: RolloutSetImageRequest, namespace: string, rollout: string, container: string, image: string, tag: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceSetRolloutImage(body, namespace, rollout, container, image, tag, options)(fetch, basePath); + }, + /** + * + * @param {RolloutUndoRolloutRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} revision + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceUndoRollout(body: RolloutUndoRolloutRequest, namespace: string, rollout: string, revision: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceUndoRollout(body, namespace, rollout, revision, options)(fetch, basePath); + }, + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceVersion(options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceVersion(options)(fetch, basePath); + }, + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfo(namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceWatchRolloutInfo(namespace, name, options)(fetch, basePath); + }, + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + */ + rolloutServiceWatchRolloutInfos(namespace: string, options?: any) { + return RolloutServiceApiFp(configuration).rolloutServiceWatchRolloutInfos(namespace, options)(fetch, basePath); + }, + }; +}; + +/** + * RolloutServiceApi - object-oriented interface + * @export + * @class RolloutServiceApi + * @extends {BaseAPI} + */ +export class RolloutServiceApi extends BaseAPI { + /** + * + * @param {RolloutAbortRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceAbortRollout(body: RolloutAbortRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceAbortRollout(body, namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceGetNamespace(options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceGetNamespace(options)(this.fetch, this.basePath); + } + + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceGetRolloutInfo(namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceGetRolloutInfo(namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceListRolloutInfos(namespace: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceListRolloutInfos(namespace, options)(this.fetch, this.basePath); + } + + /** + * + * @param {RolloutPromoteRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServicePromoteRollout(body: RolloutPromoteRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServicePromoteRollout(body, namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {RolloutRestartRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceRestartRollout(body: RolloutRestartRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceRestartRollout(body, namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {RolloutRetryRolloutRequest} body + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceRetryRollout(body: RolloutRetryRolloutRequest, namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceRetryRollout(body, namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {RolloutSetImageRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} container + * @param {string} image + * @param {string} tag + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceSetRolloutImage(body: RolloutSetImageRequest, namespace: string, rollout: string, container: string, image: string, tag: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceSetRolloutImage(body, namespace, rollout, container, image, tag, options)(this.fetch, this.basePath); + } + + /** + * + * @param {RolloutUndoRolloutRequest} body + * @param {string} namespace + * @param {string} rollout + * @param {string} revision + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceUndoRollout(body: RolloutUndoRolloutRequest, namespace: string, rollout: string, revision: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceUndoRollout(body, namespace, rollout, revision, options)(this.fetch, this.basePath); + } + + /** + * + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceVersion(options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceVersion(options)(this.fetch, this.basePath); + } + + /** + * + * @param {string} namespace + * @param {string} name + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceWatchRolloutInfo(namespace: string, name: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceWatchRolloutInfo(namespace, name, options)(this.fetch, this.basePath); + } + + /** + * + * @param {string} namespace + * @param {*} [options] Override http request option. + * @throws {RequiredError} + * @memberof RolloutServiceApi + */ + public rolloutServiceWatchRolloutInfos(namespace: string, options?: any) { + return RolloutServiceApiFp(this.configuration).rolloutServiceWatchRolloutInfos(namespace, options)(this.fetch, this.basePath); + } + +} diff --git a/ui/src/models/rollout/generated/api_test.spec.ts b/ui/src/models/rollout/generated/api_test.spec.ts new file mode 100644 index 0000000000..d6b0e0bb30 --- /dev/null +++ b/ui/src/models/rollout/generated/api_test.spec.ts @@ -0,0 +1,89 @@ +/** + * pkg/apiclient/rollout/rollout.proto + * No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) + * + * OpenAPI spec version: version not set + * + * + * NOTE: This file is auto generated by the swagger code generator program. + * https://github.com/swagger-api/swagger-codegen.git + * Do not edit the file manually. + */ + +import * as api from "./api" +import { Configuration } from "./configuration" + +const config: Configuration = {} + +describe("RolloutServiceApi", () => { + let instance: api.RolloutServiceApi + beforeEach(function() { + instance = new api.RolloutServiceApi(config) + }); + + test("rolloutServiceAbortRollout", () => { + const body: api.RolloutAbortRolloutRequest = undefined + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServiceAbortRollout(body, namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceGetNamespace", () => { + return expect(instance.rolloutServiceGetNamespace({})).resolves.toBe(null) + }) + test("rolloutServiceGetRolloutInfo", () => { + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServiceGetRolloutInfo(namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceListRolloutInfos", () => { + const namespace: string = "namespace_example" + return expect(instance.rolloutServiceListRolloutInfos(namespace, {})).resolves.toBe(null) + }) + test("rolloutServicePromoteRollout", () => { + const body: api.RolloutPromoteRolloutRequest = undefined + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServicePromoteRollout(body, namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceRestartRollout", () => { + const body: api.RolloutRestartRolloutRequest = undefined + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServiceRestartRollout(body, namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceRetryRollout", () => { + const body: api.RolloutRetryRolloutRequest = undefined + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServiceRetryRollout(body, namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceSetRolloutImage", () => { + const body: api.RolloutSetImageRequest = undefined + const namespace: string = "namespace_example" + const rollout: string = "rollout_example" + const container: string = "container_example" + const image: string = "image_example" + const tag: string = "tag_example" + return expect(instance.rolloutServiceSetRolloutImage(body, namespace, rollout, container, image, tag, {})).resolves.toBe(null) + }) + test("rolloutServiceUndoRollout", () => { + const body: api.RolloutUndoRolloutRequest = undefined + const namespace: string = "namespace_example" + const rollout: string = "rollout_example" + const revision: string = "revision_example" + return expect(instance.rolloutServiceUndoRollout(body, namespace, rollout, revision, {})).resolves.toBe(null) + }) + test("rolloutServiceVersion", () => { + return expect(instance.rolloutServiceVersion({})).resolves.toBe(null) + }) + test("rolloutServiceWatchRolloutInfo", () => { + const namespace: string = "namespace_example" + const name: string = "name_example" + return expect(instance.rolloutServiceWatchRolloutInfo(namespace, name, {})).resolves.toBe(null) + }) + test("rolloutServiceWatchRolloutInfos", () => { + const namespace: string = "namespace_example" + return expect(instance.rolloutServiceWatchRolloutInfos(namespace, {})).resolves.toBe(null) + }) +}) + diff --git a/ui/src/models/rollout/generated/configuration.ts b/ui/src/models/rollout/generated/configuration.ts new file mode 100644 index 0000000000..c4678fdc59 --- /dev/null +++ b/ui/src/models/rollout/generated/configuration.ts @@ -0,0 +1,65 @@ +// tslint:disable +/** + * pkg/apiclient/rollout/rollout.proto + * No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) + * + * OpenAPI spec version: version not set + * + * + * NOTE: This file is auto generated by the swagger code generator program. + * https://github.com/swagger-api/swagger-codegen.git + * Do not edit the file manually. + */ + +export interface ConfigurationParameters { + apiKey?: string | ((name: string) => string); + username?: string; + password?: string; + accessToken?: string | ((name: string, scopes?: string[]) => string); + basePath?: string; +} + +export class Configuration { + /** + * parameter for apiKey security + * @param name security name + * @memberof Configuration + */ + apiKey?: string | ((name: string) => string); + /** + * parameter for basic security + * + * @type {string} + * @memberof Configuration + */ + username?: string; + /** + * parameter for basic security + * + * @type {string} + * @memberof Configuration + */ + password?: string; + /** + * parameter for oauth2 security + * @param name security name + * @param scopes oauth2 scope + * @memberof Configuration + */ + accessToken?: string | ((name: string, scopes?: string[]) => string); + /** + * override base path + * + * @type {string} + * @memberof Configuration + */ + basePath?: string; + + constructor(param: ConfigurationParameters = {}) { + this.apiKey = param.apiKey; + this.username = param.username; + this.password = param.password; + this.accessToken = param.accessToken; + this.basePath = param.basePath; + } +} diff --git a/ui/src/models/rollout/generated/custom.d.ts b/ui/src/models/rollout/generated/custom.d.ts new file mode 100644 index 0000000000..9a5ceb3588 --- /dev/null +++ b/ui/src/models/rollout/generated/custom.d.ts @@ -0,0 +1,2 @@ +declare module 'portable-fetch'; +declare module 'url'; \ No newline at end of file diff --git a/ui/src/models/rollout/generated/git_push.sh b/ui/src/models/rollout/generated/git_push.sh new file mode 100644 index 0000000000..a1ff4c9bcb --- /dev/null +++ b/ui/src/models/rollout/generated/git_push.sh @@ -0,0 +1,51 @@ +#!/bin/sh +# ref: https://help.github.com/articles/adding-an-existing-project-to-github-using-the-command-line/ +# +# Usage example: /bin/sh ./git_push.sh wing328 swagger-petstore-perl "minor update" + +git_user_id=$1 +git_repo_id=$2 +release_note=$3 + +if [ "$git_user_id" = "" ]; then + git_user_id="GIT_USER_ID" + echo "[INFO] No command line input provided. Set \$git_user_id to $git_user_id" +fi + +if [ "$git_repo_id" = "" ]; then + git_repo_id="GIT_REPO_ID" + echo "[INFO] No command line input provided. Set \$git_repo_id to $git_repo_id" +fi + +if [ "$release_note" = "" ]; then + release_note="Minor update" + echo "[INFO] No command line input provided. Set \$release_note to $release_note" +fi + +# Initialize the local directory as a Git repository +git init + +# Adds the files in the local repository and stages them for commit. +git add . + +# Commits the tracked changes and prepares them to be pushed to a remote repository. +git commit -m "$release_note" + +# Sets the new remote +git_remote=`git remote` +if [ "$git_remote" = "" ]; then # git remote not defined + + if [ "$GIT_TOKEN" = "" ]; then + echo "[INFO] \$GIT_TOKEN (environment variable) is not set. Using the git credential in your environment." + git remote add origin https://github.com/${git_user_id}/${git_repo_id}.git + else + git remote add origin https://${git_user_id}:${GIT_TOKEN}@github.com/${git_user_id}/${git_repo_id}.git + fi + +fi + +git pull origin master + +# Pushes (Forces) the changes in the local repository up to the remote repository +echo "Git pushing to https://github.com/${git_user_id}/${git_repo_id}.git" +git push origin master 2>&1 | grep -v 'To https' diff --git a/ui/src/models/rollout/generated/index.ts b/ui/src/models/rollout/generated/index.ts new file mode 100644 index 0000000000..2dc292c366 --- /dev/null +++ b/ui/src/models/rollout/generated/index.ts @@ -0,0 +1,15 @@ +// tslint:disable +/** + * pkg/apiclient/rollout/rollout.proto + * No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) + * + * OpenAPI spec version: version not set + * + * + * NOTE: This file is auto generated by the swagger code generator program. + * https://github.com/swagger-api/swagger-codegen.git + * Do not edit the file manually. + */ + +export * from "./api"; +export * from "./configuration"; diff --git a/ui/src/models/rollout/rollout.tsx b/ui/src/models/rollout/rollout.tsx new file mode 100644 index 0000000000..b5129f7d9f --- /dev/null +++ b/ui/src/models/rollout/rollout.tsx @@ -0,0 +1,4 @@ +import * as Generated from './generated'; + +export type RolloutInfo = Generated.RolloutRolloutInfo; +export type Pod = Generated.RolloutPodInfo; diff --git a/ui/tsconfig.json b/ui/tsconfig.json new file mode 100644 index 0000000000..06774a244c --- /dev/null +++ b/ui/tsconfig.json @@ -0,0 +1 @@ +src/app/tsconfig.json diff --git a/ui/yarn.lock b/ui/yarn.lock new file mode 100644 index 0000000000..8891ce9746 --- /dev/null +++ b/ui/yarn.lock @@ -0,0 +1,12136 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@babel/code-frame@7.10.4": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.10.4.tgz#168da1a36e90da68ae8d49c0f1b48c7c6249213a" + integrity sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg== + dependencies: + "@babel/highlight" "^7.10.4" + +"@babel/code-frame@7.12.11": + version "7.12.11" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.11.tgz#f4ad435aa263db935b8f10f2c552d23fb716a63f" + integrity sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw== + dependencies: + "@babel/highlight" "^7.10.4" + +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.10.4", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.5.5": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.13.tgz#dcfc826beef65e75c50e21d3837d7d95798dd658" + integrity sha512-HV1Cm0Q3ZrpCR93tkWOYiuYIgLxZXZFVG2VgK+MBWjUqZTundupbfx2aXarXuw5Ko5aMcjtJgbSs4vUGBS5v6g== + dependencies: + "@babel/highlight" "^7.12.13" + +"@babel/compat-data@^7.12.1", "@babel/compat-data@^7.13.0", "@babel/compat-data@^7.13.12", "@babel/compat-data@^7.13.8": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.13.12.tgz#a8a5ccac19c200f9dd49624cac6e19d7be1236a1" + integrity sha512-3eJJ841uKxeV8dcN/2yGEUy+RfgQspPEgQat85umsE1rotuquQ2AbIub4S6j7c50a2d+4myc+zSlnXeIHrOnhQ== + +"@babel/core@7.12.3": + version "7.12.3" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.12.3.tgz#1b436884e1e3bff6fb1328dc02b208759de92ad8" + integrity sha512-0qXcZYKZp3/6N2jKYVxZv0aNCsxTSVCiK72DTiTYZAu7sjg73W0/aynWjMbiGd87EQL4WyA8reiJVh92AVla9g== + dependencies: + "@babel/code-frame" "^7.10.4" + "@babel/generator" "^7.12.1" + "@babel/helper-module-transforms" "^7.12.1" + "@babel/helpers" "^7.12.1" + "@babel/parser" "^7.12.3" + "@babel/template" "^7.10.4" + "@babel/traverse" "^7.12.1" + "@babel/types" "^7.12.1" + convert-source-map "^1.7.0" + debug "^4.1.0" + gensync "^1.0.0-beta.1" + json5 "^2.1.2" + lodash "^4.17.19" + resolve "^1.3.2" + semver "^5.4.1" + source-map "^0.5.0" + +"@babel/core@^7.1.0", "@babel/core@^7.12.3", "@babel/core@^7.7.5", "@babel/core@^7.8.4": + version "7.13.14" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.13.14.tgz#8e46ebbaca460a63497c797e574038ab04ae6d06" + integrity sha512-wZso/vyF4ki0l0znlgM4inxbdrUvCb+cVz8grxDq+6C9k6qbqoIJteQOKicaKjCipU3ISV+XedCqpL2RJJVehA== + dependencies: + "@babel/code-frame" "^7.12.13" + "@babel/generator" "^7.13.9" + "@babel/helper-compilation-targets" "^7.13.13" + "@babel/helper-module-transforms" "^7.13.14" + "@babel/helpers" "^7.13.10" + "@babel/parser" "^7.13.13" + "@babel/template" "^7.12.13" + "@babel/traverse" "^7.13.13" + "@babel/types" "^7.13.14" + convert-source-map "^1.7.0" + debug "^4.1.0" + gensync "^1.0.0-beta.2" + json5 "^2.1.2" + semver "^6.3.0" + source-map "^0.5.0" + +"@babel/generator@^7.12.1", "@babel/generator@^7.13.9": + version "7.13.9" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.13.9.tgz#3a7aa96f9efb8e2be42d38d80e2ceb4c64d8de39" + integrity sha512-mHOOmY0Axl/JCTkxTU6Lf5sWOg/v8nUa+Xkt4zMTftX0wqmb6Sh7J8gvcehBw7q0AhrhAR+FDacKjCZ2X8K+Sw== + dependencies: + "@babel/types" "^7.13.0" + jsesc "^2.5.1" + source-map "^0.5.0" + +"@babel/helper-annotate-as-pure@^7.10.4", "@babel/helper-annotate-as-pure@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.12.13.tgz#0f58e86dfc4bb3b1fcd7db806570e177d439b6ab" + integrity sha512-7YXfX5wQ5aYM/BOlbSccHDbuXXFPxeoUmfWtz8le2yTkTZc+BxsiEnENFoi2SlmA8ewDkG2LgIMIVzzn2h8kfw== + dependencies: + "@babel/types" "^7.12.13" + +"@babel/helper-builder-binary-assignment-operator-visitor@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.12.13.tgz#6bc20361c88b0a74d05137a65cac8d3cbf6f61fc" + integrity sha512-CZOv9tGphhDRlVjVkAgm8Nhklm9RzSmWpX2my+t7Ua/KT616pEzXsQCjinzvkRvHWJ9itO4f296efroX23XCMA== + dependencies: + "@babel/helper-explode-assignable-expression" "^7.12.13" + "@babel/types" "^7.12.13" + +"@babel/helper-compilation-targets@^7.12.1", "@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.13.10", "@babel/helper-compilation-targets@^7.13.13", "@babel/helper-compilation-targets@^7.13.8": + version "7.13.13" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.13.13.tgz#2b2972a0926474853f41e4adbc69338f520600e5" + integrity sha512-q1kcdHNZehBwD9jYPh3WyXcsFERi39X4I59I3NadciWtNDyZ6x+GboOxncFK0kXlKIv6BJm5acncehXWUjWQMQ== + dependencies: + "@babel/compat-data" "^7.13.12" + "@babel/helper-validator-option" "^7.12.17" + browserslist "^4.14.5" + semver "^6.3.0" + +"@babel/helper-create-class-features-plugin@^7.12.1", "@babel/helper-create-class-features-plugin@^7.13.0": + version "7.13.11" + resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.13.11.tgz#30d30a005bca2c953f5653fc25091a492177f4f6" + integrity sha512-ays0I7XYq9xbjCSvT+EvysLgfc3tOkwCULHjrnscGT3A9qD4sk3wXnJ3of0MAWsWGjdinFvajHU2smYuqXKMrw== + dependencies: + "@babel/helper-function-name" "^7.12.13" + "@babel/helper-member-expression-to-functions" "^7.13.0" + "@babel/helper-optimise-call-expression" "^7.12.13" + "@babel/helper-replace-supers" "^7.13.0" + "@babel/helper-split-export-declaration" "^7.12.13" + +"@babel/helper-create-regexp-features-plugin@^7.12.13": + version "7.12.17" + resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.12.17.tgz#a2ac87e9e319269ac655b8d4415e94d38d663cb7" + integrity sha512-p2VGmBu9oefLZ2nQpgnEnG0ZlRPvL8gAGvPUMQwUdaE8k49rOMuZpOwdQoy5qJf6K8jL3bcAMhVUlHAjIgJHUg== + dependencies: + "@babel/helper-annotate-as-pure" "^7.12.13" + regexpu-core "^4.7.1" + +"@babel/helper-define-polyfill-provider@^0.1.5": + version "0.1.5" + resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.1.5.tgz#3c2f91b7971b9fc11fe779c945c014065dea340e" + integrity sha512-nXuzCSwlJ/WKr8qxzW816gwyT6VZgiJG17zR40fou70yfAcqjoNyTLl/DQ+FExw5Hx5KNqshmN8Ldl/r2N7cTg== + dependencies: + "@babel/helper-compilation-targets" "^7.13.0" + "@babel/helper-module-imports" "^7.12.13" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/traverse" "^7.13.0" + debug "^4.1.1" + lodash.debounce "^4.0.8" + resolve "^1.14.2" + semver "^6.1.2" + +"@babel/helper-explode-assignable-expression@^7.12.13": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.13.0.tgz#17b5c59ff473d9f956f40ef570cf3a76ca12657f" + integrity sha512-qS0peLTDP8kOisG1blKbaoBg/o9OSa1qoumMjTK5pM+KDTtpxpsiubnCGP34vK8BXGcb2M9eigwgvoJryrzwWA== + dependencies: + "@babel/types" "^7.13.0" + +"@babel/helper-function-name@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.12.13.tgz#93ad656db3c3c2232559fd7b2c3dbdcbe0eb377a" + integrity sha512-TZvmPn0UOqmvi5G4vvw0qZTpVptGkB1GL61R6lKvrSdIxGm5Pky7Q3fpKiIkQCAtRCBUwB0PaThlx9vebCDSwA== + dependencies: + "@babel/helper-get-function-arity" "^7.12.13" + "@babel/template" "^7.12.13" + "@babel/types" "^7.12.13" + +"@babel/helper-get-function-arity@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.12.13.tgz#bc63451d403a3b3082b97e1d8b3fe5bd4091e583" + integrity sha512-DjEVzQNz5LICkzN0REdpD5prGoidvbdYk1BVgRUOINaWJP2t6avB27X1guXK1kXNrX0WMfsrm1A/ZBthYuIMQg== + dependencies: + "@babel/types" "^7.12.13" + +"@babel/helper-hoist-variables@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.13.0.tgz#5d5882e855b5c5eda91e0cadc26c6e7a2c8593d8" + integrity sha512-0kBzvXiIKfsCA0y6cFEIJf4OdzfpRuNk4+YTeHZpGGc666SATFKTz6sRncwFnQk7/ugJ4dSrCj6iJuvW4Qwr2g== + dependencies: + "@babel/traverse" "^7.13.0" + "@babel/types" "^7.13.0" + +"@babel/helper-member-expression-to-functions@^7.13.0", "@babel/helper-member-expression-to-functions@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.13.12.tgz#dfe368f26d426a07299d8d6513821768216e6d72" + integrity sha512-48ql1CLL59aKbU94Y88Xgb2VFy7a95ykGRbJJaaVv+LX5U8wFpLfiGXJJGUozsmA1oEh/o5Bp60Voq7ACyA/Sw== + dependencies: + "@babel/types" "^7.13.12" + +"@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.12.1", "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.13.12.tgz#c6a369a6f3621cb25da014078684da9196b61977" + integrity sha512-4cVvR2/1B693IuOvSI20xqqa/+bl7lqAMR59R4iu39R9aOX8/JoYY1sFaNvUMyMBGnHdwvJgUrzNLoUZxXypxA== + dependencies: + "@babel/types" "^7.13.12" + +"@babel/helper-module-transforms@^7.12.1", "@babel/helper-module-transforms@^7.13.0", "@babel/helper-module-transforms@^7.13.14": + version "7.13.14" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.13.14.tgz#e600652ba48ccb1641775413cb32cfa4e8b495ef" + integrity sha512-QuU/OJ0iAOSIatyVZmfqB0lbkVP0kDRiKj34xy+QNsnVZi/PA6BoSoreeqnxxa9EHFAIL0R9XOaAR/G9WlIy5g== + dependencies: + "@babel/helper-module-imports" "^7.13.12" + "@babel/helper-replace-supers" "^7.13.12" + "@babel/helper-simple-access" "^7.13.12" + "@babel/helper-split-export-declaration" "^7.12.13" + "@babel/helper-validator-identifier" "^7.12.11" + "@babel/template" "^7.12.13" + "@babel/traverse" "^7.13.13" + "@babel/types" "^7.13.14" + +"@babel/helper-optimise-call-expression@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.12.13.tgz#5c02d171b4c8615b1e7163f888c1c81c30a2aaea" + integrity sha512-BdWQhoVJkp6nVjB7nkFWcn43dkprYauqtk++Py2eaf/GRDFm5BxRqEIZCiHlZUGAVmtwKcsVL1dC68WmzeFmiA== + dependencies: + "@babel/types" "^7.12.13" + +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.13.0", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.13.0.tgz#806526ce125aed03373bc416a828321e3a6a33af" + integrity sha512-ZPafIPSwzUlAoWT8DKs1W2VyF2gOWthGd5NGFMsBcMMol+ZhK+EQY/e6V96poa6PA/Bh+C9plWN0hXO1uB8AfQ== + +"@babel/helper-remap-async-to-generator@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.13.0.tgz#376a760d9f7b4b2077a9dd05aa9c3927cadb2209" + integrity sha512-pUQpFBE9JvC9lrQbpX0TmeNIy5s7GnZjna2lhhcHC7DzgBs6fWn722Y5cfwgrtrqc7NAJwMvOa0mKhq6XaE4jg== + dependencies: + "@babel/helper-annotate-as-pure" "^7.12.13" + "@babel/helper-wrap-function" "^7.13.0" + "@babel/types" "^7.13.0" + +"@babel/helper-replace-supers@^7.12.13", "@babel/helper-replace-supers@^7.13.0", "@babel/helper-replace-supers@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.13.12.tgz#6442f4c1ad912502481a564a7386de0c77ff3804" + integrity sha512-Gz1eiX+4yDO8mT+heB94aLVNCL+rbuT2xy4YfyNqu8F+OI6vMvJK891qGBTqL9Uc8wxEvRW92Id6G7sDen3fFw== + dependencies: + "@babel/helper-member-expression-to-functions" "^7.13.12" + "@babel/helper-optimise-call-expression" "^7.12.13" + "@babel/traverse" "^7.13.0" + "@babel/types" "^7.13.12" + +"@babel/helper-simple-access@^7.12.13", "@babel/helper-simple-access@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.13.12.tgz#dd6c538afb61819d205a012c31792a39c7a5eaf6" + integrity sha512-7FEjbrx5SL9cWvXioDbnlYTppcZGuCY6ow3/D5vMggb2Ywgu4dMrpTJX0JdQAIcRRUElOIxF3yEooa9gUb9ZbA== + dependencies: + "@babel/types" "^7.13.12" + +"@babel/helper-skip-transparent-expression-wrappers@^7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.12.1.tgz#462dc63a7e435ade8468385c63d2b84cce4b3cbf" + integrity sha512-Mf5AUuhG1/OCChOJ/HcADmvcHM42WJockombn8ATJG3OnyiSxBK/Mm5x78BQWvmtXZKHgbjdGL2kin/HOLlZGA== + dependencies: + "@babel/types" "^7.12.1" + +"@babel/helper-split-export-declaration@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.12.13.tgz#e9430be00baf3e88b0e13e6f9d4eaf2136372b05" + integrity sha512-tCJDltF83htUtXx5NLcaDqRmknv652ZWCHyoTETf1CXYJdPC7nohZohjUgieXhv0hTJdRf2FjDueFehdNucpzg== + dependencies: + "@babel/types" "^7.12.13" + +"@babel/helper-validator-identifier@^7.12.11": + version "7.12.11" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz#c9a1f021917dcb5ccf0d4e453e399022981fc9ed" + integrity sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw== + +"@babel/helper-validator-option@^7.12.1", "@babel/helper-validator-option@^7.12.17": + version "7.12.17" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.12.17.tgz#d1fbf012e1a79b7eebbfdc6d270baaf8d9eb9831" + integrity sha512-TopkMDmLzq8ngChwRlyjR6raKD6gMSae4JdYDB8bByKreQgG0RBTuKe9LRxW3wFtUnjxOPRKBDwEH6Mg5KeDfw== + +"@babel/helper-wrap-function@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.13.0.tgz#bdb5c66fda8526ec235ab894ad53a1235c79fcc4" + integrity sha512-1UX9F7K3BS42fI6qd2A4BjKzgGjToscyZTdp1DjknHLCIvpgne6918io+aL5LXFcER/8QWiwpoY902pVEqgTXA== + dependencies: + "@babel/helper-function-name" "^7.12.13" + "@babel/template" "^7.12.13" + "@babel/traverse" "^7.13.0" + "@babel/types" "^7.13.0" + +"@babel/helpers@^7.12.1", "@babel/helpers@^7.13.10": + version "7.13.10" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.13.10.tgz#fd8e2ba7488533cdeac45cc158e9ebca5e3c7df8" + integrity sha512-4VO883+MWPDUVRF3PhiLBUFHoX/bsLTGFpFK/HqvvfBZz2D57u9XzPVNFVBTc0PW/CWR9BXTOKt8NF4DInUHcQ== + dependencies: + "@babel/template" "^7.12.13" + "@babel/traverse" "^7.13.0" + "@babel/types" "^7.13.0" + +"@babel/highlight@^7.10.4", "@babel/highlight@^7.12.13": + version "7.13.10" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.13.10.tgz#a8b2a66148f5b27d666b15d81774347a731d52d1" + integrity sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg== + dependencies: + "@babel/helper-validator-identifier" "^7.12.11" + chalk "^2.0.0" + js-tokens "^4.0.0" + +"@babel/parser@^7.1.0", "@babel/parser@^7.12.13", "@babel/parser@^7.12.3", "@babel/parser@^7.13.13", "@babel/parser@^7.7.0": + version "7.13.13" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.13.13.tgz#42f03862f4aed50461e543270916b47dd501f0df" + integrity sha512-OhsyMrqygfk5v8HmWwOzlYjJrtLaFhF34MrfG/Z73DgYCI6ojNUTUp2TYbtnjo8PegeJp12eamsNettCQjKjVw== + +"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.13.12.tgz#a3484d84d0b549f3fc916b99ee4783f26fabad2a" + integrity sha512-d0u3zWKcoZf379fOeJdr1a5WPDny4aOFZ6hlfKivgK0LY7ZxNfoaHL2fWwdGtHyVvra38FC+HVYkO+byfSA8AQ== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-skip-transparent-expression-wrappers" "^7.12.1" + "@babel/plugin-proposal-optional-chaining" "^7.13.12" + +"@babel/plugin-proposal-async-generator-functions@^7.12.1", "@babel/plugin-proposal-async-generator-functions@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.13.8.tgz#87aacb574b3bc4b5603f6fe41458d72a5a2ec4b1" + integrity sha512-rPBnhj+WgoSmgq+4gQUtXx/vOcU+UYtjy1AA/aeD61Hwj410fwYyqfUcRP3lR8ucgliVJL/G7sXcNUecC75IXA== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-remap-async-to-generator" "^7.13.0" + "@babel/plugin-syntax-async-generators" "^7.8.4" + +"@babel/plugin-proposal-class-properties@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.12.1.tgz#a082ff541f2a29a4821065b8add9346c0c16e5de" + integrity sha512-cKp3dlQsFsEs5CWKnN7BnSHOd0EOW8EKpEjkoz1pO2E5KzIDNV9Ros1b0CnmbVgAGXJubOYVBOGCT1OmJwOI7w== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.12.1" + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-proposal-class-properties@^7.12.1", "@babel/plugin-proposal-class-properties@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.13.0.tgz#146376000b94efd001e57a40a88a525afaab9f37" + integrity sha512-KnTDjFNC1g+45ka0myZNvSBFLhNCLN+GeGYLDEA8Oq7MZ6yMgfLoIRh86GRT0FjtJhZw8JyUskP9uvj5pHM9Zg== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-proposal-decorators@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.12.1.tgz#59271439fed4145456c41067450543aee332d15f" + integrity sha512-knNIuusychgYN8fGJHONL0RbFxLGawhXOJNLBk75TniTsZZeA+wdkDuv6wp4lGwzQEKjZi6/WYtnb3udNPmQmQ== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.12.1" + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-syntax-decorators" "^7.12.1" + +"@babel/plugin-proposal-dynamic-import@^7.12.1", "@babel/plugin-proposal-dynamic-import@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.13.8.tgz#876a1f6966e1dec332e8c9451afda3bebcdf2e1d" + integrity sha512-ONWKj0H6+wIRCkZi9zSbZtE/r73uOhMVHh256ys0UzfM7I3d4n+spZNWjOnJv2gzopumP2Wxi186vI8N0Y2JyQ== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + +"@babel/plugin-proposal-export-namespace-from@^7.12.1", "@babel/plugin-proposal-export-namespace-from@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.12.13.tgz#393be47a4acd03fa2af6e3cde9b06e33de1b446d" + integrity sha512-INAgtFo4OnLN3Y/j0VwAgw3HDXcDtX+C/erMvWzuV9v71r7urb6iyMXu7eM9IgLr1ElLlOkaHjJ0SbCmdOQ3Iw== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + +"@babel/plugin-proposal-json-strings@^7.12.1", "@babel/plugin-proposal-json-strings@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.13.8.tgz#bf1fb362547075afda3634ed31571c5901afef7b" + integrity sha512-w4zOPKUFPX1mgvTmL/fcEqy34hrQ1CRcGxdphBc6snDnnqJ47EZDIyop6IwXzAC8G916hsIuXB2ZMBCExC5k7Q== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-json-strings" "^7.8.3" + +"@babel/plugin-proposal-logical-assignment-operators@^7.12.1", "@babel/plugin-proposal-logical-assignment-operators@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.13.8.tgz#93fa78d63857c40ce3c8c3315220fd00bfbb4e1a" + integrity sha512-aul6znYB4N4HGweImqKn59Su9RS8lbUIqxtXTOcAGtNIDczoEFv+l1EhmX8rUBp3G1jMjKJm8m0jXVp63ZpS4A== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + +"@babel/plugin-proposal-nullish-coalescing-operator@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.12.1.tgz#3ed4fff31c015e7f3f1467f190dbe545cd7b046c" + integrity sha512-nZY0ESiaQDI1y96+jk6VxMOaL4LPo/QDHBqL+SF3/vl6dHkTwHlOI8L4ZwuRBHgakRBw5zsVylel7QPbbGuYgg== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.0" + +"@babel/plugin-proposal-nullish-coalescing-operator@^7.12.1", "@babel/plugin-proposal-nullish-coalescing-operator@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.13.8.tgz#3730a31dafd3c10d8ccd10648ed80a2ac5472ef3" + integrity sha512-iePlDPBn//UhxExyS9KyeYU7RM9WScAG+D3Hhno0PLJebAEpDZMocbDe64eqynhNAnwz/vZoL/q/QB2T1OH39A== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + +"@babel/plugin-proposal-numeric-separator@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.12.1.tgz#0e2c6774c4ce48be412119b4d693ac777f7685a6" + integrity sha512-MR7Ok+Af3OhNTCxYVjJZHS0t97ydnJZt/DbR4WISO39iDnhiD8XHrY12xuSJ90FFEGjir0Fzyyn7g/zY6hxbxA== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + +"@babel/plugin-proposal-numeric-separator@^7.12.1", "@babel/plugin-proposal-numeric-separator@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.12.13.tgz#bd9da3188e787b5120b4f9d465a8261ce67ed1db" + integrity sha512-O1jFia9R8BUCl3ZGB7eitaAPu62TXJRHn7rh+ojNERCFyqRwJMTmhz+tJ+k0CwI6CLjX/ee4qW74FSqlq9I35w== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + +"@babel/plugin-proposal-object-rest-spread@^7.12.1", "@babel/plugin-proposal-object-rest-spread@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.13.8.tgz#5d210a4d727d6ce3b18f9de82cc99a3964eed60a" + integrity sha512-DhB2EuB1Ih7S3/IRX5AFVgZ16k3EzfRbq97CxAVI1KSYcW+lexV8VZb7G7L8zuPVSdQMRn0kiBpf/Yzu9ZKH0g== + dependencies: + "@babel/compat-data" "^7.13.8" + "@babel/helper-compilation-targets" "^7.13.8" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-transform-parameters" "^7.13.0" + +"@babel/plugin-proposal-optional-catch-binding@^7.12.1", "@babel/plugin-proposal-optional-catch-binding@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.13.8.tgz#3ad6bd5901506ea996fc31bdcf3ccfa2bed71107" + integrity sha512-0wS/4DUF1CuTmGo+NiaHfHcVSeSLj5S3e6RivPTg/2k3wOv3jO35tZ6/ZWsQhQMvdgI7CwphjQa/ccarLymHVA== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + +"@babel/plugin-proposal-optional-chaining@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.12.1.tgz#cce122203fc8a32794296fc377c6dedaf4363797" + integrity sha512-c2uRpY6WzaVDzynVY9liyykS+kVU+WRZPMPYpkelXH8KBt1oXoI89kPbZKKG/jDT5UK92FTW2fZkZaJhdiBabw== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/helper-skip-transparent-expression-wrappers" "^7.12.1" + "@babel/plugin-syntax-optional-chaining" "^7.8.0" + +"@babel/plugin-proposal-optional-chaining@^7.12.1", "@babel/plugin-proposal-optional-chaining@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.13.12.tgz#ba9feb601d422e0adea6760c2bd6bbb7bfec4866" + integrity sha512-fcEdKOkIB7Tf4IxrgEVeFC4zeJSTr78no9wTdBuZZbqF64kzllU0ybo2zrzm7gUQfxGhBgq4E39oRs8Zx/RMYQ== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-skip-transparent-expression-wrappers" "^7.12.1" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + +"@babel/plugin-proposal-private-methods@^7.12.1", "@babel/plugin-proposal-private-methods@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.13.0.tgz#04bd4c6d40f6e6bbfa2f57e2d8094bad900ef787" + integrity sha512-MXyyKQd9inhx1kDYPkFRVOBXQ20ES8Pto3T7UZ92xj2mY0EVD8oAVzeyYuVfy/mxAdTSIayOvg+aVzcHV2bn6Q== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-proposal-unicode-property-regex@^7.12.1", "@babel/plugin-proposal-unicode-property-regex@^7.12.13", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.12.13.tgz#bebde51339be829c17aaaaced18641deb62b39ba" + integrity sha512-XyJmZidNfofEkqFV5VC/bLabGmO5QzenPO/YOfGuEbgU+2sSwMmio3YLb4WtBgcmmdwZHyVyv8on77IUjQ5Gvg== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.12.13" + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-async-generators@^7.8.0", "@babel/plugin-syntax-async-generators@^7.8.4": + version "7.8.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz#a983fb1aeb2ec3f6ed042a210f640e90e786fe0d" + integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-bigint@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz#4c9a6f669f5d0cdf1b90a1671e9a146be5300cea" + integrity sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-class-properties@^7.12.1", "@babel/plugin-syntax-class-properties@^7.12.13", "@babel/plugin-syntax-class-properties@^7.8.3": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10" + integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-decorators@^7.12.1": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.12.13.tgz#fac829bf3c7ef4a1bc916257b403e58c6bdaf648" + integrity sha512-Rw6aIXGuqDLr6/LoBBYE57nKOzQpz/aDkKlMqEwH+Vp0MXbG6H/TfRjaY343LKxzAKAMXIHsQ8JzaZKuDZ9MwA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-dynamic-import@^7.8.0", "@babel/plugin-syntax-dynamic-import@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz#62bf98b2da3cd21d626154fc96ee5b3cb68eacb3" + integrity sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-export-namespace-from@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz#028964a9ba80dbc094c915c487ad7c4e7a66465a" + integrity sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.3" + +"@babel/plugin-syntax-flow@^7.12.1": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.12.13.tgz#5df9962503c0a9c918381c929d51d4d6949e7e86" + integrity sha512-J/RYxnlSLXZLVR7wTRsozxKT8qbsx1mNKJzXEEjQ0Kjx1ZACcyHgbanNWNCFtc36IzuWhYWPpvJFFoexoOWFmA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-import-meta@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz#ee601348c370fa334d2207be158777496521fd51" + integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-json-strings@^7.8.0", "@babel/plugin-syntax-json-strings@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz#01ca21b668cd8218c9e640cb6dd88c5412b2c96a" + integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-jsx@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.12.13.tgz#044fb81ebad6698fe62c478875575bcbb9b70f15" + integrity sha512-d4HM23Q1K7oq/SLNmG6mRt85l2csmQ0cHRaxRXjKW0YFdEXqlZ5kzFQKH5Uc3rDJECgu+yCRgPkG04Mm98R/1g== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-logical-assignment-operators@^7.10.4", "@babel/plugin-syntax-logical-assignment-operators@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz#ca91ef46303530448b906652bac2e9fe9941f699" + integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.0", "@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz#167ed70368886081f74b5c36c65a88c03b66d1a9" + integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-numeric-separator@^7.10.4", "@babel/plugin-syntax-numeric-separator@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz#b9b070b3e33570cd9fd07ba7fa91c0dd37b9af97" + integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-object-rest-spread@^7.8.0", "@babel/plugin-syntax-object-rest-spread@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz#60e225edcbd98a640332a2e72dd3e66f1af55871" + integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-catch-binding@^7.8.0", "@babel/plugin-syntax-optional-catch-binding@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz#6111a265bcfb020eb9efd0fdfd7d26402b9ed6c1" + integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-chaining@^7.8.0", "@babel/plugin-syntax-optional-chaining@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz#4f69c2ab95167e0180cd5336613f8c5788f7d48a" + integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-top-level-await@^7.12.1", "@babel/plugin-syntax-top-level-await@^7.12.13", "@babel/plugin-syntax-top-level-await@^7.8.3": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.12.13.tgz#c5f0fa6e249f5b739727f923540cf7a806130178" + integrity sha512-A81F9pDwyS7yM//KwbCSDqy3Uj4NMIurtplxphWxoYtNPov7cJsDkAFNNyVlIZ3jwGycVsurZ+LtOA8gZ376iQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-typescript@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.12.13.tgz#9dff111ca64154cef0f4dc52cf843d9f12ce4474" + integrity sha512-cHP3u1JiUiG2LFDKbXnwVad81GvfyIOmCD6HIEId6ojrY0Drfy2q1jw7BwN7dE84+kTnBjLkXoL3IEy/3JPu2w== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-arrow-functions@^7.12.1", "@babel/plugin-transform-arrow-functions@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.13.0.tgz#10a59bebad52d637a027afa692e8d5ceff5e3dae" + integrity sha512-96lgJagobeVmazXFaDrbmCLQxBysKu7U6Do3mLsx27gf5Dk85ezysrs2BZUpXD703U/Su1xTBDxxar2oa4jAGg== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-async-to-generator@^7.12.1", "@babel/plugin-transform-async-to-generator@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.13.0.tgz#8e112bf6771b82bf1e974e5e26806c5c99aa516f" + integrity sha512-3j6E004Dx0K3eGmhxVJxwwI89CTJrce7lg3UrtFuDAVQ/2+SJ/h/aSFOeE6/n0WB1GsOffsJp6MnPQNQ8nmwhg== + dependencies: + "@babel/helper-module-imports" "^7.12.13" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-remap-async-to-generator" "^7.13.0" + +"@babel/plugin-transform-block-scoped-functions@^7.12.1", "@babel/plugin-transform-block-scoped-functions@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.12.13.tgz#a9bf1836f2a39b4eb6cf09967739de29ea4bf4c4" + integrity sha512-zNyFqbc3kI/fVpqwfqkg6RvBgFpC4J18aKKMmv7KdQ/1GgREapSJAykLMVNwfRGO3BtHj3YQZl8kxCXPcVMVeg== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-block-scoping@^7.12.1", "@babel/plugin-transform-block-scoping@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.12.13.tgz#f36e55076d06f41dfd78557ea039c1b581642e61" + integrity sha512-Pxwe0iqWJX4fOOM2kEZeUuAxHMWb9nK+9oh5d11bsLoB0xMg+mkDpt0eYuDZB7ETrY9bbcVlKUGTOGWy7BHsMQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-classes@^7.12.1", "@babel/plugin-transform-classes@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.13.0.tgz#0265155075c42918bf4d3a4053134176ad9b533b" + integrity sha512-9BtHCPUARyVH1oXGcSJD3YpsqRLROJx5ZNP6tN5vnk17N0SVf9WCtf8Nuh1CFmgByKKAIMstitKduoCmsaDK5g== + dependencies: + "@babel/helper-annotate-as-pure" "^7.12.13" + "@babel/helper-function-name" "^7.12.13" + "@babel/helper-optimise-call-expression" "^7.12.13" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-replace-supers" "^7.13.0" + "@babel/helper-split-export-declaration" "^7.12.13" + globals "^11.1.0" + +"@babel/plugin-transform-computed-properties@^7.12.1", "@babel/plugin-transform-computed-properties@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.13.0.tgz#845c6e8b9bb55376b1fa0b92ef0bdc8ea06644ed" + integrity sha512-RRqTYTeZkZAz8WbieLTvKUEUxZlUTdmL5KGMyZj7FnMfLNKV4+r5549aORG/mgojRmFlQMJDUupwAMiF2Q7OUg== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-destructuring@^7.12.1", "@babel/plugin-transform-destructuring@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.13.0.tgz#c5dce270014d4e1ebb1d806116694c12b7028963" + integrity sha512-zym5em7tePoNT9s964c0/KU3JPPnuq7VhIxPRefJ4/s82cD+q1mgKfuGRDMCPL0HTyKz4dISuQlCusfgCJ86HA== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-dotall-regex@^7.12.1", "@babel/plugin-transform-dotall-regex@^7.12.13", "@babel/plugin-transform-dotall-regex@^7.4.4": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.12.13.tgz#3f1601cc29905bfcb67f53910f197aeafebb25ad" + integrity sha512-foDrozE65ZFdUC2OfgeOCrEPTxdB3yjqxpXh8CH+ipd9CHd4s/iq81kcUpyH8ACGNEPdFqbtzfgzbT/ZGlbDeQ== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.12.13" + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-duplicate-keys@^7.12.1", "@babel/plugin-transform-duplicate-keys@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.12.13.tgz#6f06b87a8b803fd928e54b81c258f0a0033904de" + integrity sha512-NfADJiiHdhLBW3pulJlJI2NB0t4cci4WTZ8FtdIuNc2+8pslXdPtRRAEWqUY+m9kNOk2eRYbTAOipAxlrOcwwQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-exponentiation-operator@^7.12.1", "@babel/plugin-transform-exponentiation-operator@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.12.13.tgz#4d52390b9a273e651e4aba6aee49ef40e80cd0a1" + integrity sha512-fbUelkM1apvqez/yYx1/oICVnGo2KM5s63mhGylrmXUxK/IAXSIf87QIxVfZldWf4QsOafY6vV3bX8aMHSvNrA== + dependencies: + "@babel/helper-builder-binary-assignment-operator-visitor" "^7.12.13" + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-flow-strip-types@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.12.1.tgz#8430decfa7eb2aea5414ed4a3fa6e1652b7d77c4" + integrity sha512-8hAtkmsQb36yMmEtk2JZ9JnVyDSnDOdlB+0nEGzIDLuK4yR3JcEjfuFPYkdEPSh8Id+rAMeBEn+X0iVEyho6Hg== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-syntax-flow" "^7.12.1" + +"@babel/plugin-transform-for-of@^7.12.1", "@babel/plugin-transform-for-of@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.13.0.tgz#c799f881a8091ac26b54867a845c3e97d2696062" + integrity sha512-IHKT00mwUVYE0zzbkDgNRP6SRzvfGCYsOxIRz8KsiaaHCcT9BWIkO+H9QRJseHBLOGBZkHUdHiqj6r0POsdytg== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-function-name@^7.12.1", "@babel/plugin-transform-function-name@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.12.13.tgz#bb024452f9aaed861d374c8e7a24252ce3a50051" + integrity sha512-6K7gZycG0cmIwwF7uMK/ZqeCikCGVBdyP2J5SKNCXO5EOHcqi+z7Jwf8AmyDNcBgxET8DrEtCt/mPKPyAzXyqQ== + dependencies: + "@babel/helper-function-name" "^7.12.13" + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-literals@^7.12.1", "@babel/plugin-transform-literals@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.12.13.tgz#2ca45bafe4a820197cf315794a4d26560fe4bdb9" + integrity sha512-FW+WPjSR7hiUxMcKqyNjP05tQ2kmBCdpEpZHY1ARm96tGQCCBvXKnpjILtDplUnJ/eHZ0lALLM+d2lMFSpYJrQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-member-expression-literals@^7.12.1", "@babel/plugin-transform-member-expression-literals@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.12.13.tgz#5ffa66cd59b9e191314c9f1f803b938e8c081e40" + integrity sha512-kxLkOsg8yir4YeEPHLuO2tXP9R/gTjpuTOjshqSpELUN3ZAg2jfDnKUvzzJxObun38sw3wm4Uu69sX/zA7iRvg== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-modules-amd@^7.12.1", "@babel/plugin-transform-modules-amd@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.13.0.tgz#19f511d60e3d8753cc5a6d4e775d3a5184866cc3" + integrity sha512-EKy/E2NHhY/6Vw5d1k3rgoobftcNUmp9fGjb9XZwQLtTctsRBOTRO7RHHxfIky1ogMN5BxN7p9uMA3SzPfotMQ== + dependencies: + "@babel/helper-module-transforms" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-commonjs@^7.12.1", "@babel/plugin-transform-modules-commonjs@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.13.8.tgz#7b01ad7c2dcf2275b06fa1781e00d13d420b3e1b" + integrity sha512-9QiOx4MEGglfYZ4XOnU79OHr6vIWUakIj9b4mioN8eQIoEh+pf5p/zEB36JpDFWA12nNMiRf7bfoRvl9Rn79Bw== + dependencies: + "@babel/helper-module-transforms" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-simple-access" "^7.12.13" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-systemjs@^7.12.1", "@babel/plugin-transform-modules-systemjs@^7.13.8": + version "7.13.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.13.8.tgz#6d066ee2bff3c7b3d60bf28dec169ad993831ae3" + integrity sha512-hwqctPYjhM6cWvVIlOIe27jCIBgHCsdH2xCJVAYQm7V5yTMoilbVMi9f6wKg0rpQAOn6ZG4AOyvCqFF/hUh6+A== + dependencies: + "@babel/helper-hoist-variables" "^7.13.0" + "@babel/helper-module-transforms" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-validator-identifier" "^7.12.11" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-umd@^7.12.1", "@babel/plugin-transform-modules-umd@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.13.0.tgz#8a3d96a97d199705b9fd021580082af81c06e70b" + integrity sha512-D/ILzAh6uyvkWjKKyFE/W0FzWwasv6vPTSqPcjxFqn6QpX3u8DjRVliq4F2BamO2Wee/om06Vyy+vPkNrd4wxw== + dependencies: + "@babel/helper-module-transforms" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-named-capturing-groups-regex@^7.12.1", "@babel/plugin-transform-named-capturing-groups-regex@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.12.13.tgz#2213725a5f5bbbe364b50c3ba5998c9599c5c9d9" + integrity sha512-Xsm8P2hr5hAxyYblrfACXpQKdQbx4m2df9/ZZSQ8MAhsadw06+jW7s9zsSw6he+mJZXRlVMyEnVktJo4zjk1WA== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.12.13" + +"@babel/plugin-transform-new-target@^7.12.1", "@babel/plugin-transform-new-target@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.12.13.tgz#e22d8c3af24b150dd528cbd6e685e799bf1c351c" + integrity sha512-/KY2hbLxrG5GTQ9zzZSc3xWiOy379pIETEhbtzwZcw9rvuaVV4Fqy7BYGYOWZnaoXIQYbbJ0ziXLa/sKcGCYEQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-object-super@^7.12.1", "@babel/plugin-transform-object-super@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.12.13.tgz#b4416a2d63b8f7be314f3d349bd55a9c1b5171f7" + integrity sha512-JzYIcj3XtYspZDV8j9ulnoMPZZnF/Cj0LUxPOjR89BdBVx+zYJI9MdMIlUZjbXDX+6YVeS6I3e8op+qQ3BYBoQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + "@babel/helper-replace-supers" "^7.12.13" + +"@babel/plugin-transform-parameters@^7.12.1", "@babel/plugin-transform-parameters@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.13.0.tgz#8fa7603e3097f9c0b7ca1a4821bc2fb52e9e5007" + integrity sha512-Jt8k/h/mIwE2JFEOb3lURoY5C85ETcYPnbuAJ96zRBzh1XHtQZfs62ChZ6EP22QlC8c7Xqr9q+e1SU5qttwwjw== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-property-literals@^7.12.1", "@babel/plugin-transform-property-literals@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.12.13.tgz#4e6a9e37864d8f1b3bc0e2dce7bf8857db8b1a81" + integrity sha512-nqVigwVan+lR+g8Fj8Exl0UQX2kymtjcWfMOYM1vTYEKujeyv2SkMgazf2qNcK7l4SDiKyTA/nHCPqL4e2zo1A== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-react-constant-elements@^7.12.1": + version "7.13.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.13.13.tgz#0208b1d942bf939cd4f7aa5b255d42602aa4a920" + integrity sha512-SNJU53VM/SjQL0bZhyU+f4kJQz7bQQajnrZRSaU21hruG/NWY41AEM9AWXeXX90pYr/C2yAmTgI6yW3LlLrAUQ== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-react-display-name@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.12.1.tgz#1cbcd0c3b1d6648c55374a22fc9b6b7e5341c00d" + integrity sha512-cAzB+UzBIrekfYxyLlFqf/OagTvHLcVBb5vpouzkYkBclRPraiygVnafvAoipErZLI8ANv8Ecn6E/m5qPXD26w== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-transform-react-display-name@^7.12.1", "@babel/plugin-transform-react-display-name@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.12.13.tgz#c28effd771b276f4647411c9733dbb2d2da954bd" + integrity sha512-MprESJzI9O5VnJZrL7gg1MpdqmiFcUv41Jc7SahxYsNP2kDkFqClxxTZq+1Qv4AFCamm+GXMRDQINNn+qrxmiA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-react-jsx-development@^7.12.1", "@babel/plugin-transform-react-jsx-development@^7.12.17": + version "7.12.17" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.12.17.tgz#f510c0fa7cd7234153539f9a362ced41a5ca1447" + integrity sha512-BPjYV86SVuOaudFhsJR1zjgxxOhJDt6JHNoD48DxWEIxUCAMjV1ys6DYw4SDYZh0b1QsS2vfIA9t/ZsQGsDOUQ== + dependencies: + "@babel/plugin-transform-react-jsx" "^7.12.17" + +"@babel/plugin-transform-react-jsx-self@^7.12.1": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.12.13.tgz#422d99d122d592acab9c35ea22a6cfd9bf189f60" + integrity sha512-FXYw98TTJ125GVCCkFLZXlZ1qGcsYqNQhVBQcZjyrwf8FEUtVfKIoidnO8S0q+KBQpDYNTmiGo1gn67Vti04lQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-react-jsx-source@^7.12.1": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.12.13.tgz#051d76126bee5c9a6aa3ba37be2f6c1698856bcb" + integrity sha512-O5JJi6fyfih0WfDgIJXksSPhGP/G0fQpfxYy87sDc+1sFmsCS6wr3aAn+whbzkhbjtq4VMqLRaSzR6IsshIC0Q== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-react-jsx@^7.12.1", "@babel/plugin-transform-react-jsx@^7.12.17", "@babel/plugin-transform-react-jsx@^7.13.12": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.13.12.tgz#1df5dfaf0f4b784b43e96da6f28d630e775f68b3" + integrity sha512-jcEI2UqIcpCqB5U5DRxIl0tQEProI2gcu+g8VTIqxLO5Iidojb4d77q+fwGseCvd8af/lJ9masp4QWzBXFE2xA== + dependencies: + "@babel/helper-annotate-as-pure" "^7.12.13" + "@babel/helper-module-imports" "^7.13.12" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-jsx" "^7.12.13" + "@babel/types" "^7.13.12" + +"@babel/plugin-transform-react-pure-annotations@^7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.12.1.tgz#05d46f0ab4d1339ac59adf20a1462c91b37a1a42" + integrity sha512-RqeaHiwZtphSIUZ5I85PEH19LOSzxfuEazoY7/pWASCAIBuATQzpSVD+eT6MebeeZT2F4eSL0u4vw6n4Nm0Mjg== + dependencies: + "@babel/helper-annotate-as-pure" "^7.10.4" + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-transform-regenerator@^7.12.1", "@babel/plugin-transform-regenerator@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.12.13.tgz#b628bcc9c85260ac1aeb05b45bde25210194a2f5" + integrity sha512-lxb2ZAvSLyJ2PEe47hoGWPmW22v7CtSl9jW8mingV4H2sEX/JOcrAj2nPuGWi56ERUm2bUpjKzONAuT6HCn2EA== + dependencies: + regenerator-transform "^0.14.2" + +"@babel/plugin-transform-reserved-words@^7.12.1", "@babel/plugin-transform-reserved-words@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.12.13.tgz#7d9988d4f06e0fe697ea1d9803188aa18b472695" + integrity sha512-xhUPzDXxZN1QfiOy/I5tyye+TRz6lA7z6xaT4CLOjPRMVg1ldRf0LHw0TDBpYL4vG78556WuHdyO9oi5UmzZBg== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-runtime@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.12.1.tgz#04b792057eb460389ff6a4198e377614ea1e7ba5" + integrity sha512-Ac/H6G9FEIkS2tXsZjL4RAdS3L3WHxci0usAnz7laPWUmFiGtj7tIASChqKZMHTSQTQY6xDbOq+V1/vIq3QrWg== + dependencies: + "@babel/helper-module-imports" "^7.12.1" + "@babel/helper-plugin-utils" "^7.10.4" + resolve "^1.8.1" + semver "^5.5.1" + +"@babel/plugin-transform-shorthand-properties@^7.12.1", "@babel/plugin-transform-shorthand-properties@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.12.13.tgz#db755732b70c539d504c6390d9ce90fe64aff7ad" + integrity sha512-xpL49pqPnLtf0tVluuqvzWIgLEhuPpZzvs2yabUHSKRNlN7ScYU7aMlmavOeyXJZKgZKQRBlh8rHbKiJDraTSw== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-spread@^7.12.1", "@babel/plugin-transform-spread@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.13.0.tgz#84887710e273c1815ace7ae459f6f42a5d31d5fd" + integrity sha512-V6vkiXijjzYeFmQTr3dBxPtZYLPcUfY34DebOU27jIl2M/Y8Egm52Hw82CSjjPqd54GTlJs5x+CR7HeNr24ckg== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-skip-transparent-expression-wrappers" "^7.12.1" + +"@babel/plugin-transform-sticky-regex@^7.12.1", "@babel/plugin-transform-sticky-regex@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.12.13.tgz#760ffd936face73f860ae646fb86ee82f3d06d1f" + integrity sha512-Jc3JSaaWT8+fr7GRvQP02fKDsYk4K/lYwWq38r/UGfaxo89ajud321NH28KRQ7xy1Ybc0VUE5Pz8psjNNDUglg== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-template-literals@^7.12.1", "@babel/plugin-transform-template-literals@^7.13.0": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.13.0.tgz#a36049127977ad94438dee7443598d1cefdf409d" + integrity sha512-d67umW6nlfmr1iehCcBv69eSUSySk1EsIS8aTDX4Xo9qajAh6mYtcl4kJrBkGXuxZPEgVr7RVfAvNW6YQkd4Mw== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + +"@babel/plugin-transform-typeof-symbol@^7.12.1", "@babel/plugin-transform-typeof-symbol@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.12.13.tgz#785dd67a1f2ea579d9c2be722de8c84cb85f5a7f" + integrity sha512-eKv/LmUJpMnu4npgfvs3LiHhJua5fo/CysENxa45YCQXZwKnGCQKAg87bvoqSW1fFT+HA32l03Qxsm8ouTY3ZQ== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-typescript@^7.12.1": + version "7.13.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.13.0.tgz#4a498e1f3600342d2a9e61f60131018f55774853" + integrity sha512-elQEwluzaU8R8dbVuW2Q2Y8Nznf7hnjM7+DSCd14Lo5fF63C9qNLbwZYbmZrtV9/ySpSUpkRpQXvJb6xyu4hCQ== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.13.0" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/plugin-syntax-typescript" "^7.12.13" + +"@babel/plugin-transform-unicode-escapes@^7.12.1", "@babel/plugin-transform-unicode-escapes@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.12.13.tgz#840ced3b816d3b5127dd1d12dcedc5dead1a5e74" + integrity sha512-0bHEkdwJ/sN/ikBHfSmOXPypN/beiGqjo+o4/5K+vxEFNPRPdImhviPakMKG4x96l85emoa0Z6cDflsdBusZbw== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-transform-unicode-regex@^7.12.1", "@babel/plugin-transform-unicode-regex@^7.12.13": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.12.13.tgz#b52521685804e155b1202e83fc188d34bb70f5ac" + integrity sha512-mDRzSNY7/zopwisPZ5kM9XKCfhchqIYwAKRERtEnhYscZB79VRekuRSoYbN0+KVe3y8+q1h6A4svXtP7N+UoCA== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.12.13" + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/preset-env@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.12.1.tgz#9c7e5ca82a19efc865384bb4989148d2ee5d7ac2" + integrity sha512-H8kxXmtPaAGT7TyBvSSkoSTUK6RHh61So05SyEbpmr0MCZrsNYn7mGMzzeYoOUCdHzww61k8XBft2TaES+xPLg== + dependencies: + "@babel/compat-data" "^7.12.1" + "@babel/helper-compilation-targets" "^7.12.1" + "@babel/helper-module-imports" "^7.12.1" + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/helper-validator-option" "^7.12.1" + "@babel/plugin-proposal-async-generator-functions" "^7.12.1" + "@babel/plugin-proposal-class-properties" "^7.12.1" + "@babel/plugin-proposal-dynamic-import" "^7.12.1" + "@babel/plugin-proposal-export-namespace-from" "^7.12.1" + "@babel/plugin-proposal-json-strings" "^7.12.1" + "@babel/plugin-proposal-logical-assignment-operators" "^7.12.1" + "@babel/plugin-proposal-nullish-coalescing-operator" "^7.12.1" + "@babel/plugin-proposal-numeric-separator" "^7.12.1" + "@babel/plugin-proposal-object-rest-spread" "^7.12.1" + "@babel/plugin-proposal-optional-catch-binding" "^7.12.1" + "@babel/plugin-proposal-optional-chaining" "^7.12.1" + "@babel/plugin-proposal-private-methods" "^7.12.1" + "@babel/plugin-proposal-unicode-property-regex" "^7.12.1" + "@babel/plugin-syntax-async-generators" "^7.8.0" + "@babel/plugin-syntax-class-properties" "^7.12.1" + "@babel/plugin-syntax-dynamic-import" "^7.8.0" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.0" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.0" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + "@babel/plugin-syntax-object-rest-spread" "^7.8.0" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.0" + "@babel/plugin-syntax-optional-chaining" "^7.8.0" + "@babel/plugin-syntax-top-level-await" "^7.12.1" + "@babel/plugin-transform-arrow-functions" "^7.12.1" + "@babel/plugin-transform-async-to-generator" "^7.12.1" + "@babel/plugin-transform-block-scoped-functions" "^7.12.1" + "@babel/plugin-transform-block-scoping" "^7.12.1" + "@babel/plugin-transform-classes" "^7.12.1" + "@babel/plugin-transform-computed-properties" "^7.12.1" + "@babel/plugin-transform-destructuring" "^7.12.1" + "@babel/plugin-transform-dotall-regex" "^7.12.1" + "@babel/plugin-transform-duplicate-keys" "^7.12.1" + "@babel/plugin-transform-exponentiation-operator" "^7.12.1" + "@babel/plugin-transform-for-of" "^7.12.1" + "@babel/plugin-transform-function-name" "^7.12.1" + "@babel/plugin-transform-literals" "^7.12.1" + "@babel/plugin-transform-member-expression-literals" "^7.12.1" + "@babel/plugin-transform-modules-amd" "^7.12.1" + "@babel/plugin-transform-modules-commonjs" "^7.12.1" + "@babel/plugin-transform-modules-systemjs" "^7.12.1" + "@babel/plugin-transform-modules-umd" "^7.12.1" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.12.1" + "@babel/plugin-transform-new-target" "^7.12.1" + "@babel/plugin-transform-object-super" "^7.12.1" + "@babel/plugin-transform-parameters" "^7.12.1" + "@babel/plugin-transform-property-literals" "^7.12.1" + "@babel/plugin-transform-regenerator" "^7.12.1" + "@babel/plugin-transform-reserved-words" "^7.12.1" + "@babel/plugin-transform-shorthand-properties" "^7.12.1" + "@babel/plugin-transform-spread" "^7.12.1" + "@babel/plugin-transform-sticky-regex" "^7.12.1" + "@babel/plugin-transform-template-literals" "^7.12.1" + "@babel/plugin-transform-typeof-symbol" "^7.12.1" + "@babel/plugin-transform-unicode-escapes" "^7.12.1" + "@babel/plugin-transform-unicode-regex" "^7.12.1" + "@babel/preset-modules" "^0.1.3" + "@babel/types" "^7.12.1" + core-js-compat "^3.6.2" + semver "^5.5.0" + +"@babel/preset-env@^7.12.1", "@babel/preset-env@^7.8.4": + version "7.13.12" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.13.12.tgz#6dff470478290582ac282fb77780eadf32480237" + integrity sha512-JzElc6jk3Ko6zuZgBtjOd01pf9yYDEIH8BcqVuYIuOkzOwDesoa/Nz4gIo4lBG6K861KTV9TvIgmFuT6ytOaAA== + dependencies: + "@babel/compat-data" "^7.13.12" + "@babel/helper-compilation-targets" "^7.13.10" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-validator-option" "^7.12.17" + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.13.12" + "@babel/plugin-proposal-async-generator-functions" "^7.13.8" + "@babel/plugin-proposal-class-properties" "^7.13.0" + "@babel/plugin-proposal-dynamic-import" "^7.13.8" + "@babel/plugin-proposal-export-namespace-from" "^7.12.13" + "@babel/plugin-proposal-json-strings" "^7.13.8" + "@babel/plugin-proposal-logical-assignment-operators" "^7.13.8" + "@babel/plugin-proposal-nullish-coalescing-operator" "^7.13.8" + "@babel/plugin-proposal-numeric-separator" "^7.12.13" + "@babel/plugin-proposal-object-rest-spread" "^7.13.8" + "@babel/plugin-proposal-optional-catch-binding" "^7.13.8" + "@babel/plugin-proposal-optional-chaining" "^7.13.12" + "@babel/plugin-proposal-private-methods" "^7.13.0" + "@babel/plugin-proposal-unicode-property-regex" "^7.12.13" + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-class-properties" "^7.12.13" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-top-level-await" "^7.12.13" + "@babel/plugin-transform-arrow-functions" "^7.13.0" + "@babel/plugin-transform-async-to-generator" "^7.13.0" + "@babel/plugin-transform-block-scoped-functions" "^7.12.13" + "@babel/plugin-transform-block-scoping" "^7.12.13" + "@babel/plugin-transform-classes" "^7.13.0" + "@babel/plugin-transform-computed-properties" "^7.13.0" + "@babel/plugin-transform-destructuring" "^7.13.0" + "@babel/plugin-transform-dotall-regex" "^7.12.13" + "@babel/plugin-transform-duplicate-keys" "^7.12.13" + "@babel/plugin-transform-exponentiation-operator" "^7.12.13" + "@babel/plugin-transform-for-of" "^7.13.0" + "@babel/plugin-transform-function-name" "^7.12.13" + "@babel/plugin-transform-literals" "^7.12.13" + "@babel/plugin-transform-member-expression-literals" "^7.12.13" + "@babel/plugin-transform-modules-amd" "^7.13.0" + "@babel/plugin-transform-modules-commonjs" "^7.13.8" + "@babel/plugin-transform-modules-systemjs" "^7.13.8" + "@babel/plugin-transform-modules-umd" "^7.13.0" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.12.13" + "@babel/plugin-transform-new-target" "^7.12.13" + "@babel/plugin-transform-object-super" "^7.12.13" + "@babel/plugin-transform-parameters" "^7.13.0" + "@babel/plugin-transform-property-literals" "^7.12.13" + "@babel/plugin-transform-regenerator" "^7.12.13" + "@babel/plugin-transform-reserved-words" "^7.12.13" + "@babel/plugin-transform-shorthand-properties" "^7.12.13" + "@babel/plugin-transform-spread" "^7.13.0" + "@babel/plugin-transform-sticky-regex" "^7.12.13" + "@babel/plugin-transform-template-literals" "^7.13.0" + "@babel/plugin-transform-typeof-symbol" "^7.12.13" + "@babel/plugin-transform-unicode-escapes" "^7.12.13" + "@babel/plugin-transform-unicode-regex" "^7.12.13" + "@babel/preset-modules" "^0.1.4" + "@babel/types" "^7.13.12" + babel-plugin-polyfill-corejs2 "^0.1.4" + babel-plugin-polyfill-corejs3 "^0.1.3" + babel-plugin-polyfill-regenerator "^0.1.2" + core-js-compat "^3.9.0" + semver "^6.3.0" + +"@babel/preset-modules@^0.1.3", "@babel/preset-modules@^0.1.4": + version "0.1.4" + resolved "https://registry.yarnpkg.com/@babel/preset-modules/-/preset-modules-0.1.4.tgz#362f2b68c662842970fdb5e254ffc8fc1c2e415e" + integrity sha512-J36NhwnfdzpmH41M1DrnkkgAqhZaqr/NBdPfQ677mLzlaXo+oDiv1deyCDtgAhz8p328otdob0Du7+xgHGZbKg== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" + "@babel/plugin-transform-dotall-regex" "^7.4.4" + "@babel/types" "^7.4.4" + esutils "^2.0.2" + +"@babel/preset-react@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/preset-react/-/preset-react-7.12.1.tgz#7f022b13f55b6dd82f00f16d1c599ae62985358c" + integrity sha512-euCExymHCi0qB9u5fKw7rvlw7AZSjw/NaB9h7EkdTt5+yHRrXdiRTh7fkG3uBPpJg82CqLfp1LHLqWGSCrab+g== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-transform-react-display-name" "^7.12.1" + "@babel/plugin-transform-react-jsx" "^7.12.1" + "@babel/plugin-transform-react-jsx-development" "^7.12.1" + "@babel/plugin-transform-react-jsx-self" "^7.12.1" + "@babel/plugin-transform-react-jsx-source" "^7.12.1" + "@babel/plugin-transform-react-pure-annotations" "^7.12.1" + +"@babel/preset-react@^7.12.5": + version "7.13.13" + resolved "https://registry.yarnpkg.com/@babel/preset-react/-/preset-react-7.13.13.tgz#fa6895a96c50763fe693f9148568458d5a839761" + integrity sha512-gx+tDLIE06sRjKJkVtpZ/t3mzCDOnPG+ggHZG9lffUbX8+wC739x20YQc9V35Do6ZAxaUc/HhVHIiOzz5MvDmA== + dependencies: + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/helper-validator-option" "^7.12.17" + "@babel/plugin-transform-react-display-name" "^7.12.13" + "@babel/plugin-transform-react-jsx" "^7.13.12" + "@babel/plugin-transform-react-jsx-development" "^7.12.17" + "@babel/plugin-transform-react-pure-annotations" "^7.12.1" + +"@babel/preset-typescript@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.12.1.tgz#86480b483bb97f75036e8864fe404cc782cc311b" + integrity sha512-hNK/DhmoJPsksdHuI/RVrcEws7GN5eamhi28JkO52MqIxU8Z0QpmiSOQxZHWOHV7I3P4UjHV97ay4TcamMA6Kw== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + "@babel/plugin-transform-typescript" "^7.12.1" + +"@babel/runtime-corejs3@^7.10.2": + version "7.13.10" + resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.13.10.tgz#14c3f4c85de22ba88e8e86685d13e8861a82fe86" + integrity sha512-x/XYVQ1h684pp1mJwOV4CyvqZXqbc8CMsMGUnAbuc82ZCdv1U63w5RSUzgDSXQHG5Rps/kiksH6g2D5BuaKyXg== + dependencies: + core-js-pure "^3.0.0" + regenerator-runtime "^0.13.4" + +"@babel/runtime@7.12.1": + version "7.12.1" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.12.1.tgz#b4116a6b6711d010b2dad3b7b6e43bf1b9954740" + integrity sha512-J5AIf3vPj3UwXaAzb5j1xM4WAQDX3EMgemF8rjCP3SoW09LfRKAXQKt6CoVYl230P6iWdRcBbnLDDdnqWxZSCA== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/runtime@^7.1.2", "@babel/runtime@^7.10.2", "@babel/runtime@^7.11.2", "@babel/runtime@^7.12.1", "@babel/runtime@^7.12.5", "@babel/runtime@^7.5.5", "@babel/runtime@^7.7.2", "@babel/runtime@^7.8.4", "@babel/runtime@^7.9.2": + version "7.13.10" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.13.10.tgz#47d42a57b6095f4468da440388fdbad8bebf0d7d" + integrity sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/template@^7.10.4", "@babel/template@^7.12.13", "@babel/template@^7.3.3": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.12.13.tgz#530265be8a2589dbb37523844c5bcb55947fb327" + integrity sha512-/7xxiGA57xMo/P2GVvdEumr8ONhFOhfgq2ihK3h1e6THqzTAkHbkXgB0xI9yeTfIUoH3+oAeHhqm/I43OTbbjA== + dependencies: + "@babel/code-frame" "^7.12.13" + "@babel/parser" "^7.12.13" + "@babel/types" "^7.12.13" + +"@babel/traverse@^7.1.0", "@babel/traverse@^7.12.1", "@babel/traverse@^7.13.0", "@babel/traverse@^7.13.13", "@babel/traverse@^7.7.0": + version "7.13.13" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.13.13.tgz#39aa9c21aab69f74d948a486dd28a2dbdbf5114d" + integrity sha512-CblEcwmXKR6eP43oQGG++0QMTtCjAsa3frUuzHoiIJWpaIIi8dwMyEFUJoXRLxagGqCK+jALRwIO+o3R9p/uUg== + dependencies: + "@babel/code-frame" "^7.12.13" + "@babel/generator" "^7.13.9" + "@babel/helper-function-name" "^7.12.13" + "@babel/helper-split-export-declaration" "^7.12.13" + "@babel/parser" "^7.13.13" + "@babel/types" "^7.13.13" + debug "^4.1.0" + globals "^11.1.0" + +"@babel/types@^7.0.0", "@babel/types@^7.12.1", "@babel/types@^7.12.13", "@babel/types@^7.12.6", "@babel/types@^7.13.0", "@babel/types@^7.13.12", "@babel/types@^7.13.13", "@babel/types@^7.13.14", "@babel/types@^7.3.0", "@babel/types@^7.3.3", "@babel/types@^7.4.4", "@babel/types@^7.7.0": + version "7.13.14" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.13.14.tgz#c35a4abb15c7cd45a2746d78ab328e362cbace0d" + integrity sha512-A2aa3QTkWoyqsZZFl56MLUsfmh7O0gN41IPvXAE/++8ojpbz12SszD7JEGYVdn4f9Kt4amIei07swF1h4AqmmQ== + dependencies: + "@babel/helper-validator-identifier" "^7.12.11" + lodash "^4.17.19" + to-fast-properties "^2.0.0" + +"@bcoe/v8-coverage@^0.2.3": + version "0.2.3" + resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" + integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== + +"@cnakazawa/watch@^1.0.3": + version "1.0.4" + resolved "https://registry.yarnpkg.com/@cnakazawa/watch/-/watch-1.0.4.tgz#f864ae85004d0fcab6f50be9141c4da368d1656a" + integrity sha512-v9kIhKwjeZThiWrLmj0y17CWoyddASLj9O2yvbZkbvw/N3rWOYy9zkV66ursAoVr0mV15bL8g0c4QZUE6cdDoQ== + dependencies: + exec-sh "^0.3.2" + minimist "^1.2.0" + +"@csstools/convert-colors@^1.4.0": + version "1.4.0" + resolved "https://registry.yarnpkg.com/@csstools/convert-colors/-/convert-colors-1.4.0.tgz#ad495dc41b12e75d588c6db8b9834f08fa131eb7" + integrity sha512-5a6wqoJV/xEdbRNKVo6I4hO3VjyDq//8q2f9I6PBAvMesJHFauXDorcNCsr9RzvsZnaWi5NYCcfyqP1QeFHFbw== + +"@csstools/normalize.css@^10.1.0": + version "10.1.0" + resolved "https://registry.yarnpkg.com/@csstools/normalize.css/-/normalize.css-10.1.0.tgz#f0950bba18819512d42f7197e56c518aa491cf18" + integrity sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg== + +"@discoveryjs/json-ext@^0.5.0": + version "0.5.2" + resolved "https://registry.yarnpkg.com/@discoveryjs/json-ext/-/json-ext-0.5.2.tgz#8f03a22a04de437254e8ce8cc84ba39689288752" + integrity sha512-HyYEUDeIj5rRQU2Hk5HTB2uHsbRQpF70nvMhVzi+VJR0X+xNEhjPui4/kBf3VeH/wqD28PT4sVOm8qqLjBrSZg== + +"@eslint/eslintrc@^0.4.0": + version "0.4.0" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.0.tgz#99cc0a0584d72f1df38b900fb062ba995f395547" + integrity sha512-2ZPCc+uNbjV5ERJr+aKSPRwZgKd2z11x0EgLvb1PURmUrn9QNRXFqje0Ldq454PfAVyaJYyrDvvIKSFP4NnBog== + dependencies: + ajv "^6.12.4" + debug "^4.1.1" + espree "^7.3.0" + globals "^12.1.0" + ignore "^4.0.6" + import-fresh "^3.2.1" + js-yaml "^3.13.1" + minimatch "^3.0.4" + strip-json-comments "^3.1.1" + +"@fortawesome/fontawesome-common-types@^0.2.35": + version "0.2.35" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.2.35.tgz#01dd3d054da07a00b764d78748df20daf2b317e9" + integrity sha512-IHUfxSEDS9dDGqYwIW7wTN6tn/O8E0n5PcAHz9cAaBoZw6UpG20IG/YM3NNLaGPwPqgjBAFjIURzqoQs3rrtuw== + +"@fortawesome/fontawesome-free@^5.15.2": + version "5.15.3" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-free/-/fontawesome-free-5.15.3.tgz#c36ffa64a2a239bf948541a97b6ae8d729e09a9a" + integrity sha512-rFnSUN/QOtnOAgqFRooTA3H57JLDm0QEG/jPdk+tLQNL/eWd+Aok8g3qCI+Q1xuDPWpGW/i9JySpJVsq8Q0s9w== + +"@fortawesome/fontawesome-svg-core@^1.2.34": + version "1.2.35" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-svg-core/-/fontawesome-svg-core-1.2.35.tgz#85aea8c25645fcec88d35f2eb1045c38d3e65cff" + integrity sha512-uLEXifXIL7hnh2sNZQrIJWNol7cTVIzwI+4qcBIq9QWaZqUblm0IDrtSqbNg+3SQf8SMGHkiSigD++rHmCHjBg== + dependencies: + "@fortawesome/fontawesome-common-types" "^0.2.35" + +"@fortawesome/free-regular-svg-icons@^5.15.2": + version "5.15.3" + resolved "https://registry.yarnpkg.com/@fortawesome/free-regular-svg-icons/-/free-regular-svg-icons-5.15.3.tgz#1ec4f2410ff638db549c5c5484fc60b66407dbe6" + integrity sha512-q4/p8Xehy9qiVTdDWHL4Z+o5PCLRChePGZRTXkl+/Z7erDVL8VcZUuqzJjs6gUz6czss4VIPBRdCz6wP37/zMQ== + dependencies: + "@fortawesome/fontawesome-common-types" "^0.2.35" + +"@fortawesome/free-solid-svg-icons@^5.15.2": + version "5.15.3" + resolved "https://registry.yarnpkg.com/@fortawesome/free-solid-svg-icons/-/free-solid-svg-icons-5.15.3.tgz#52eebe354f60dc77e0bde934ffc5c75ffd04f9d8" + integrity sha512-XPeeu1IlGYqz4VWGRAT5ukNMd4VHUEEJ7ysZ7pSSgaEtNvSo+FLurybGJVmiqkQdK50OkSja2bfZXOeyMGRD8Q== + dependencies: + "@fortawesome/fontawesome-common-types" "^0.2.35" + +"@fortawesome/react-fontawesome@^0.1.14": + version "0.1.14" + resolved "https://registry.yarnpkg.com/@fortawesome/react-fontawesome/-/react-fontawesome-0.1.14.tgz#bf28875c3935b69ce2dc620e1060b217a47f64ca" + integrity sha512-4wqNb0gRLVaBm/h+lGe8UfPPivcbuJ6ecI4hIgW0LjI7kzpYB9FkN0L9apbVzg+lsBdcTf0AlBtODjcSX5mmKA== + dependencies: + prop-types "^15.7.2" + +"@hapi/address@2.x.x": + version "2.1.4" + resolved "https://registry.yarnpkg.com/@hapi/address/-/address-2.1.4.tgz#5d67ed43f3fd41a69d4b9ff7b56e7c0d1d0a81e5" + integrity sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ== + +"@hapi/bourne@1.x.x": + version "1.3.2" + resolved "https://registry.yarnpkg.com/@hapi/bourne/-/bourne-1.3.2.tgz#0a7095adea067243ce3283e1b56b8a8f453b242a" + integrity sha512-1dVNHT76Uu5N3eJNTYcvxee+jzX4Z9lfciqRRHCU27ihbUcYi+iSc2iml5Ke1LXe1SyJCLA0+14Jh4tXJgOppA== + +"@hapi/hoek@8.x.x", "@hapi/hoek@^8.3.0": + version "8.5.1" + resolved "https://registry.yarnpkg.com/@hapi/hoek/-/hoek-8.5.1.tgz#fde96064ca446dec8c55a8c2f130957b070c6e06" + integrity sha512-yN7kbciD87WzLGc5539Tn0sApjyiGHAJgKvG9W8C7O+6c7qmoQMfVs0W4bX17eqz6C78QJqqFrtgdK5EWf6Qow== + +"@hapi/joi@^15.1.0": + version "15.1.1" + resolved "https://registry.yarnpkg.com/@hapi/joi/-/joi-15.1.1.tgz#c675b8a71296f02833f8d6d243b34c57b8ce19d7" + integrity sha512-entf8ZMOK8sc+8YfeOlM8pCfg3b5+WZIKBfUaaJT8UsjAAPjartzxIYm3TIbjvA4u+u++KbcXD38k682nVHDAQ== + dependencies: + "@hapi/address" "2.x.x" + "@hapi/bourne" "1.x.x" + "@hapi/hoek" "8.x.x" + "@hapi/topo" "3.x.x" + +"@hapi/topo@3.x.x": + version "3.1.6" + resolved "https://registry.yarnpkg.com/@hapi/topo/-/topo-3.1.6.tgz#68d935fa3eae7fdd5ab0d7f953f3205d8b2bfc29" + integrity sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ== + dependencies: + "@hapi/hoek" "^8.3.0" + +"@istanbuljs/load-nyc-config@^1.0.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz#fd3db1d59ecf7cf121e80650bb86712f9b55eced" + integrity sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ== + dependencies: + camelcase "^5.3.1" + find-up "^4.1.0" + get-package-type "^0.1.0" + js-yaml "^3.13.1" + resolve-from "^5.0.0" + +"@istanbuljs/schema@^0.1.2": + version "0.1.3" + resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.3.tgz#e45e384e4b8ec16bce2fd903af78450f6bf7ec98" + integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== + +"@jest/console@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/console/-/console-26.6.2.tgz#4e04bc464014358b03ab4937805ee36a0aeb98f2" + integrity sha512-IY1R2i2aLsLr7Id3S6p2BA82GNWryt4oSvEXLAKc+L2zdi89dSkE8xC1C+0kpATG4JhBJREnQOH7/zmccM2B0g== + dependencies: + "@jest/types" "^26.6.2" + "@types/node" "*" + chalk "^4.0.0" + jest-message-util "^26.6.2" + jest-util "^26.6.2" + slash "^3.0.0" + +"@jest/core@^26.6.0", "@jest/core@^26.6.3": + version "26.6.3" + resolved "https://registry.yarnpkg.com/@jest/core/-/core-26.6.3.tgz#7639fcb3833d748a4656ada54bde193051e45fad" + integrity sha512-xvV1kKbhfUqFVuZ8Cyo+JPpipAHHAV3kcDBftiduK8EICXmTFddryy3P7NfZt8Pv37rA9nEJBKCCkglCPt/Xjw== + dependencies: + "@jest/console" "^26.6.2" + "@jest/reporters" "^26.6.2" + "@jest/test-result" "^26.6.2" + "@jest/transform" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + exit "^0.1.2" + graceful-fs "^4.2.4" + jest-changed-files "^26.6.2" + jest-config "^26.6.3" + jest-haste-map "^26.6.2" + jest-message-util "^26.6.2" + jest-regex-util "^26.0.0" + jest-resolve "^26.6.2" + jest-resolve-dependencies "^26.6.3" + jest-runner "^26.6.3" + jest-runtime "^26.6.3" + jest-snapshot "^26.6.2" + jest-util "^26.6.2" + jest-validate "^26.6.2" + jest-watcher "^26.6.2" + micromatch "^4.0.2" + p-each-series "^2.1.0" + rimraf "^3.0.0" + slash "^3.0.0" + strip-ansi "^6.0.0" + +"@jest/environment@^26.6.0", "@jest/environment@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/environment/-/environment-26.6.2.tgz#ba364cc72e221e79cc8f0a99555bf5d7577cf92c" + integrity sha512-nFy+fHl28zUrRsCeMB61VDThV1pVTtlEokBRgqPrcT1JNq4yRNIyTHfyht6PqtUvY9IsuLGTrbG8kPXjSZIZwA== + dependencies: + "@jest/fake-timers" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + jest-mock "^26.6.2" + +"@jest/fake-timers@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad" + integrity sha512-14Uleatt7jdzefLPYM3KLcnUl1ZNikaKq34enpb5XG9i81JpppDb5muZvonvKyrl7ftEHkKS5L5/eB/kxJ+bvA== + dependencies: + "@jest/types" "^26.6.2" + "@sinonjs/fake-timers" "^6.0.1" + "@types/node" "*" + jest-message-util "^26.6.2" + jest-mock "^26.6.2" + jest-util "^26.6.2" + +"@jest/globals@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/globals/-/globals-26.6.2.tgz#5b613b78a1aa2655ae908eba638cc96a20df720a" + integrity sha512-85Ltnm7HlB/KesBUuALwQ68YTU72w9H2xW9FjZ1eL1U3lhtefjjl5c2MiUbpXt/i6LaPRvoOFJ22yCBSfQ0JIA== + dependencies: + "@jest/environment" "^26.6.2" + "@jest/types" "^26.6.2" + expect "^26.6.2" + +"@jest/reporters@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/reporters/-/reporters-26.6.2.tgz#1f518b99637a5f18307bd3ecf9275f6882a667f6" + integrity sha512-h2bW53APG4HvkOnVMo8q3QXa6pcaNt1HkwVsOPMBV6LD/q9oSpxNSYZQYkAnjdMjrJ86UuYeLo+aEZClV6opnw== + dependencies: + "@bcoe/v8-coverage" "^0.2.3" + "@jest/console" "^26.6.2" + "@jest/test-result" "^26.6.2" + "@jest/transform" "^26.6.2" + "@jest/types" "^26.6.2" + chalk "^4.0.0" + collect-v8-coverage "^1.0.0" + exit "^0.1.2" + glob "^7.1.2" + graceful-fs "^4.2.4" + istanbul-lib-coverage "^3.0.0" + istanbul-lib-instrument "^4.0.3" + istanbul-lib-report "^3.0.0" + istanbul-lib-source-maps "^4.0.0" + istanbul-reports "^3.0.2" + jest-haste-map "^26.6.2" + jest-resolve "^26.6.2" + jest-util "^26.6.2" + jest-worker "^26.6.2" + slash "^3.0.0" + source-map "^0.6.0" + string-length "^4.0.1" + terminal-link "^2.0.0" + v8-to-istanbul "^7.0.0" + optionalDependencies: + node-notifier "^8.0.0" + +"@jest/source-map@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-26.6.2.tgz#29af5e1e2e324cafccc936f218309f54ab69d535" + integrity sha512-YwYcCwAnNmOVsZ8mr3GfnzdXDAl4LaenZP5z+G0c8bzC9/dugL8zRmxZzdoTl4IaS3CryS1uWnROLPFmb6lVvA== + dependencies: + callsites "^3.0.0" + graceful-fs "^4.2.4" + source-map "^0.6.0" + +"@jest/test-result@^26.6.0", "@jest/test-result@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-26.6.2.tgz#55da58b62df134576cc95476efa5f7949e3f5f18" + integrity sha512-5O7H5c/7YlojphYNrK02LlDIV2GNPYisKwHm2QTKjNZeEzezCbwYs9swJySv2UfPMyZ0VdsmMv7jIlD/IKYQpQ== + dependencies: + "@jest/console" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/istanbul-lib-coverage" "^2.0.0" + collect-v8-coverage "^1.0.0" + +"@jest/test-sequencer@^26.6.3": + version "26.6.3" + resolved "https://registry.yarnpkg.com/@jest/test-sequencer/-/test-sequencer-26.6.3.tgz#98e8a45100863886d074205e8ffdc5a7eb582b17" + integrity sha512-YHlVIjP5nfEyjlrSr8t/YdNfU/1XEt7c5b4OxcXCjyRhjzLYu/rO69/WHPuYcbCWkz8kAeZVZp2N2+IOLLEPGw== + dependencies: + "@jest/test-result" "^26.6.2" + graceful-fs "^4.2.4" + jest-haste-map "^26.6.2" + jest-runner "^26.6.3" + jest-runtime "^26.6.3" + +"@jest/transform@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-26.6.2.tgz#5ac57c5fa1ad17b2aae83e73e45813894dcf2e4b" + integrity sha512-E9JjhUgNzvuQ+vVAL21vlyfy12gP0GhazGgJC4h6qUt1jSdUXGWJ1wfu/X7Sd8etSgxV4ovT1pb9v5D6QW4XgA== + dependencies: + "@babel/core" "^7.1.0" + "@jest/types" "^26.6.2" + babel-plugin-istanbul "^6.0.0" + chalk "^4.0.0" + convert-source-map "^1.4.0" + fast-json-stable-stringify "^2.0.0" + graceful-fs "^4.2.4" + jest-haste-map "^26.6.2" + jest-regex-util "^26.0.0" + jest-util "^26.6.2" + micromatch "^4.0.2" + pirates "^4.0.1" + slash "^3.0.0" + source-map "^0.6.1" + write-file-atomic "^3.0.0" + +"@jest/types@^26.6.0", "@jest/types@^26.6.2": + version "26.6.2" + resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e" + integrity sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.0" + "@types/istanbul-reports" "^3.0.0" + "@types/node" "*" + "@types/yargs" "^15.0.0" + chalk "^4.0.0" + +"@nodelib/fs.scandir@2.1.4": + version "2.1.4" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz#d4b3549a5db5de2683e0c1071ab4f140904bbf69" + integrity sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA== + dependencies: + "@nodelib/fs.stat" "2.0.4" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.4", "@nodelib/fs.stat@^2.0.2": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz#a3f2dd61bab43b8db8fa108a121cfffe4c676655" + integrity sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q== + +"@nodelib/fs.walk@^1.2.3": + version "1.2.6" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz#cce9396b30aa5afe9e3756608f5831adcb53d063" + integrity sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow== + dependencies: + "@nodelib/fs.scandir" "2.1.4" + fastq "^1.6.0" + +"@npmcli/move-file@^1.0.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-1.1.2.tgz#1a82c3e372f7cae9253eb66d72543d6b8685c674" + integrity sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg== + dependencies: + mkdirp "^1.0.4" + rimraf "^3.0.2" + +"@pmmmwh/react-refresh-webpack-plugin@0.4.3": + version "0.4.3" + resolved "https://registry.yarnpkg.com/@pmmmwh/react-refresh-webpack-plugin/-/react-refresh-webpack-plugin-0.4.3.tgz#1eec460596d200c0236bf195b078a5d1df89b766" + integrity sha512-br5Qwvh8D2OQqSXpd1g/xqXKnK0r+Jz6qVKBbWmpUcrbGOxUrf39V5oZ1876084CGn18uMdR5uvPqBv9UqtBjQ== + dependencies: + ansi-html "^0.0.7" + error-stack-parser "^2.0.6" + html-entities "^1.2.1" + native-url "^0.2.6" + schema-utils "^2.6.5" + source-map "^0.7.3" + +"@polka/url@^1.0.0-next.9": + version "1.0.0-next.12" + resolved "https://registry.yarnpkg.com/@polka/url/-/url-1.0.0-next.12.tgz#431ec342a7195622f86688bbda82e3166ce8cb28" + integrity sha512-6RglhutqrGFMO1MNUXp95RBuYIuc8wTnMAV5MUhLmjTOy78ncwOw7RgeQ/HeymkKXRhZd0s2DNrM1rL7unk3MQ== + +"@rollup/plugin-node-resolve@^7.1.1": + version "7.1.3" + resolved "https://registry.yarnpkg.com/@rollup/plugin-node-resolve/-/plugin-node-resolve-7.1.3.tgz#80de384edfbd7bfc9101164910f86078151a3eca" + integrity sha512-RxtSL3XmdTAE2byxekYLnx+98kEUOrPHF/KRVjLH+DEIHy6kjIw7YINQzn+NXiH/NTrQLAwYs0GWB+csWygA9Q== + dependencies: + "@rollup/pluginutils" "^3.0.8" + "@types/resolve" "0.0.8" + builtin-modules "^3.1.0" + is-module "^1.0.0" + resolve "^1.14.2" + +"@rollup/plugin-replace@^2.3.1": + version "2.4.2" + resolved "https://registry.yarnpkg.com/@rollup/plugin-replace/-/plugin-replace-2.4.2.tgz#a2d539314fbc77c244858faa523012825068510a" + integrity sha512-IGcu+cydlUMZ5En85jxHH4qj2hta/11BHq95iHEyb2sbgiN0eCdzvUcHw5gt9pBL5lTi4JDYJ1acCoMGpTvEZg== + dependencies: + "@rollup/pluginutils" "^3.1.0" + magic-string "^0.25.7" + +"@rollup/pluginutils@^3.0.8", "@rollup/pluginutils@^3.1.0": + version "3.1.0" + resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-3.1.0.tgz#706b4524ee6dc8b103b3c995533e5ad680c02b9b" + integrity sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg== + dependencies: + "@types/estree" "0.0.39" + estree-walker "^1.0.1" + picomatch "^2.2.2" + +"@sinonjs/commons@^1.7.0": + version "1.8.2" + resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-1.8.2.tgz#858f5c4b48d80778fde4b9d541f27edc0d56488b" + integrity sha512-sruwd86RJHdsVf/AtBoijDmUqJp3B6hF/DGC23C+JaegnDHaZyewCjoVGTdg3J0uz3Zs7NnIT05OBOmML72lQw== + dependencies: + type-detect "4.0.8" + +"@sinonjs/fake-timers@^6.0.1": + version "6.0.1" + resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-6.0.1.tgz#293674fccb3262ac782c7aadfdeca86b10c75c40" + integrity sha512-MZPUxrmFubI36XS1DI3qmI0YdN1gks62JtFZvxR67ljjSNCeK6U08Zx4msEWOXuofgqUt6zPHSi1H9fbjR/NRA== + dependencies: + "@sinonjs/commons" "^1.7.0" + +"@surma/rollup-plugin-off-main-thread@^1.1.1": + version "1.4.2" + resolved "https://registry.yarnpkg.com/@surma/rollup-plugin-off-main-thread/-/rollup-plugin-off-main-thread-1.4.2.tgz#e6786b6af5799f82f7ab3a82e53f6182d2b91a58" + integrity sha512-yBMPqmd1yEJo/280PAMkychuaALyQ9Lkb5q1ck3mjJrFuEobIfhnQ4J3mbvBoISmR3SWMWV+cGB/I0lCQee79A== + dependencies: + ejs "^2.6.1" + magic-string "^0.25.0" + +"@svgr/babel-plugin-add-jsx-attribute@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-5.4.0.tgz#81ef61947bb268eb9d50523446f9c638fb355906" + integrity sha512-ZFf2gs/8/6B8PnSofI0inYXr2SDNTDScPXhN7k5EqD4aZ3gi6u+rbmZHVB8IM3wDyx8ntKACZbtXSm7oZGRqVg== + +"@svgr/babel-plugin-remove-jsx-attribute@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-5.4.0.tgz#6b2c770c95c874654fd5e1d5ef475b78a0a962ef" + integrity sha512-yaS4o2PgUtwLFGTKbsiAy6D0o3ugcUhWK0Z45umJ66EPWunAz9fuFw2gJuje6wqQvQWOTJvIahUwndOXb7QCPg== + +"@svgr/babel-plugin-remove-jsx-empty-expression@^5.0.1": + version "5.0.1" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-5.0.1.tgz#25621a8915ed7ad70da6cea3d0a6dbc2ea933efd" + integrity sha512-LA72+88A11ND/yFIMzyuLRSMJ+tRKeYKeQ+mR3DcAZ5I4h5CPWN9AHyUzJbWSYp/u2u0xhmgOe0+E41+GjEueA== + +"@svgr/babel-plugin-replace-jsx-attribute-value@^5.0.1": + version "5.0.1" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-5.0.1.tgz#0b221fc57f9fcd10e91fe219e2cd0dd03145a897" + integrity sha512-PoiE6ZD2Eiy5mK+fjHqwGOS+IXX0wq/YDtNyIgOrc6ejFnxN4b13pRpiIPbtPwHEc+NT2KCjteAcq33/F1Y9KQ== + +"@svgr/babel-plugin-svg-dynamic-title@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-5.4.0.tgz#139b546dd0c3186b6e5db4fefc26cb0baea729d7" + integrity sha512-zSOZH8PdZOpuG1ZVx/cLVePB2ibo3WPpqo7gFIjLV9a0QsuQAzJiwwqmuEdTaW2pegyBE17Uu15mOgOcgabQZg== + +"@svgr/babel-plugin-svg-em-dimensions@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-5.4.0.tgz#6543f69526632a133ce5cabab965deeaea2234a0" + integrity sha512-cPzDbDA5oT/sPXDCUYoVXEmm3VIoAWAPT6mSPTJNbQaBNUuEKVKyGH93oDY4e42PYHRW67N5alJx/eEol20abw== + +"@svgr/babel-plugin-transform-react-native-svg@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-5.4.0.tgz#00bf9a7a73f1cad3948cdab1f8dfb774750f8c80" + integrity sha512-3eYP/SaopZ41GHwXma7Rmxcv9uRslRDTY1estspeB1w1ueZWd/tPlMfEOoccYpEMZU3jD4OU7YitnXcF5hLW2Q== + +"@svgr/babel-plugin-transform-svg-component@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-5.5.0.tgz#583a5e2a193e214da2f3afeb0b9e8d3250126b4a" + integrity sha512-q4jSH1UUvbrsOtlo/tKcgSeiCHRSBdXoIoqX1pgcKK/aU3JD27wmMKwGtpB8qRYUYoyXvfGxUVKchLuR5pB3rQ== + +"@svgr/babel-preset@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/babel-preset/-/babel-preset-5.5.0.tgz#8af54f3e0a8add7b1e2b0fcd5a882c55393df327" + integrity sha512-4FiXBjvQ+z2j7yASeGPEi8VD/5rrGQk4Xrq3EdJmoZgz/tpqChpo5hgXDvmEauwtvOc52q8ghhZK4Oy7qph4ig== + dependencies: + "@svgr/babel-plugin-add-jsx-attribute" "^5.4.0" + "@svgr/babel-plugin-remove-jsx-attribute" "^5.4.0" + "@svgr/babel-plugin-remove-jsx-empty-expression" "^5.0.1" + "@svgr/babel-plugin-replace-jsx-attribute-value" "^5.0.1" + "@svgr/babel-plugin-svg-dynamic-title" "^5.4.0" + "@svgr/babel-plugin-svg-em-dimensions" "^5.4.0" + "@svgr/babel-plugin-transform-react-native-svg" "^5.4.0" + "@svgr/babel-plugin-transform-svg-component" "^5.5.0" + +"@svgr/core@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/core/-/core-5.5.0.tgz#82e826b8715d71083120fe8f2492ec7d7874a579" + integrity sha512-q52VOcsJPvV3jO1wkPtzTuKlvX7Y3xIcWRpCMtBF3MrteZJtBfQw/+u0B1BHy5ColpQc1/YVTrPEtSYIMNZlrQ== + dependencies: + "@svgr/plugin-jsx" "^5.5.0" + camelcase "^6.2.0" + cosmiconfig "^7.0.0" + +"@svgr/hast-util-to-babel-ast@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-5.5.0.tgz#5ee52a9c2533f73e63f8f22b779f93cd432a5461" + integrity sha512-cAaR/CAiZRB8GP32N+1jocovUtvlj0+e65TB50/6Lcime+EA49m/8l+P2ko+XPJ4dw3xaPS3jOL4F2X4KWxoeQ== + dependencies: + "@babel/types" "^7.12.6" + +"@svgr/plugin-jsx@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/plugin-jsx/-/plugin-jsx-5.5.0.tgz#1aa8cd798a1db7173ac043466d7b52236b369000" + integrity sha512-V/wVh33j12hGh05IDg8GpIUXbjAPnTdPTKuP4VNLggnwaHMPNQNae2pRnyTAILWCQdz5GyMqtO488g7CKM8CBA== + dependencies: + "@babel/core" "^7.12.3" + "@svgr/babel-preset" "^5.5.0" + "@svgr/hast-util-to-babel-ast" "^5.5.0" + svg-parser "^2.0.2" + +"@svgr/plugin-svgo@^5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/plugin-svgo/-/plugin-svgo-5.5.0.tgz#02da55d85320549324e201c7b2e53bf431fcc246" + integrity sha512-r5swKk46GuQl4RrVejVwpeeJaydoxkdwkM1mBKOgJLBUJPGaLci6ylg/IjhrRsREKDkr4kbMWdgOtbXEh0fyLQ== + dependencies: + cosmiconfig "^7.0.0" + deepmerge "^4.2.2" + svgo "^1.2.2" + +"@svgr/webpack@5.5.0": + version "5.5.0" + resolved "https://registry.yarnpkg.com/@svgr/webpack/-/webpack-5.5.0.tgz#aae858ee579f5fa8ce6c3166ef56c6a1b381b640" + integrity sha512-DOBOK255wfQxguUta2INKkzPj6AIS6iafZYiYmHn6W3pHlycSRRlvWKCfLDG10fXfLWqE3DJHgRUOyJYmARa7g== + dependencies: + "@babel/core" "^7.12.3" + "@babel/plugin-transform-react-constant-elements" "^7.12.1" + "@babel/preset-env" "^7.12.1" + "@babel/preset-react" "^7.12.5" + "@svgr/core" "^5.5.0" + "@svgr/plugin-jsx" "^5.5.0" + "@svgr/plugin-svgo" "^5.5.0" + loader-utils "^2.0.0" + +"@testing-library/dom@^7.28.1": + version "7.30.2" + resolved "https://registry.yarnpkg.com/@testing-library/dom/-/dom-7.30.2.tgz#a63ae7078235ec6248a8a522b04e696ab49896cc" + integrity sha512-NJzHILb5De0J0varzT0W00qDTLcbF86etfAyx5ty7iJhpR6eCs+JR99Ls7AMSUG2bWRYIG0u4KTPH6PMcZhlWQ== + dependencies: + "@babel/code-frame" "^7.10.4" + "@babel/runtime" "^7.12.5" + "@types/aria-query" "^4.2.0" + aria-query "^4.2.2" + chalk "^4.1.0" + dom-accessibility-api "^0.5.4" + lz-string "^1.4.4" + pretty-format "^26.6.2" + +"@testing-library/jest-dom@^5.11.4": + version "5.11.10" + resolved "https://registry.yarnpkg.com/@testing-library/jest-dom/-/jest-dom-5.11.10.tgz#1cd90715023e1627f5ed26ab3b38e6f22d77046c" + integrity sha512-FuKiq5xuk44Fqm0000Z9w0hjOdwZRNzgx7xGGxQYepWFZy+OYUMOT/wPI4nLYXCaVltNVpU1W/qmD88wLWDsqQ== + dependencies: + "@babel/runtime" "^7.9.2" + "@types/testing-library__jest-dom" "^5.9.1" + aria-query "^4.2.2" + chalk "^3.0.0" + css "^3.0.0" + css.escape "^1.5.1" + lodash "^4.17.15" + redent "^3.0.0" + +"@testing-library/react@^11.1.0": + version "11.2.6" + resolved "https://registry.yarnpkg.com/@testing-library/react/-/react-11.2.6.tgz#586a23adc63615985d85be0c903f374dab19200b" + integrity sha512-TXMCg0jT8xmuU8BkKMtp8l7Z50Ykew5WNX8UoIKTaLFwKkP2+1YDhOLA2Ga3wY4x29jyntk7EWfum0kjlYiSjQ== + dependencies: + "@babel/runtime" "^7.12.5" + "@testing-library/dom" "^7.28.1" + +"@testing-library/user-event@^12.1.10": + version "12.8.3" + resolved "https://registry.yarnpkg.com/@testing-library/user-event/-/user-event-12.8.3.tgz#1aa3ed4b9f79340a1e1836bc7f57c501e838704a" + integrity sha512-IR0iWbFkgd56Bu5ZI/ej8yQwrkCv8Qydx6RzwbKz9faXazR/+5tvYKsZQgyXJiwgpcva127YO6JcWy7YlCfofQ== + dependencies: + "@babel/runtime" "^7.12.5" + +"@types/anymatch@*": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@types/anymatch/-/anymatch-1.3.1.tgz#336badc1beecb9dacc38bea2cf32adf627a8421a" + integrity sha512-/+CRPXpBDpo2RK9C68N3b2cOvO0Cf5B9aPijHsoDQTHivnGSObdOF2BRQOYjojWTDy6nQvMjmqRXIxH55VjxxA== + +"@types/aria-query@^4.2.0": + version "4.2.1" + resolved "https://registry.yarnpkg.com/@types/aria-query/-/aria-query-4.2.1.tgz#78b5433344e2f92e8b306c06a5622c50c245bf6b" + integrity sha512-S6oPal772qJZHoRZLFc/XoZW2gFvwXusYUmXPXkgxJLuEk2vOt7jc4Yo6z/vtI0EBkbPBVrJJ0B+prLIKiWqHg== + +"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.7": + version "7.1.14" + resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.14.tgz#faaeefc4185ec71c389f4501ee5ec84b170cc402" + integrity sha512-zGZJzzBUVDo/eV6KgbE0f0ZI7dInEYvo12Rb70uNQDshC3SkRMb67ja0GgRHZgAX3Za6rhaWlvbDO8rrGyAb1g== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + "@types/babel__generator" "*" + "@types/babel__template" "*" + "@types/babel__traverse" "*" + +"@types/babel__generator@*": + version "7.6.2" + resolved "https://registry.yarnpkg.com/@types/babel__generator/-/babel__generator-7.6.2.tgz#f3d71178e187858f7c45e30380f8f1b7415a12d8" + integrity sha512-MdSJnBjl+bdwkLskZ3NGFp9YcXGx5ggLpQQPqtgakVhsWK0hTtNYhjpZLlWQTviGTvF8at+Bvli3jV7faPdgeQ== + dependencies: + "@babel/types" "^7.0.0" + +"@types/babel__template@*": + version "7.4.0" + resolved "https://registry.yarnpkg.com/@types/babel__template/-/babel__template-7.4.0.tgz#0c888dd70b3ee9eebb6e4f200e809da0076262be" + integrity sha512-NTPErx4/FiPCGScH7foPyr+/1Dkzkni+rHiYHHoTjvwou7AQzJkNeD60A9CXRy+ZEN2B1bggmkTMCDb+Mv5k+A== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + +"@types/babel__traverse@*", "@types/babel__traverse@^7.0.4", "@types/babel__traverse@^7.0.6": + version "7.11.1" + resolved "https://registry.yarnpkg.com/@types/babel__traverse/-/babel__traverse-7.11.1.tgz#654f6c4f67568e24c23b367e947098c6206fa639" + integrity sha512-Vs0hm0vPahPMYi9tDjtP66llufgO3ST16WXaSTtDGEl9cewAl3AibmxWw6TINOqHPT9z0uABKAYjT9jNSg4npw== + dependencies: + "@babel/types" "^7.3.0" + +"@types/eslint@^7.2.6": + version "7.2.7" + resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-7.2.7.tgz#f7ef1cf0dceab0ae6f9a976a0a9af14ab1baca26" + integrity sha512-EHXbc1z2GoQRqHaAT7+grxlTJ3WE2YNeD6jlpPoRc83cCoThRY+NUWjCUZaYmk51OICkPXn2hhphcWcWXgNW0Q== + dependencies: + "@types/estree" "*" + "@types/json-schema" "*" + +"@types/estree@*": + version "0.0.47" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-0.0.47.tgz#d7a51db20f0650efec24cd04994f523d93172ed4" + integrity sha512-c5ciR06jK8u9BstrmJyO97m+klJrrhCf9u3rLu3DEAJBirxRqSCvDQoYKmxuYwQI5SZChAWu+tq9oVlGRuzPAg== + +"@types/estree@0.0.39": + version "0.0.39" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-0.0.39.tgz#e177e699ee1b8c22d23174caaa7422644389509f" + integrity sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw== + +"@types/glob@^7.1.1": + version "7.1.3" + resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.1.3.tgz#e6ba80f36b7daad2c685acd9266382e68985c183" + integrity sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w== + dependencies: + "@types/minimatch" "*" + "@types/node" "*" + +"@types/graceful-fs@^4.1.2": + version "4.1.5" + resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15" + integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw== + dependencies: + "@types/node" "*" + +"@types/history@*": + version "4.7.8" + resolved "https://registry.yarnpkg.com/@types/history/-/history-4.7.8.tgz#49348387983075705fe8f4e02fb67f7daaec4934" + integrity sha512-S78QIYirQcUoo6UJZx9CSP0O2ix9IaeAXwQi26Rhr/+mg7qqPy8TzaxHSUut7eGjL8WmLccT7/MXf304WjqHcA== + +"@types/html-minifier-terser@^5.0.0": + version "5.1.1" + resolved "https://registry.yarnpkg.com/@types/html-minifier-terser/-/html-minifier-terser-5.1.1.tgz#3c9ee980f1a10d6021ae6632ca3e79ca2ec4fb50" + integrity sha512-giAlZwstKbmvMk1OO7WXSj4OZ0keXAcl2TQq4LWHiiPH2ByaH7WeUzng+Qej8UPxxv+8lRTuouo0iaNDBuzIBA== + +"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.3.tgz#4ba8ddb720221f432e443bd5f9117fd22cfd4762" + integrity sha512-sz7iLqvVUg1gIedBOvlkxPlc8/uVzyS5OwGz1cKjXzkl3FpL3al0crU8YGU1WoHkxn0Wxbw5tyi6hvzJKNzFsw== + +"@types/istanbul-lib-report@*": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#c14c24f18ea8190c118ee7562b7ff99a36552686" + integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== + dependencies: + "@types/istanbul-lib-coverage" "*" + +"@types/istanbul-reports@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.0.tgz#508b13aa344fa4976234e75dddcc34925737d821" + integrity sha512-nwKNbvnwJ2/mndE9ItP/zc2TCzw6uuodnF4EHYWD+gCQDVBuRQL5UzbZD0/ezy1iKsFU2ZQiDqg4M9dN4+wZgA== + dependencies: + "@types/istanbul-lib-report" "*" + +"@types/jest@*", "@types/jest@^26.0.15": + version "26.0.22" + resolved "https://registry.yarnpkg.com/@types/jest/-/jest-26.0.22.tgz#8308a1debdf1b807aa47be2838acdcd91e88fbe6" + integrity sha512-eeWwWjlqxvBxc4oQdkueW5OF/gtfSceKk4OnOAGlUSwS/liBRtZppbJuz1YkgbrbfGOoeBHun9fOvXnjNwrSOw== + dependencies: + jest-diff "^26.0.0" + pretty-format "^26.0.0" + +"@types/json-schema@*", "@types/json-schema@^7.0.3", "@types/json-schema@^7.0.5", "@types/json-schema@^7.0.6": + version "7.0.7" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.7.tgz#98a993516c859eb0d5c4c8f098317a9ea68db9ad" + integrity sha512-cxWFQVseBm6O9Gbw1IWb8r6OS4OhSt3hPZLkFApLjM8TEXROBuQGLAH2i2gZpcXdLBIrpXuTDhH7Vbm1iXmNGA== + +"@types/json5@^0.0.29": + version "0.0.29" + resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" + integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4= + +"@types/minimatch@*": + version "3.0.4" + resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.4.tgz#f0ec25dbf2f0e4b18647313ac031134ca5b24b21" + integrity sha512-1z8k4wzFnNjVK/tlxvrWuK5WMt6mydWWP7+zvH5eFep4oj+UkrfiJTRtjCeBXNpwaA/FYqqtb4/QS4ianFpIRA== + +"@types/node@*": + version "14.14.37" + resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.37.tgz#a3dd8da4eb84a996c36e331df98d82abd76b516e" + integrity sha512-XYmBiy+ohOR4Lh5jE379fV2IU+6Jn4g5qASinhitfyO71b/sCo6MKsMLF5tc7Zf2CE8hViVQyYSobJNke8OvUw== + +"@types/node@^12.0.0": + version "12.20.7" + resolved "https://registry.yarnpkg.com/@types/node/-/node-12.20.7.tgz#1cb61fd0c85cb87e728c43107b5fd82b69bc9ef8" + integrity sha512-gWL8VUkg8VRaCAUgG9WmhefMqHmMblxe2rVpMF86nZY/+ZysU+BkAp+3cz03AixWDSSz0ks5WX59yAhv/cDwFA== + +"@types/normalize-package-data@^2.4.0": + version "2.4.0" + resolved "https://registry.yarnpkg.com/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz#e486d0d97396d79beedd0a6e33f4534ff6b4973e" + integrity sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA== + +"@types/parse-json@^4.0.0": + version "4.0.0" + resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" + integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== + +"@types/prettier@^2.0.0": + version "2.2.3" + resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.2.3.tgz#ef65165aea2924c9359205bf748865b8881753c0" + integrity sha512-PijRCG/K3s3w1We6ynUKdxEc5AcuuH3NBmMDP8uvKVp6X43UY7NQlTzczakXP3DJR0F4dfNQIGjU2cUeRYs2AA== + +"@types/prop-types@*": + version "15.7.3" + resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.3.tgz#2ab0d5da2e5815f94b0b9d4b95d1e5f243ab2ca7" + integrity sha512-KfRL3PuHmqQLOG+2tGpRO26Ctg+Cq1E01D2DMriKEATHgWLfeNDmq9e29Q9WIky0dQ3NPkd1mzYH8Lm936Z9qw== + +"@types/q@^1.5.1": + version "1.5.4" + resolved "https://registry.yarnpkg.com/@types/q/-/q-1.5.4.tgz#15925414e0ad2cd765bfef58842f7e26a7accb24" + integrity sha512-1HcDas8SEj4z1Wc696tH56G8OlRaH/sqZOynNNB+HF0WOeXPaxTtbYzJY2oEfiUxjSKjhCKr+MvR7dCHcEelug== + +"@types/react-dom@^17.0.0": + version "17.0.3" + resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-17.0.3.tgz#7fdf37b8af9d6d40127137865bb3fff8871d7ee1" + integrity sha512-4NnJbCeWE+8YBzupn/YrJxZ8VnjcJq5iR1laqQ1vkpQgBiA7bwk0Rp24fxsdNinzJY2U+HHS4dJJDPdoMjdJ7w== + dependencies: + "@types/react" "*" + +"@types/react-helmet@^6.1.0": + version "6.1.0" + resolved "https://registry.yarnpkg.com/@types/react-helmet/-/react-helmet-6.1.0.tgz#af586ed685f4905e2adc7462d1d65ace52beee7a" + integrity sha512-PYRoU1XJFOzQ3BHvWL1T8iDNbRjdMDJMT5hFmZKGbsq09kbSqJy61uwEpTrbTNWDopVphUT34zUSVLK9pjsgYQ== + dependencies: + "@types/react" "*" + +"@types/react-router-dom@^5.1.7": + version "5.1.7" + resolved "https://registry.yarnpkg.com/@types/react-router-dom/-/react-router-dom-5.1.7.tgz#a126d9ea76079ffbbdb0d9225073eb5797ab7271" + integrity sha512-D5mHD6TbdV/DNHYsnwBTv+y73ei+mMjrkGrla86HthE4/PVvL1J94Bu3qABU+COXzpL23T1EZapVVpwHuBXiUg== + dependencies: + "@types/history" "*" + "@types/react" "*" + "@types/react-router" "*" + +"@types/react-router@*": + version "5.1.13" + resolved "https://registry.yarnpkg.com/@types/react-router/-/react-router-5.1.13.tgz#051c0d229bd48ad90558a1db500708127cc512f7" + integrity sha512-ZIuaO9Yrln54X6elg8q2Ivp6iK6p4syPsefEYAhRDAoqNh48C8VYUmB9RkXjKSQAJSJV0mbIFCX7I4vZDcHrjg== + dependencies: + "@types/history" "*" + "@types/react" "*" + +"@types/react@*", "@types/react@^17.0.0", "@types/react@^17.0.2": + version "17.0.3" + resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.3.tgz#ba6e215368501ac3826951eef2904574c262cc79" + integrity sha512-wYOUxIgs2HZZ0ACNiIayItyluADNbONl7kt8lkLjVK8IitMH5QMyAh75Fwhmo37r1m7L2JaFj03sIfxBVDvRAg== + dependencies: + "@types/prop-types" "*" + "@types/scheduler" "*" + csstype "^3.0.2" + +"@types/resolve@0.0.8": + version "0.0.8" + resolved "https://registry.yarnpkg.com/@types/resolve/-/resolve-0.0.8.tgz#f26074d238e02659e323ce1a13d041eee280e194" + integrity sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ== + dependencies: + "@types/node" "*" + +"@types/scheduler@*": + version "0.16.1" + resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.1.tgz#18845205e86ff0038517aab7a18a62a6b9f71275" + integrity sha512-EaCxbanVeyxDRTQBkdLb3Bvl/HK7PBK6UJjsSixB0iHKoWxE5uu2Q/DgtpOhPIojN0Zl1whvOd7PoHs2P0s5eA== + +"@types/source-list-map@*": + version "0.1.2" + resolved "https://registry.yarnpkg.com/@types/source-list-map/-/source-list-map-0.1.2.tgz#0078836063ffaf17412349bba364087e0ac02ec9" + integrity sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA== + +"@types/stack-utils@^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.0.tgz#7036640b4e21cc2f259ae826ce843d277dad8cff" + integrity sha512-RJJrrySY7A8havqpGObOB4W92QXKJo63/jFLLgpvOtsGUqbQZ9Sbgl35KMm1DjC6j7AvmmU2bIno+3IyEaemaw== + +"@types/tapable@^1", "@types/tapable@^1.0.5": + version "1.0.7" + resolved "https://registry.yarnpkg.com/@types/tapable/-/tapable-1.0.7.tgz#545158342f949e8fd3bfd813224971ecddc3fac4" + integrity sha512-0VBprVqfgFD7Ehb2vd8Lh9TG3jP98gvr8rgehQqzztZNI7o8zS8Ad4jyZneKELphpuE212D8J70LnSNQSyO6bQ== + +"@types/testing-library__jest-dom@^5.9.1": + version "5.9.5" + resolved "https://registry.yarnpkg.com/@types/testing-library__jest-dom/-/testing-library__jest-dom-5.9.5.tgz#5bf25c91ad2d7b38f264b12275e5c92a66d849b0" + integrity sha512-ggn3ws+yRbOHog9GxnXiEZ/35Mow6YtPZpd7Z5mKDeZS/o7zx3yAle0ov/wjhVB5QT4N2Dt+GNoGCdqkBGCajQ== + dependencies: + "@types/jest" "*" + +"@types/uglify-js@*": + version "3.13.0" + resolved "https://registry.yarnpkg.com/@types/uglify-js/-/uglify-js-3.13.0.tgz#1cad8df1fb0b143c5aba08de5712ea9d1ff71124" + integrity sha512-EGkrJD5Uy+Pg0NUR8uA4bJ5WMfljyad0G+784vLCNUkD+QwOJXUbBYExXfVGf7YtyzdQp3L/XMYcliB987kL5Q== + dependencies: + source-map "^0.6.1" + +"@types/webpack-sources@*": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@types/webpack-sources/-/webpack-sources-2.1.0.tgz#8882b0bd62d1e0ce62f183d0d01b72e6e82e8c10" + integrity sha512-LXn/oYIpBeucgP1EIJbKQ2/4ZmpvRl+dlrFdX7+94SKRUV3Evy3FsfMZY318vGhkWUS5MPhtOM3w1/hCOAOXcg== + dependencies: + "@types/node" "*" + "@types/source-list-map" "*" + source-map "^0.7.3" + +"@types/webpack@^4.41.8": + version "4.41.27" + resolved "https://registry.yarnpkg.com/@types/webpack/-/webpack-4.41.27.tgz#f47da488c8037e7f1b2dbf2714fbbacb61ec0ffc" + integrity sha512-wK/oi5gcHi72VMTbOaQ70VcDxSQ1uX8S2tukBK9ARuGXrYM/+u4ou73roc7trXDNmCxCoerE8zruQqX/wuHszA== + dependencies: + "@types/anymatch" "*" + "@types/node" "*" + "@types/tapable" "^1" + "@types/uglify-js" "*" + "@types/webpack-sources" "*" + source-map "^0.6.0" + +"@types/yargs-parser@*": + version "20.2.0" + resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-20.2.0.tgz#dd3e6699ba3237f0348cd085e4698780204842f9" + integrity sha512-37RSHht+gzzgYeobbG+KWryeAW8J33Nhr69cjTqSYymXVZEN9NbRYWoYlRtDhHKPVT1FyNKwaTPC1NynKZpzRA== + +"@types/yargs@^15.0.0": + version "15.0.13" + resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-15.0.13.tgz#34f7fec8b389d7f3c1fd08026a5763e072d3c6dc" + integrity sha512-kQ5JNTrbDv3Rp5X2n/iUu37IJBDU2gsZ5R/g1/KHOOEc5IKfUFjXT6DENPGduh08I/pamwtEq4oul7gUqKTQDQ== + dependencies: + "@types/yargs-parser" "*" + +"@typescript-eslint/eslint-plugin@^4.5.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.20.0.tgz#9d8794bd99aad9153092ad13c96164e3082e9a92" + integrity sha512-sw+3HO5aehYqn5w177z2D82ZQlqHCwcKSMboueo7oE4KU9QiC0SAgfS/D4z9xXvpTc8Bt41Raa9fBR8T2tIhoQ== + dependencies: + "@typescript-eslint/experimental-utils" "4.20.0" + "@typescript-eslint/scope-manager" "4.20.0" + debug "^4.1.1" + functional-red-black-tree "^1.0.1" + lodash "^4.17.15" + regexpp "^3.0.0" + semver "^7.3.2" + tsutils "^3.17.1" + +"@typescript-eslint/experimental-utils@4.20.0", "@typescript-eslint/experimental-utils@^4.0.1": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-4.20.0.tgz#a8ab2d7b61924f99042b7d77372996d5f41dc44b" + integrity sha512-sQNlf6rjLq2yB5lELl3gOE7OuoA/6IVXJUJ+Vs7emrQMva14CkOwyQwD7CW+TkmOJ4Q/YGmoDLmbfFrpGmbKng== + dependencies: + "@types/json-schema" "^7.0.3" + "@typescript-eslint/scope-manager" "4.20.0" + "@typescript-eslint/types" "4.20.0" + "@typescript-eslint/typescript-estree" "4.20.0" + eslint-scope "^5.0.0" + eslint-utils "^2.0.0" + +"@typescript-eslint/experimental-utils@^3.10.1": + version "3.10.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-3.10.1.tgz#e179ffc81a80ebcae2ea04e0332f8b251345a686" + integrity sha512-DewqIgscDzmAfd5nOGe4zm6Bl7PKtMG2Ad0KG8CUZAHlXfAKTF9Ol5PXhiMh39yRL2ChRH1cuuUGOcVyyrhQIw== + dependencies: + "@types/json-schema" "^7.0.3" + "@typescript-eslint/types" "3.10.1" + "@typescript-eslint/typescript-estree" "3.10.1" + eslint-scope "^5.0.0" + eslint-utils "^2.0.0" + +"@typescript-eslint/parser@^4.5.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-4.20.0.tgz#8dd403c8b4258b99194972d9799e201b8d083bdd" + integrity sha512-m6vDtgL9EABdjMtKVw5rr6DdeMCH3OA1vFb0dAyuZSa3e5yw1YRzlwFnm9knma9Lz6b2GPvoNSa8vOXrqsaglA== + dependencies: + "@typescript-eslint/scope-manager" "4.20.0" + "@typescript-eslint/types" "4.20.0" + "@typescript-eslint/typescript-estree" "4.20.0" + debug "^4.1.1" + +"@typescript-eslint/scope-manager@4.20.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-4.20.0.tgz#953ecbf3b00845ece7be66246608be9d126d05ca" + integrity sha512-/zm6WR6iclD5HhGpcwl/GOYDTzrTHmvf8LLLkwKqqPKG6+KZt/CfSgPCiybshmck66M2L5fWSF/MKNuCwtKQSQ== + dependencies: + "@typescript-eslint/types" "4.20.0" + "@typescript-eslint/visitor-keys" "4.20.0" + +"@typescript-eslint/types@3.10.1": + version "3.10.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-3.10.1.tgz#1d7463fa7c32d8a23ab508a803ca2fe26e758727" + integrity sha512-+3+FCUJIahE9q0lDi1WleYzjCwJs5hIsbugIgnbB+dSCYUxl8L6PwmsyOPFZde2hc1DlTo/xnkOgiTLSyAbHiQ== + +"@typescript-eslint/types@4.20.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-4.20.0.tgz#c6cf5ef3c9b1c8f699a9bbdafb7a1da1ca781225" + integrity sha512-cYY+1PIjei1nk49JAPnH1VEnu7OYdWRdJhYI5wiKOUMhLTG1qsx5cQxCUTuwWCmQoyriadz3Ni8HZmGSofeC+w== + +"@typescript-eslint/typescript-estree@3.10.1": + version "3.10.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-3.10.1.tgz#fd0061cc38add4fad45136d654408569f365b853" + integrity sha512-QbcXOuq6WYvnB3XPsZpIwztBoquEYLXh2MtwVU+kO8jgYCiv4G5xrSP/1wg4tkvrEE+esZVquIPX/dxPlePk1w== + dependencies: + "@typescript-eslint/types" "3.10.1" + "@typescript-eslint/visitor-keys" "3.10.1" + debug "^4.1.1" + glob "^7.1.6" + is-glob "^4.0.1" + lodash "^4.17.15" + semver "^7.3.2" + tsutils "^3.17.1" + +"@typescript-eslint/typescript-estree@4.20.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-4.20.0.tgz#8b3b08f85f18a8da5d88f65cb400f013e88ab7be" + integrity sha512-Knpp0reOd4ZsyoEJdW8i/sK3mtZ47Ls7ZHvD8WVABNx5Xnn7KhenMTRGegoyMTx6TiXlOVgMz9r0pDgXTEEIHA== + dependencies: + "@typescript-eslint/types" "4.20.0" + "@typescript-eslint/visitor-keys" "4.20.0" + debug "^4.1.1" + globby "^11.0.1" + is-glob "^4.0.1" + semver "^7.3.2" + tsutils "^3.17.1" + +"@typescript-eslint/visitor-keys@3.10.1": + version "3.10.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-3.10.1.tgz#cd4274773e3eb63b2e870ac602274487ecd1e931" + integrity sha512-9JgC82AaQeglebjZMgYR5wgmfUdUc+EitGUUMW8u2nDckaeimzW+VsoLV6FoimPv2id3VQzfjwBxEMVz08ameQ== + dependencies: + eslint-visitor-keys "^1.1.0" + +"@typescript-eslint/visitor-keys@4.20.0": + version "4.20.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-4.20.0.tgz#1e84db034da13f208325e6bfc995c3b75f7dbd62" + integrity sha512-NXKRM3oOVQL8yNFDNCZuieRIwZ5UtjNLYtmMx2PacEAGmbaEYtGgVHUHVyZvU/0rYZcizdrWjDo+WBtRPSgq+A== + dependencies: + "@typescript-eslint/types" "4.20.0" + eslint-visitor-keys "^2.0.0" + +"@webassemblyjs/ast@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.9.0.tgz#bd850604b4042459a5a41cd7d338cbed695ed964" + integrity sha512-C6wW5L+b7ogSDVqymbkkvuW9kruN//YisMED04xzeBBqjHa2FYnmvOlS6Xj68xWQRgWvI9cIglsjFowH/RJyEA== + dependencies: + "@webassemblyjs/helper-module-context" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/wast-parser" "1.9.0" + +"@webassemblyjs/floating-point-hex-parser@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.9.0.tgz#3c3d3b271bddfc84deb00f71344438311d52ffb4" + integrity sha512-TG5qcFsS8QB4g4MhrxK5TqfdNe7Ey/7YL/xN+36rRjl/BlGE/NcBvJcqsRgCP6Z92mRE+7N50pRIi8SmKUbcQA== + +"@webassemblyjs/helper-api-error@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.9.0.tgz#203f676e333b96c9da2eeab3ccef33c45928b6a2" + integrity sha512-NcMLjoFMXpsASZFxJ5h2HZRcEhDkvnNFOAKneP5RbKRzaWJN36NC4jqQHKwStIhGXu5mUWlUUk7ygdtrO8lbmw== + +"@webassemblyjs/helper-buffer@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.9.0.tgz#a1442d269c5feb23fcbc9ef759dac3547f29de00" + integrity sha512-qZol43oqhq6yBPx7YM3m9Bv7WMV9Eevj6kMi6InKOuZxhw+q9hOkvq5e/PpKSiLfyetpaBnogSbNCfBwyB00CA== + +"@webassemblyjs/helper-code-frame@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.9.0.tgz#647f8892cd2043a82ac0c8c5e75c36f1d9159f27" + integrity sha512-ERCYdJBkD9Vu4vtjUYe8LZruWuNIToYq/ME22igL+2vj2dQ2OOujIZr3MEFvfEaqKoVqpsFKAGsRdBSBjrIvZA== + dependencies: + "@webassemblyjs/wast-printer" "1.9.0" + +"@webassemblyjs/helper-fsm@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-fsm/-/helper-fsm-1.9.0.tgz#c05256b71244214671f4b08ec108ad63b70eddb8" + integrity sha512-OPRowhGbshCb5PxJ8LocpdX9Kl0uB4XsAjl6jH/dWKlk/mzsANvhwbiULsaiqT5GZGT9qinTICdj6PLuM5gslw== + +"@webassemblyjs/helper-module-context@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-module-context/-/helper-module-context-1.9.0.tgz#25d8884b76839871a08a6c6f806c3979ef712f07" + integrity sha512-MJCW8iGC08tMk2enck1aPW+BE5Cw8/7ph/VGZxwyvGbJwjktKkDK7vy7gAmMDx88D7mhDTCNKAW5tED+gZ0W8g== + dependencies: + "@webassemblyjs/ast" "1.9.0" + +"@webassemblyjs/helper-wasm-bytecode@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.9.0.tgz#4fed8beac9b8c14f8c58b70d124d549dd1fe5790" + integrity sha512-R7FStIzyNcd7xKxCZH5lE0Bqy+hGTwS3LJjuv1ZVxd9O7eHCedSdrId/hMOd20I+v8wDXEn+bjfKDLzTepoaUw== + +"@webassemblyjs/helper-wasm-section@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.9.0.tgz#5a4138d5a6292ba18b04c5ae49717e4167965346" + integrity sha512-XnMB8l3ek4tvrKUUku+IVaXNHz2YsJyOOmz+MMkZvh8h1uSJpSen6vYnw3IoQ7WwEuAhL8Efjms1ZWjqh2agvw== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + +"@webassemblyjs/ieee754@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/ieee754/-/ieee754-1.9.0.tgz#15c7a0fbaae83fb26143bbacf6d6df1702ad39e4" + integrity sha512-dcX8JuYU/gvymzIHc9DgxTzUUTLexWwt8uCTWP3otys596io0L5aW02Gb1RjYpx2+0Jus1h4ZFqjla7umFniTg== + dependencies: + "@xtuc/ieee754" "^1.2.0" + +"@webassemblyjs/leb128@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/leb128/-/leb128-1.9.0.tgz#f19ca0b76a6dc55623a09cffa769e838fa1e1c95" + integrity sha512-ENVzM5VwV1ojs9jam6vPys97B/S65YQtv/aanqnU7D8aSoHFX8GyhGg0CMfyKNIHBuAVjy3tlzd5QMMINa7wpw== + dependencies: + "@xtuc/long" "4.2.2" + +"@webassemblyjs/utf8@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/utf8/-/utf8-1.9.0.tgz#04d33b636f78e6a6813227e82402f7637b6229ab" + integrity sha512-GZbQlWtopBTP0u7cHrEx+73yZKrQoBMpwkGEIqlacljhXCkVM1kMQge/Mf+csMJAjEdSwhOyLAS0AoR3AG5P8w== + +"@webassemblyjs/wasm-edit@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.9.0.tgz#3fe6d79d3f0f922183aa86002c42dd256cfee9cf" + integrity sha512-FgHzBm80uwz5M8WKnMTn6j/sVbqilPdQXTWraSjBwFXSYGirpkSWE2R9Qvz9tNiTKQvoKILpCuTjBKzOIm0nxw== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/helper-wasm-section" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + "@webassemblyjs/wasm-opt" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + "@webassemblyjs/wast-printer" "1.9.0" + +"@webassemblyjs/wasm-gen@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.9.0.tgz#50bc70ec68ded8e2763b01a1418bf43491a7a49c" + integrity sha512-cPE3o44YzOOHvlsb4+E9qSqjc9Qf9Na1OO/BHFy4OI91XDE14MjFN4lTMezzaIWdPqHnsTodGGNP+iRSYfGkjA== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/ieee754" "1.9.0" + "@webassemblyjs/leb128" "1.9.0" + "@webassemblyjs/utf8" "1.9.0" + +"@webassemblyjs/wasm-opt@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.9.0.tgz#2211181e5b31326443cc8112eb9f0b9028721a61" + integrity sha512-Qkjgm6Anhm+OMbIL0iokO7meajkzQD71ioelnfPEj6r4eOFuqm4YC3VBPqXjFyyNwowzbMD+hizmprP/Fwkl2A== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-buffer" "1.9.0" + "@webassemblyjs/wasm-gen" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + +"@webassemblyjs/wasm-parser@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.9.0.tgz#9d48e44826df4a6598294aa6c87469d642fff65e" + integrity sha512-9+wkMowR2AmdSWQzsPEjFU7njh8HTO5MqO8vjwEHuM+AMHioNqSBONRdr0NQQ3dVQrzp0s8lTcYqzUdb7YgELA== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-api-error" "1.9.0" + "@webassemblyjs/helper-wasm-bytecode" "1.9.0" + "@webassemblyjs/ieee754" "1.9.0" + "@webassemblyjs/leb128" "1.9.0" + "@webassemblyjs/utf8" "1.9.0" + +"@webassemblyjs/wast-parser@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-parser/-/wast-parser-1.9.0.tgz#3031115d79ac5bd261556cecc3fa90a3ef451914" + integrity sha512-qsqSAP3QQ3LyZjNC/0jBJ/ToSxfYJ8kYyuiGvtn/8MK89VrNEfwj7BPQzJVHi0jGTRK2dGdJ5PRqhtjzoww+bw== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/floating-point-hex-parser" "1.9.0" + "@webassemblyjs/helper-api-error" "1.9.0" + "@webassemblyjs/helper-code-frame" "1.9.0" + "@webassemblyjs/helper-fsm" "1.9.0" + "@xtuc/long" "4.2.2" + +"@webassemblyjs/wast-printer@1.9.0": + version "1.9.0" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-printer/-/wast-printer-1.9.0.tgz#4935d54c85fef637b00ce9f52377451d00d47899" + integrity sha512-2J0nE95rHXHyQ24cWjMKJ1tqB/ds8z/cyeOZxJhcb+rW+SQASVjuznUSmdz5GpVJTzU8JkhYut0D3siFDD6wsA== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/wast-parser" "1.9.0" + "@xtuc/long" "4.2.2" + +"@webpack-cli/configtest@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@webpack-cli/configtest/-/configtest-1.0.2.tgz#2a20812bfb3a2ebb0b27ee26a52eeb3e3f000836" + integrity sha512-3OBzV2fBGZ5TBfdW50cha1lHDVf9vlvRXnjpVbJBa20pSZQaSkMJZiwA8V2vD9ogyeXn8nU5s5A6mHyf5jhMzA== + +"@webpack-cli/info@^1.2.3": + version "1.2.3" + resolved "https://registry.yarnpkg.com/@webpack-cli/info/-/info-1.2.3.tgz#ef819d10ace2976b6d134c7c823a3e79ee31a92c" + integrity sha512-lLek3/T7u40lTqzCGpC6CAbY6+vXhdhmwFRxZLMnRm6/sIF/7qMpT8MocXCRQfz0JAh63wpbXLMnsQ5162WS7Q== + dependencies: + envinfo "^7.7.3" + +"@webpack-cli/serve@^1.3.1": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@webpack-cli/serve/-/serve-1.3.1.tgz#911d1b3ff4a843304b9c3bacf67bb34672418441" + integrity sha512-0qXvpeYO6vaNoRBI52/UsbcaBydJCggoBBnIo/ovQQdn6fug0BgwsjorV1hVS7fMqGVTZGcVxv8334gjmbj5hw== + +"@xtuc/ieee754@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@xtuc/ieee754/-/ieee754-1.2.0.tgz#eef014a3145ae477a1cbc00cd1e552336dceb790" + integrity sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA== + +"@xtuc/long@4.2.2": + version "4.2.2" + resolved "https://registry.yarnpkg.com/@xtuc/long/-/long-4.2.2.tgz#d291c6a4e97989b5c61d9acf396ae4fe133a718d" + integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ== + +abab@^2.0.3, abab@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" + integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q== + +accepts@~1.3.4, accepts@~1.3.5, accepts@~1.3.7: + version "1.3.7" + resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" + integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== + dependencies: + mime-types "~2.1.24" + negotiator "0.6.2" + +acorn-globals@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-6.0.0.tgz#46cdd39f0f8ff08a876619b55f5ac8a6dc770b45" + integrity sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg== + dependencies: + acorn "^7.1.1" + acorn-walk "^7.1.1" + +acorn-jsx@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.1.tgz#fc8661e11b7ac1539c47dbfea2e72b3af34d267b" + integrity sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng== + +acorn-walk@^7.1.1: + version "7.2.0" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc" + integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA== + +acorn-walk@^8.0.0: + version "8.0.2" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.0.2.tgz#d4632bfc63fd93d0f15fd05ea0e984ffd3f5a8c3" + integrity sha512-+bpA9MJsHdZ4bgfDcpk0ozQyhhVct7rzOmO0s1IIr0AGGgKBljss8n2zp11rRP2wid5VGeh04CgeKzgat5/25A== + +acorn@^6.4.1: + version "6.4.2" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-6.4.2.tgz#35866fd710528e92de10cf06016498e47e39e1e6" + integrity sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ== + +acorn@^7.1.0, acorn@^7.1.1, acorn@^7.4.0: + version "7.4.1" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" + integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== + +acorn@^8.0.4, acorn@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.1.0.tgz#52311fd7037ae119cbb134309e901aa46295b3fe" + integrity sha512-LWCF/Wn0nfHOmJ9rzQApGnxnvgfROzGilS8936rqN/lfcYkY9MYZzdMqN+2NJ4SlTc+m5HiSa+kNfDtI64dwUA== + +address@1.1.2, address@^1.0.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/address/-/address-1.1.2.tgz#bf1116c9c758c51b7a933d296b72c221ed9428b6" + integrity sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA== + +adjust-sourcemap-loader@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/adjust-sourcemap-loader/-/adjust-sourcemap-loader-3.0.0.tgz#5ae12fb5b7b1c585e80bbb5a63ec163a1a45e61e" + integrity sha512-YBrGyT2/uVQ/c6Rr+t6ZJXniY03YtHGMJQYal368burRGYKqhx9qGTWqcBU5s1CwYY9E/ri63RYyG1IacMZtqw== + dependencies: + loader-utils "^2.0.0" + regex-parser "^2.2.11" + +aggregate-error@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" + integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== + dependencies: + clean-stack "^2.0.0" + indent-string "^4.0.0" + +ajv-errors@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/ajv-errors/-/ajv-errors-1.0.1.tgz#f35986aceb91afadec4102fbd85014950cefa64d" + integrity sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ== + +ajv-keywords@^3.1.0, ajv-keywords@^3.4.1, ajv-keywords@^3.5.2: + version "3.5.2" + resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" + integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ== + +ajv@^6.1.0, ajv@^6.10.0, ajv@^6.10.2, ajv@^6.12.3, ajv@^6.12.4, ajv@^6.12.5: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +ajv@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.0.1.tgz#dac101898a87f8ebb57fea69617e8096523c628c" + integrity sha512-46ZA4TalFcLLqX1dEU3dhdY38wAtDydJ4e7QQTVekLUTzXkb1LfqU6VOBXC/a9wiv4T094WURqJH6ZitF92Kqw== + dependencies: + fast-deep-equal "^3.1.1" + json-schema-traverse "^1.0.0" + require-from-string "^2.0.2" + uri-js "^4.2.2" + +alphanum-sort@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/alphanum-sort/-/alphanum-sort-1.0.2.tgz#97a1119649b211ad33691d9f9f486a8ec9fbe0a3" + integrity sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM= + +ansi-colors@^3.0.0: + version "3.2.4" + resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-3.2.4.tgz#e3a3da4bfbae6c86a9c285625de124a234026fbf" + integrity sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA== + +ansi-colors@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" + integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== + +ansi-escapes@^4.2.1, ansi-escapes@^4.3.1: + version "4.3.2" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" + integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== + dependencies: + type-fest "^0.21.3" + +ansi-html@0.0.7, ansi-html@^0.0.7: + version "0.0.7" + resolved "https://registry.yarnpkg.com/ansi-html/-/ansi-html-0.0.7.tgz#813584021962a9e9e6fd039f940d12f56ca7859e" + integrity sha1-gTWEAhliqenm/QOflA0S9WynhZ4= + +ansi-regex@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" + integrity sha1-w7M6te42DYbg5ijwRorn7yfWVN8= + +ansi-regex@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997" + integrity sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg== + +ansi-regex@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" + integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== + +ansi-styles@^3.2.0, ansi-styles@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" + integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== + dependencies: + color-convert "^1.9.0" + +ansi-styles@^4.0.0, ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +anymatch@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-2.0.0.tgz#bcb24b4f37934d9aa7ac17b4adaf89e7c76ef2eb" + integrity sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw== + dependencies: + micromatch "^3.1.4" + normalize-path "^2.1.1" + +anymatch@^3.0.3, anymatch@~3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142" + integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg== + dependencies: + normalize-path "^3.0.0" + picomatch "^2.0.4" + +aproba@^1.1.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" + integrity sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw== + +argparse@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" + integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== + dependencies: + sprintf-js "~1.0.2" + +aria-query@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-4.2.2.tgz#0d2ca6c9aceb56b8977e9fed6aed7e15bbd2f83b" + integrity sha512-o/HelwhuKpTj/frsOsbNLNgnNGVIFsVP/SW2BSF14gVl7kAfMOJ6/8wUAUvG1R1NHKrfG+2sHZTu0yauT1qBrA== + dependencies: + "@babel/runtime" "^7.10.2" + "@babel/runtime-corejs3" "^7.10.2" + +arity-n@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/arity-n/-/arity-n-1.0.4.tgz#d9e76b11733e08569c0847ae7b39b2860b30b745" + integrity sha1-2edrEXM+CFacCEeuezmyhgswt0U= + +arr-diff@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520" + integrity sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA= + +arr-flatten@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" + integrity sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg== + +arr-union@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4" + integrity sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ= + +array-flatten@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" + integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= + +array-flatten@^2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-2.1.2.tgz#24ef80a28c1a893617e2149b0c6d0d788293b099" + integrity sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ== + +array-includes@^3.1.1, array-includes@^3.1.2, array-includes@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.3.tgz#c7f619b382ad2afaf5326cddfdc0afc61af7690a" + integrity sha512-gcem1KlBU7c9rB+Rq8/3PPKsK2kjqeEBa3bD5kkQo4nYlOHQCJqIJFqBXDEfwaRuYTT4E+FxA9xez7Gf/e3Q7A== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.2" + get-intrinsic "^1.1.1" + is-string "^1.0.5" + +array-union@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-1.0.2.tgz#9a34410e4f4e3da23dea375be5be70f24778ec39" + integrity sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk= + dependencies: + array-uniq "^1.0.1" + +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + +array-uniq@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" + integrity sha1-r2rId6Jcx/dOBYiUdThY39sk/bY= + +array-unique@^0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" + integrity sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg= + +array.prototype.flat@^1.2.3: + version "1.2.4" + resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.2.4.tgz#6ef638b43312bd401b4c6199fdec7e2dc9e9a123" + integrity sha512-4470Xi3GAPAjZqFcljX2xzckv1qeKPizoNkiS0+O4IoPR2ZNpcjE0pkhdihlDouK+x6QOast26B4Q/O9DJnwSg== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.1" + +array.prototype.flatmap@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.2.4.tgz#94cfd47cc1556ec0747d97f7c7738c58122004c9" + integrity sha512-r9Z0zYoxqHz60vvQbWEdXIEtCwHF0yxaWfno9qzXeNHvfyl3BZqygmGzb84dsubyaXLH4husF+NFgMSdpZhk2Q== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.1" + function-bind "^1.1.1" + +arrify@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/arrify/-/arrify-2.0.1.tgz#c9655e9331e0abcd588d2a7cad7e9956f66701fa" + integrity sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug== + +asap@~2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.6.tgz#e50347611d7e690943208bbdafebcbc2fb866d46" + integrity sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY= + +asn1.js@^5.2.0: + version "5.4.1" + resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" + integrity sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA== + dependencies: + bn.js "^4.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + safer-buffer "^2.1.0" + +asn1@~0.2.3: + version "0.2.4" + resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.4.tgz#8d2475dfab553bb33e77b54e59e880bb8ce23136" + integrity sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg== + dependencies: + safer-buffer "~2.1.0" + +assert-plus@1.0.0, assert-plus@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" + integrity sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU= + +assert@^1.1.1: + version "1.5.0" + resolved "https://registry.yarnpkg.com/assert/-/assert-1.5.0.tgz#55c109aaf6e0aefdb3dc4b71240c70bf574b18eb" + integrity sha512-EDsgawzwoun2CZkCgtxJbv392v4nbk9XDD06zI+kQYoBM/3RBWLlEyJARDOmhAAosBjWACEkKL6S+lIZtcAubA== + dependencies: + object-assign "^4.1.1" + util "0.10.3" + +assign-symbols@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" + integrity sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c= + +ast-types-flow@^0.0.7: + version "0.0.7" + resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz#f70b735c6bca1a5c9c22d982c3e39e7feba3bdad" + integrity sha1-9wtzXGvKGlycItmCw+Oef+ujva0= + +astral-regex@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" + integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== + +async-each@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.3.tgz#b727dbf87d7651602f06f4d4ac387f47d91b0cbf" + integrity sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ== + +async-limiter@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/async-limiter/-/async-limiter-1.0.1.tgz#dd379e94f0db8310b08291f9d64c3209766617fd" + integrity sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ== + +async@^2.6.2: + version "2.6.3" + resolved "https://registry.yarnpkg.com/async/-/async-2.6.3.tgz#d72625e2344a3656e3a3ad4fa749fa83299d82ff" + integrity sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg== + dependencies: + lodash "^4.17.14" + +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" + integrity sha1-x57Zf380y48robyXkLzDZkdLS3k= + +at-least-node@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" + integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== + +atob@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" + integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== + +autoprefixer@^9.6.1: + version "9.8.6" + resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-9.8.6.tgz#3b73594ca1bf9266320c5acf1588d74dea74210f" + integrity sha512-XrvP4VVHdRBCdX1S3WXVD8+RyG9qeb1D5Sn1DeLiG2xfSpzellk5k54xbUERJ3M5DggQxes39UGOTP8CFrEGbg== + dependencies: + browserslist "^4.12.0" + caniuse-lite "^1.0.30001109" + colorette "^1.2.1" + normalize-range "^0.1.2" + num2fraction "^1.2.2" + postcss "^7.0.32" + postcss-value-parser "^4.1.0" + +aws-sign2@~0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" + integrity sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg= + +aws4@^1.8.0: + version "1.11.0" + resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.11.0.tgz#d61f46d83b2519250e2784daf5b09479a8b41c59" + integrity sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA== + +axe-core@^4.0.2: + version "4.1.3" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.1.3.tgz#64a4c85509e0991f5168340edc4bedd1ceea6966" + integrity sha512-vwPpH4Aj4122EW38mxO/fxhGKtwWTMLDIJfZ1He0Edbtjcfna/R3YB67yVhezUMzqc3Jr3+Ii50KRntlENL4xQ== + +axobject-query@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/axobject-query/-/axobject-query-2.2.0.tgz#943d47e10c0b704aa42275e20edf3722648989be" + integrity sha512-Td525n+iPOOyUQIeBfcASuG6uJsDOITl7Mds5gFyerkWiX7qhUTdYUBlSgNMyVqtSJqwpt1kXGLdUt6SykLMRA== + +babel-eslint@^10.1.0: + version "10.1.0" + resolved "https://registry.yarnpkg.com/babel-eslint/-/babel-eslint-10.1.0.tgz#6968e568a910b78fb3779cdd8b6ac2f479943232" + integrity sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg== + dependencies: + "@babel/code-frame" "^7.0.0" + "@babel/parser" "^7.7.0" + "@babel/traverse" "^7.7.0" + "@babel/types" "^7.7.0" + eslint-visitor-keys "^1.0.0" + resolve "^1.12.0" + +babel-extract-comments@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/babel-extract-comments/-/babel-extract-comments-1.0.0.tgz#0a2aedf81417ed391b85e18b4614e693a0351a21" + integrity sha512-qWWzi4TlddohA91bFwgt6zO/J0X+io7Qp184Fw0m2JYRSTZnJbFR8+07KmzudHCZgOiKRCrjhylwv9Xd8gfhVQ== + dependencies: + babylon "^6.18.0" + +babel-jest@^26.6.0, babel-jest@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-26.6.3.tgz#d87d25cb0037577a0c89f82e5755c5d293c01056" + integrity sha512-pl4Q+GAVOHwvjrck6jKjvmGhnO3jHX/xuB9d27f+EJZ/6k+6nMuPjorrYp7s++bKKdANwzElBWnLWaObvTnaZA== + dependencies: + "@jest/transform" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/babel__core" "^7.1.7" + babel-plugin-istanbul "^6.0.0" + babel-preset-jest "^26.6.2" + chalk "^4.0.0" + graceful-fs "^4.2.4" + slash "^3.0.0" + +babel-loader@8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-8.1.0.tgz#c611d5112bd5209abe8b9fa84c3e4da25275f1c3" + integrity sha512-7q7nC1tYOrqvUrN3LQK4GwSk/TQorZSOlO9C+RZDZpODgyN4ZlCqE5q9cDsyWOliN+aU9B4JX01xK9eJXowJLw== + dependencies: + find-cache-dir "^2.1.0" + loader-utils "^1.4.0" + mkdirp "^0.5.3" + pify "^4.0.1" + schema-utils "^2.6.5" + +babel-plugin-dynamic-import-node@^2.3.3: + version "2.3.3" + resolved "https://registry.yarnpkg.com/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz#84fda19c976ec5c6defef57f9427b3def66e17a3" + integrity sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ== + dependencies: + object.assign "^4.1.0" + +babel-plugin-istanbul@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-6.0.0.tgz#e159ccdc9af95e0b570c75b4573b7c34d671d765" + integrity sha512-AF55rZXpe7trmEylbaE1Gv54wn6rwU03aptvRoVIGP8YykoSxqdVLV1TfwflBCE/QtHmqtP8SWlTENqbK8GCSQ== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@istanbuljs/load-nyc-config" "^1.0.0" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-instrument "^4.0.0" + test-exclude "^6.0.0" + +babel-plugin-jest-hoist@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-26.6.2.tgz#8185bd030348d254c6d7dd974355e6a28b21e62d" + integrity sha512-PO9t0697lNTmcEHH69mdtYiOIkkOlj9fySqfO3K1eCcdISevLAE0xY59VLLUj0SoiPiTX/JU2CYFpILydUa5Lw== + dependencies: + "@babel/template" "^7.3.3" + "@babel/types" "^7.3.3" + "@types/babel__core" "^7.0.0" + "@types/babel__traverse" "^7.0.6" + +babel-plugin-macros@2.8.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/babel-plugin-macros/-/babel-plugin-macros-2.8.0.tgz#0f958a7cc6556b1e65344465d99111a1e5e10138" + integrity sha512-SEP5kJpfGYqYKpBrj5XU3ahw5p5GOHJ0U5ssOSQ/WBVdwkD2Dzlce95exQTs3jOVWPPKLBN2rlEWkCK7dSmLvg== + dependencies: + "@babel/runtime" "^7.7.2" + cosmiconfig "^6.0.0" + resolve "^1.12.0" + +babel-plugin-named-asset-import@^0.3.7: + version "0.3.7" + resolved "https://registry.yarnpkg.com/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.7.tgz#156cd55d3f1228a5765774340937afc8398067dd" + integrity sha512-squySRkf+6JGnvjoUtDEjSREJEBirnXi9NqP6rjSYsylxQxqBTz+pkmf395i9E2zsvmYUaI40BHo6SqZUdydlw== + +babel-plugin-polyfill-corejs2@^0.1.4: + version "0.1.10" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.1.10.tgz#a2c5c245f56c0cac3dbddbf0726a46b24f0f81d1" + integrity sha512-DO95wD4g0A8KRaHKi0D51NdGXzvpqVLnLu5BTvDlpqUEpTmeEtypgC1xqesORaWmiUOQI14UHKlzNd9iZ2G3ZA== + dependencies: + "@babel/compat-data" "^7.13.0" + "@babel/helper-define-polyfill-provider" "^0.1.5" + semver "^6.1.1" + +babel-plugin-polyfill-corejs3@^0.1.3: + version "0.1.7" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.1.7.tgz#80449d9d6f2274912e05d9e182b54816904befd0" + integrity sha512-u+gbS9bbPhZWEeyy1oR/YaaSpod/KDT07arZHb80aTpl8H5ZBq+uN1nN9/xtX7jQyfLdPfoqI4Rue/MQSWJquw== + dependencies: + "@babel/helper-define-polyfill-provider" "^0.1.5" + core-js-compat "^3.8.1" + +babel-plugin-polyfill-regenerator@^0.1.2: + version "0.1.6" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.1.6.tgz#0fe06a026fe0faa628ccc8ba3302da0a6ce02f3f" + integrity sha512-OUrYG9iKPKz8NxswXbRAdSwF0GhRdIEMTloQATJi4bDuFqrXaXcCUT/VGNrr8pBcjMh1RxZ7Xt9cytVJTJfvMg== + dependencies: + "@babel/helper-define-polyfill-provider" "^0.1.5" + +babel-plugin-syntax-object-rest-spread@^6.8.0: + version "6.13.0" + resolved "https://registry.yarnpkg.com/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz#fd6536f2bce13836ffa3a5458c4903a597bb3bf5" + integrity sha1-/WU28rzhODb/o6VFjEkDpZe7O/U= + +babel-plugin-transform-object-rest-spread@^6.26.0: + version "6.26.0" + resolved "https://registry.yarnpkg.com/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz#0f36692d50fef6b7e2d4b3ac1478137a963b7b06" + integrity sha1-DzZpLVD+9rfi1LOsFHgTepY7ewY= + dependencies: + babel-plugin-syntax-object-rest-spread "^6.8.0" + babel-runtime "^6.26.0" + +babel-plugin-transform-react-remove-prop-types@0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-remove-prop-types/-/babel-plugin-transform-react-remove-prop-types-0.4.24.tgz#f2edaf9b4c6a5fbe5c1d678bfb531078c1555f3a" + integrity sha512-eqj0hVcJUR57/Ug2zE1Yswsw4LhuqqHhD+8v120T1cl3kjg76QwtyBrdIk4WVwK+lAhBJVYCd/v+4nc4y+8JsA== + +babel-preset-current-node-syntax@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz#b4399239b89b2a011f9ddbe3e4f401fc40cff73b" + integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ== + dependencies: + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-bigint" "^7.8.3" + "@babel/plugin-syntax-class-properties" "^7.8.3" + "@babel/plugin-syntax-import-meta" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.8.3" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.8.3" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-top-level-await" "^7.8.3" + +babel-preset-jest@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-26.6.2.tgz#747872b1171df032252426586881d62d31798fee" + integrity sha512-YvdtlVm9t3k777c5NPQIv6cxFFFapys25HiUmuSgHwIZhfifweR5c5Sf5nwE3MAbfu327CYSvps8Yx6ANLyleQ== + dependencies: + babel-plugin-jest-hoist "^26.6.2" + babel-preset-current-node-syntax "^1.0.0" + +babel-preset-react-app@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/babel-preset-react-app/-/babel-preset-react-app-10.0.0.tgz#689b60edc705f8a70ce87f47ab0e560a317d7045" + integrity sha512-itL2z8v16khpuKutx5IH8UdCdSTuzrOhRFTEdIhveZ2i1iBKDrVE0ATa4sFVy+02GLucZNVBWtoarXBy0Msdpg== + dependencies: + "@babel/core" "7.12.3" + "@babel/plugin-proposal-class-properties" "7.12.1" + "@babel/plugin-proposal-decorators" "7.12.1" + "@babel/plugin-proposal-nullish-coalescing-operator" "7.12.1" + "@babel/plugin-proposal-numeric-separator" "7.12.1" + "@babel/plugin-proposal-optional-chaining" "7.12.1" + "@babel/plugin-transform-flow-strip-types" "7.12.1" + "@babel/plugin-transform-react-display-name" "7.12.1" + "@babel/plugin-transform-runtime" "7.12.1" + "@babel/preset-env" "7.12.1" + "@babel/preset-react" "7.12.1" + "@babel/preset-typescript" "7.12.1" + "@babel/runtime" "7.12.1" + babel-plugin-macros "2.8.0" + babel-plugin-transform-react-remove-prop-types "0.4.24" + +babel-runtime@^6.26.0: + version "6.26.0" + resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe" + integrity sha1-llxwWGaOgrVde/4E/yM3vItWR/4= + dependencies: + core-js "^2.4.0" + regenerator-runtime "^0.11.0" + +babylon@^6.18.0: + version "6.18.0" + resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3" + integrity sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ== + +balanced-match@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" + integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c= + +base64-js@^1.0.2: + version "1.5.1" + resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" + integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + +base@^0.11.1: + version "0.11.2" + resolved "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz#7bde5ced145b6d551a90db87f83c558b4eb48a8f" + integrity sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg== + dependencies: + cache-base "^1.0.1" + class-utils "^0.3.5" + component-emitter "^1.2.1" + define-property "^1.0.0" + isobject "^3.0.1" + mixin-deep "^1.2.0" + pascalcase "^0.1.1" + +batch@0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/batch/-/batch-0.6.1.tgz#dc34314f4e679318093fc760272525f94bf25c16" + integrity sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY= + +bcrypt-pbkdf@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" + integrity sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4= + dependencies: + tweetnacl "^0.14.3" + +bfj@^7.0.2: + version "7.0.2" + resolved "https://registry.yarnpkg.com/bfj/-/bfj-7.0.2.tgz#1988ce76f3add9ac2913fd8ba47aad9e651bfbb2" + integrity sha512-+e/UqUzwmzJamNF50tBV6tZPTORow7gQ96iFow+8b562OdMpEK0BcJEq2OSPEDmAbSMBQ7PKZ87ubFkgxpYWgw== + dependencies: + bluebird "^3.5.5" + check-types "^11.1.1" + hoopy "^0.1.4" + tryer "^1.0.1" + +big.js@^5.2.2: + version "5.2.2" + resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" + integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== + +binary-extensions@^1.0.0: + version "1.13.1" + resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.13.1.tgz#598afe54755b2868a5330d2aff9d4ebb53209b65" + integrity sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw== + +binary-extensions@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" + integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== + +bindings@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" + integrity sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ== + dependencies: + file-uri-to-path "1.0.0" + +bluebird@^3.5.5: + version "3.7.2" + resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" + integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== + +bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.9: + version "4.12.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" + integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== + +bn.js@^5.0.0, bn.js@^5.1.1: + version "5.2.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.0.tgz#358860674396c6997771a9d051fcc1b57d4ae002" + integrity sha512-D7iWRBvnZE8ecXiLj/9wbxH7Tk79fAh8IHaTNq1RWRixsS02W+5qS+iE9yq6RYl0asXx5tw0bLhmT5pIfbSquw== + +body-parser@1.19.0: + version "1.19.0" + resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.0.tgz#96b2709e57c9c4e09a6fd66a8fd979844f69f08a" + integrity sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw== + dependencies: + bytes "3.1.0" + content-type "~1.0.4" + debug "2.6.9" + depd "~1.1.2" + http-errors "1.7.2" + iconv-lite "0.4.24" + on-finished "~2.3.0" + qs "6.7.0" + raw-body "2.4.0" + type-is "~1.6.17" + +bonjour@^3.5.0: + version "3.5.0" + resolved "https://registry.yarnpkg.com/bonjour/-/bonjour-3.5.0.tgz#8e890a183d8ee9a2393b3844c691a42bcf7bc9f5" + integrity sha1-jokKGD2O6aI5OzhExpGkK897yfU= + dependencies: + array-flatten "^2.1.0" + deep-equal "^1.0.1" + dns-equal "^1.0.0" + dns-txt "^2.0.2" + multicast-dns "^6.0.1" + multicast-dns-service-types "^1.1.0" + +boolbase@^1.0.0, boolbase@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" + integrity sha1-aN/1++YMUes3cl6p4+0xDcwed24= + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +braces@^2.3.1, braces@^2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz#5979fd3f14cd531565e5fa2df1abfff1dfaee729" + integrity sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w== + dependencies: + arr-flatten "^1.1.0" + array-unique "^0.3.2" + extend-shallow "^2.0.1" + fill-range "^4.0.0" + isobject "^3.0.1" + repeat-element "^1.1.2" + snapdragon "^0.8.1" + snapdragon-node "^2.0.1" + split-string "^3.0.2" + to-regex "^3.0.1" + +braces@^3.0.1, braces@~3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +brorand@^1.0.1, brorand@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" + integrity sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8= + +browser-process-hrtime@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626" + integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow== + +browserify-aes@^1.0.0, browserify-aes@^1.0.4: + version "1.2.0" + resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" + integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== + dependencies: + buffer-xor "^1.0.3" + cipher-base "^1.0.0" + create-hash "^1.1.0" + evp_bytestokey "^1.0.3" + inherits "^2.0.1" + safe-buffer "^5.0.1" + +browserify-cipher@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz#8d6474c1b870bfdabcd3bcfcc1934a10e94f15f0" + integrity sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w== + dependencies: + browserify-aes "^1.0.4" + browserify-des "^1.0.0" + evp_bytestokey "^1.0.0" + +browserify-des@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.2.tgz#3af4f1f59839403572f1c66204375f7a7f703e9c" + integrity sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A== + dependencies: + cipher-base "^1.0.1" + des.js "^1.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + +browserify-rsa@^4.0.0, browserify-rsa@^4.0.1: + version "4.1.0" + resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.1.0.tgz#b2fd06b5b75ae297f7ce2dc651f918f5be158c8d" + integrity sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog== + dependencies: + bn.js "^5.0.0" + randombytes "^2.0.1" + +browserify-sign@^4.0.0: + version "4.2.1" + resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.2.1.tgz#eaf4add46dd54be3bb3b36c0cf15abbeba7956c3" + integrity sha512-/vrA5fguVAKKAVTNJjgSm1tRQDHUU6DbwO9IROu/0WAzC8PKhucDSh18J0RMvVeHAn5puMd+QHC2erPRNf8lmg== + dependencies: + bn.js "^5.1.1" + browserify-rsa "^4.0.1" + create-hash "^1.2.0" + create-hmac "^1.1.7" + elliptic "^6.5.3" + inherits "^2.0.4" + parse-asn1 "^5.1.5" + readable-stream "^3.6.0" + safe-buffer "^5.2.0" + +browserify-zlib@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.2.0.tgz#2869459d9aa3be245fe8fe2ca1f46e2e7f54d73f" + integrity sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA== + dependencies: + pako "~1.0.5" + +browserslist@4.14.2: + version "4.14.2" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.14.2.tgz#1b3cec458a1ba87588cc5e9be62f19b6d48813ce" + integrity sha512-HI4lPveGKUR0x2StIz+2FXfDk9SfVMrxn6PLh1JeGUwcuoDkdKZebWiyLRJ68iIPDpMI4JLVDf7S7XzslgWOhw== + dependencies: + caniuse-lite "^1.0.30001125" + electron-to-chromium "^1.3.564" + escalade "^3.0.2" + node-releases "^1.1.61" + +browserslist@^4.0.0, browserslist@^4.12.0, browserslist@^4.14.5, browserslist@^4.16.3, browserslist@^4.6.2, browserslist@^4.6.4: + version "4.16.3" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.16.3.tgz#340aa46940d7db878748567c5dea24a48ddf3717" + integrity sha512-vIyhWmIkULaq04Gt93txdh+j02yX/JzlyhLYbV3YQCn/zvES3JnY7TifHHvvr1w5hTDluNKMkV05cs4vy8Q7sw== + dependencies: + caniuse-lite "^1.0.30001181" + colorette "^1.2.1" + electron-to-chromium "^1.3.649" + escalade "^3.1.1" + node-releases "^1.1.70" + +bser@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/bser/-/bser-2.1.1.tgz#e6787da20ece9d07998533cfd9de6f5c38f4bc05" + integrity sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ== + dependencies: + node-int64 "^0.4.0" + +buffer-from@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef" + integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A== + +buffer-indexof@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/buffer-indexof/-/buffer-indexof-1.1.1.tgz#52fabcc6a606d1a00302802648ef68f639da268c" + integrity sha512-4/rOEg86jivtPTeOUUT61jJO1Ya1TrR/OkqCSZDyq84WJh3LuuiphBYJN+fm5xufIk4XAFcEwte/8WzC8If/1g== + +buffer-xor@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" + integrity sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk= + +buffer@^4.3.0: + version "4.9.2" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-4.9.2.tgz#230ead344002988644841ab0244af8c44bbe3ef8" + integrity sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg== + dependencies: + base64-js "^1.0.2" + ieee754 "^1.1.4" + isarray "^1.0.0" + +builtin-modules@^3.1.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-3.2.0.tgz#45d5db99e7ee5e6bc4f362e008bf917ab5049887" + integrity sha512-lGzLKcioL90C7wMczpkY0n/oART3MbBa8R9OFGE1rJxoVI86u4WAGfEk8Wjv10eKSyTHVGkSo3bvBylCEtk7LA== + +builtin-status-codes@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" + integrity sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug= + +bytes@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" + integrity sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg= + +bytes@3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" + integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== + +cacache@^12.0.2: + version "12.0.4" + resolved "https://registry.yarnpkg.com/cacache/-/cacache-12.0.4.tgz#668bcbd105aeb5f1d92fe25570ec9525c8faa40c" + integrity sha512-a0tMB40oefvuInr4Cwb3GerbL9xTj1D5yg0T5xrjGCGyfvbxseIXX7BAO/u/hIXdafzOI5JC3wDwHyf24buOAQ== + dependencies: + bluebird "^3.5.5" + chownr "^1.1.1" + figgy-pudding "^3.5.1" + glob "^7.1.4" + graceful-fs "^4.1.15" + infer-owner "^1.0.3" + lru-cache "^5.1.1" + mississippi "^3.0.0" + mkdirp "^0.5.1" + move-concurrently "^1.0.1" + promise-inflight "^1.0.1" + rimraf "^2.6.3" + ssri "^6.0.1" + unique-filename "^1.1.1" + y18n "^4.0.0" + +cacache@^15.0.5: + version "15.0.6" + resolved "https://registry.yarnpkg.com/cacache/-/cacache-15.0.6.tgz#65a8c580fda15b59150fb76bf3f3a8e45d583099" + integrity sha512-g1WYDMct/jzW+JdWEyjaX2zoBkZ6ZT9VpOyp2I/VMtDsNLffNat3kqPFfi1eDRSK9/SuKGyORDHcQMcPF8sQ/w== + dependencies: + "@npmcli/move-file" "^1.0.1" + chownr "^2.0.0" + fs-minipass "^2.0.0" + glob "^7.1.4" + infer-owner "^1.0.4" + lru-cache "^6.0.0" + minipass "^3.1.1" + minipass-collect "^1.0.2" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.2" + mkdirp "^1.0.3" + p-map "^4.0.0" + promise-inflight "^1.0.1" + rimraf "^3.0.2" + ssri "^8.0.1" + tar "^6.0.2" + unique-filename "^1.1.1" + +cache-base@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2" + integrity sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ== + dependencies: + collection-visit "^1.0.0" + component-emitter "^1.2.1" + get-value "^2.0.6" + has-value "^1.0.0" + isobject "^3.0.1" + set-value "^2.0.0" + to-object-path "^0.3.0" + union-value "^1.0.0" + unset-value "^1.0.0" + +call-bind@^1.0.0, call-bind@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" + integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== + dependencies: + function-bind "^1.1.1" + get-intrinsic "^1.0.2" + +caller-callsite@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/caller-callsite/-/caller-callsite-2.0.0.tgz#847e0fce0a223750a9a027c54b33731ad3154134" + integrity sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ= + dependencies: + callsites "^2.0.0" + +caller-path@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/caller-path/-/caller-path-2.0.0.tgz#468f83044e369ab2010fac5f06ceee15bb2cb1f4" + integrity sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ= + dependencies: + caller-callsite "^2.0.0" + +callsites@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-2.0.0.tgz#06eb84f00eea413da86affefacbffb36093b3c50" + integrity sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA= + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +camel-case@^4.1.1: + version "4.1.2" + resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-4.1.2.tgz#9728072a954f805228225a6deea6b38461e1bd5a" + integrity sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw== + dependencies: + pascal-case "^3.1.2" + tslib "^2.0.3" + +camelcase@5.3.1, camelcase@^5.0.0, camelcase@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" + integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== + +camelcase@^6.0.0, camelcase@^6.1.0, camelcase@^6.2.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.2.0.tgz#924af881c9d525ac9d87f40d964e5cea982a1809" + integrity sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg== + +caniuse-api@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/caniuse-api/-/caniuse-api-3.0.0.tgz#5e4d90e2274961d46291997df599e3ed008ee4c0" + integrity sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw== + dependencies: + browserslist "^4.0.0" + caniuse-lite "^1.0.0" + lodash.memoize "^4.1.2" + lodash.uniq "^4.5.0" + +caniuse-lite@^1.0.0, caniuse-lite@^1.0.30000981, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001125, caniuse-lite@^1.0.30001181: + version "1.0.30001204" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001204.tgz#256c85709a348ec4d175e847a3b515c66e79f2aa" + integrity sha512-JUdjWpcxfJ9IPamy2f5JaRDCaqJOxDzOSKtbdx4rH9VivMd1vIzoPumsJa9LoMIi4Fx2BV2KZOxWhNkBjaYivQ== + +capture-exit@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/capture-exit/-/capture-exit-2.0.0.tgz#fb953bfaebeb781f62898239dabb426d08a509a4" + integrity sha512-PiT/hQmTonHhl/HFGN+Lx3JJUznrVYJ3+AQsnthneZbvW7x+f08Tk7yLJTLEOUvBTbduLeeBkxEaYXUOUrRq6g== + dependencies: + rsvp "^4.8.4" + +case-sensitive-paths-webpack-plugin@2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.3.0.tgz#23ac613cc9a856e4f88ff8bb73bbb5e989825cf7" + integrity sha512-/4YgnZS8y1UXXmC02xD5rRrBEu6T5ub+mQHLNRj0fzTRbgdBYhsNo2V5EqwgqrExjxsjtF/OpAKAMkKsxbD5XQ== + +caseless@~0.12.0: + version "0.12.0" + resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" + integrity sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw= + +chalk@2.4.2, chalk@^2.0.0, chalk@^2.4.1, chalk@^2.4.2: + version "2.4.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" + integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== + dependencies: + ansi-styles "^3.2.1" + escape-string-regexp "^1.0.5" + supports-color "^5.3.0" + +chalk@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" + integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +chalk@^4.0.0, chalk@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a" + integrity sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +char-regex@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" + integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== + +check-types@^11.1.1: + version "11.1.2" + resolved "https://registry.yarnpkg.com/check-types/-/check-types-11.1.2.tgz#86a7c12bf5539f6324eb0e70ca8896c0e38f3e2f" + integrity sha512-tzWzvgePgLORb9/3a0YenggReLKAIb2owL03H2Xdoe5pKcUyWRSEQ8xfCar8t2SIAuEDwtmx2da1YB52YuHQMQ== + +"chokidar@>=2.0.0 <4.0.0", chokidar@^3.4.1: + version "3.5.1" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.1.tgz#ee9ce7bbebd2b79f49f304799d5468e31e14e68a" + integrity sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw== + dependencies: + anymatch "~3.1.1" + braces "~3.0.2" + glob-parent "~5.1.0" + is-binary-path "~2.1.0" + is-glob "~4.0.1" + normalize-path "~3.0.0" + readdirp "~3.5.0" + optionalDependencies: + fsevents "~2.3.1" + +chokidar@^2.1.8: + version "2.1.8" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-2.1.8.tgz#804b3a7b6a99358c3c5c61e71d8728f041cff917" + integrity sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg== + dependencies: + anymatch "^2.0.0" + async-each "^1.0.1" + braces "^2.3.2" + glob-parent "^3.1.0" + inherits "^2.0.3" + is-binary-path "^1.0.0" + is-glob "^4.0.0" + normalize-path "^3.0.0" + path-is-absolute "^1.0.0" + readdirp "^2.2.1" + upath "^1.1.1" + optionalDependencies: + fsevents "^1.2.7" + +chownr@^1.1.1: + version "1.1.4" + resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" + integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== + +chownr@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" + integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== + +chrome-trace-event@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz#234090ee97c7d4ad1a2c4beae27505deffc608a4" + integrity sha512-9e/zx1jw7B4CO+c/RXoCsfg/x1AfUBioy4owYH0bJprEYAx5hRFLRhWBqHAG57D0ZM4H7vxbP7bPe0VwhQRYDQ== + dependencies: + tslib "^1.9.0" + +ci-info@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" + integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== + +cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" + integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +cjs-module-lexer@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-0.6.0.tgz#4186fcca0eae175970aee870b9fe2d6cf8d5655f" + integrity sha512-uc2Vix1frTfnuzxxu1Hp4ktSvM3QaI4oXl4ZUqL1wjTu/BGki9TrCWoqLTg/drR1KwAEarXuRFCG2Svr1GxPFw== + +class-utils@^0.3.5: + version "0.3.6" + resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463" + integrity sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg== + dependencies: + arr-union "^3.1.0" + define-property "^0.2.5" + isobject "^3.0.0" + static-extend "^0.1.1" + +clean-css@^4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-4.2.3.tgz#507b5de7d97b48ee53d84adb0160ff6216380f78" + integrity sha512-VcMWDN54ZN/DS+g58HYL5/n4Zrqe8vHJpGA8KdgUXFU4fuP/aHNw8eld9SyEIyabIMJX/0RaY/fplOo5hYLSFA== + dependencies: + source-map "~0.6.0" + +clean-stack@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" + integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== + +cliui@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-5.0.0.tgz#deefcfdb2e800784aa34f46fa08e06851c7bbbc5" + integrity sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA== + dependencies: + string-width "^3.1.0" + strip-ansi "^5.2.0" + wrap-ansi "^5.1.0" + +cliui@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1" + integrity sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ== + dependencies: + string-width "^4.2.0" + strip-ansi "^6.0.0" + wrap-ansi "^6.2.0" + +clone-deep@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/clone-deep/-/clone-deep-4.0.1.tgz#c19fd9bdbbf85942b4fd979c84dcf7d5f07c2387" + integrity sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ== + dependencies: + is-plain-object "^2.0.4" + kind-of "^6.0.2" + shallow-clone "^3.0.0" + +co@^4.6.0: + version "4.6.0" + resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" + integrity sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ= + +coa@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/coa/-/coa-2.0.2.tgz#43f6c21151b4ef2bf57187db0d73de229e3e7ec3" + integrity sha512-q5/jG+YQnSy4nRTV4F7lPepBJZ8qBNJJDBuJdoejDyLXgmL7IEo+Le2JDZudFTFt7mrCqIRaSjws4ygRCTCAXA== + dependencies: + "@types/q" "^1.5.1" + chalk "^2.4.1" + q "^1.1.2" + +collect-v8-coverage@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz#cc2c8e94fc18bbdffe64d6534570c8a673b27f59" + integrity sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg== + +collection-visit@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz#4bc0373c164bc3291b4d368c829cf1a80a59dca0" + integrity sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA= + dependencies: + map-visit "^1.0.0" + object-visit "^1.0.0" + +color-convert@^1.9.0, color-convert@^1.9.1: + version "1.9.3" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" + integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== + dependencies: + color-name "1.1.3" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" + integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= + +color-name@^1.0.0, color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +color-string@^1.5.4: + version "1.5.5" + resolved "https://registry.yarnpkg.com/color-string/-/color-string-1.5.5.tgz#65474a8f0e7439625f3d27a6a19d89fc45223014" + integrity sha512-jgIoum0OfQfq9Whcfc2z/VhCNcmQjWbey6qBX0vqt7YICflUmBCh9E9CiQD5GSJ+Uehixm3NUwHVhqUAWRivZg== + dependencies: + color-name "^1.0.0" + simple-swizzle "^0.2.2" + +color@^3.0.0: + version "3.1.3" + resolved "https://registry.yarnpkg.com/color/-/color-3.1.3.tgz#ca67fb4e7b97d611dcde39eceed422067d91596e" + integrity sha512-xgXAcTHa2HeFCGLE9Xs/R82hujGtu9Jd9x4NW3T34+OMs7VoPsjwzRczKHvTAHeJwWFwX5j15+MgAppE8ztObQ== + dependencies: + color-convert "^1.9.1" + color-string "^1.5.4" + +colorette@^1.2.1, colorette@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94" + integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w== + +combined-stream@^1.0.6, combined-stream@~1.0.6: + version "1.0.8" + resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + +commander@^2.20.0: + version "2.20.3" + resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33" + integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ== + +commander@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068" + integrity sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA== + +commander@^6.2.0: + version "6.2.1" + resolved "https://registry.yarnpkg.com/commander/-/commander-6.2.1.tgz#0792eb682dfbc325999bb2b84fddddba110ac73c" + integrity sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA== + +commander@^7.0.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" + integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== + +common-tags@^1.8.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.0.tgz#8e3153e542d4a39e9b10554434afaaf98956a937" + integrity sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw== + +commondir@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" + integrity sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs= + +component-emitter@^1.2.1: + version "1.3.0" + resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" + integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== + +compose-function@3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/compose-function/-/compose-function-3.0.3.tgz#9ed675f13cc54501d30950a486ff6a7ba3ab185f" + integrity sha1-ntZ18TzFRQHTCVCkhv9qe6OrGF8= + dependencies: + arity-n "^1.0.4" + +compressible@~2.0.16: + version "2.0.18" + resolved "https://registry.yarnpkg.com/compressible/-/compressible-2.0.18.tgz#af53cca6b070d4c3c0750fbd77286a6d7cc46fba" + integrity sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg== + dependencies: + mime-db ">= 1.43.0 < 2" + +compression@^1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/compression/-/compression-1.7.4.tgz#95523eff170ca57c29a0ca41e6fe131f41e5bb8f" + integrity sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ== + dependencies: + accepts "~1.3.5" + bytes "3.0.0" + compressible "~2.0.16" + debug "2.6.9" + on-headers "~1.0.2" + safe-buffer "5.1.2" + vary "~1.1.2" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= + +concat-stream@^1.5.0: + version "1.6.2" + resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz#904bdf194cd3122fc675c77fc4ac3d4ff0fd1a34" + integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== + dependencies: + buffer-from "^1.0.0" + inherits "^2.0.3" + readable-stream "^2.2.2" + typedarray "^0.0.6" + +confusing-browser-globals@^1.0.10: + version "1.0.10" + resolved "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.10.tgz#30d1e7f3d1b882b25ec4933d1d1adac353d20a59" + integrity sha512-gNld/3lySHwuhaVluJUKLePYirM3QNCKzVxqAdhJII9/WXKVX5PURzMVJspS1jTslSqjeuG4KMVTSouit5YPHA== + +connect-history-api-fallback@^1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz#8b32089359308d111115d81cad3fceab888f97bc" + integrity sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg== + +console-browserify@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.2.0.tgz#67063cef57ceb6cf4993a2ab3a55840ae8c49336" + integrity sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA== + +constants-browserify@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75" + integrity sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U= + +contains-path@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/contains-path/-/contains-path-0.1.0.tgz#fe8cf184ff6670b6baef01a9d4861a5cbec4120a" + integrity sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo= + +content-disposition@0.5.3: + version "0.5.3" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.3.tgz#e130caf7e7279087c5616c2007d0485698984fbd" + integrity sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g== + dependencies: + safe-buffer "5.1.2" + +content-type@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" + integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== + +convert-source-map@1.7.0, convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.7.0.tgz#17a2cb882d7f77d3490585e2ce6c524424a3a442" + integrity sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA== + dependencies: + safe-buffer "~5.1.1" + +convert-source-map@^0.3.3: + version "0.3.5" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-0.3.5.tgz#f1d802950af7dd2631a1febe0596550c86ab3190" + integrity sha1-8dgClQr33SYxof6+BZZVDIarMZA= + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" + integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= + +cookie@0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" + integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== + +copy-concurrently@^1.0.0: + version "1.0.5" + resolved "https://registry.yarnpkg.com/copy-concurrently/-/copy-concurrently-1.0.5.tgz#92297398cae34937fcafd6ec8139c18051f0b5e0" + integrity sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A== + dependencies: + aproba "^1.1.1" + fs-write-stream-atomic "^1.0.8" + iferr "^0.1.5" + mkdirp "^0.5.1" + rimraf "^2.5.4" + run-queue "^1.0.0" + +copy-descriptor@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d" + integrity sha1-Z29us8OZl8LuGsOpJP1hJHSPV40= + +copy-webpack-plugin@^6.3.2: + version "6.4.1" + resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-6.4.1.tgz#138cd9b436dbca0a6d071720d5414848992ec47e" + integrity sha512-MXyPCjdPVx5iiWyl40Va3JGh27bKzOTNY3NjUTrosD2q7dR/cLD0013uqJ3BpFbUjyONINjb6qI7nDIJujrMbA== + dependencies: + cacache "^15.0.5" + fast-glob "^3.2.4" + find-cache-dir "^3.3.1" + glob-parent "^5.1.1" + globby "^11.0.1" + loader-utils "^2.0.0" + normalize-path "^3.0.0" + p-limit "^3.0.2" + schema-utils "^3.0.0" + serialize-javascript "^5.0.1" + webpack-sources "^1.4.3" + +core-js-compat@^3.6.2, core-js-compat@^3.8.1, core-js-compat@^3.9.0: + version "3.9.1" + resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.9.1.tgz#4e572acfe90aff69d76d8c37759d21a5c59bb455" + integrity sha512-jXAirMQxrkbiiLsCx9bQPJFA6llDadKMpYrBJQJ3/c4/vsPP/fAf29h24tviRlvwUL6AmY5CHLu2GvjuYviQqA== + dependencies: + browserslist "^4.16.3" + semver "7.0.0" + +core-js-pure@^3.0.0: + version "3.9.1" + resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.9.1.tgz#677b322267172bd490e4464696f790cbc355bec5" + integrity sha512-laz3Zx0avrw9a4QEIdmIblnVuJz8W51leY9iLThatCsFawWxC3sE4guASC78JbCin+DkwMpCdp1AVAuzL/GN7A== + +core-js@^2.4.0: + version "2.6.12" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.12.tgz#d9333dfa7b065e347cc5682219d6f690859cc2ec" + integrity sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ== + +core-js@^3.6.5: + version "3.9.1" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.9.1.tgz#cec8de593db8eb2a85ffb0dbdeb312cb6e5460ae" + integrity sha512-gSjRvzkxQc1zjM/5paAmL4idJBFzuJoo+jDjF1tStYFMV2ERfD02HhahhCGXUyHxQRG4yFKVSdO6g62eoRMcDg== + +core-util-is@1.0.2, core-util-is@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" + integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac= + +cosmiconfig@^5.0.0: + version "5.2.1" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-5.2.1.tgz#040f726809c591e77a17c0a3626ca45b4f168b1a" + integrity sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA== + dependencies: + import-fresh "^2.0.0" + is-directory "^0.3.1" + js-yaml "^3.13.1" + parse-json "^4.0.0" + +cosmiconfig@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-6.0.0.tgz#da4fee853c52f6b1e6935f41c1a2fc50bd4a9982" + integrity sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.1.0" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.7.2" + +cosmiconfig@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.0.0.tgz#ef9b44d773959cae63ddecd122de23853b60f8d3" + integrity sha512-pondGvTuVYDk++upghXJabWzL6Kxu6f26ljFw64Swq9v6sQPUL3EUlVDV56diOjpCayKihL6hVe8exIACU4XcA== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.2.1" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.10.0" + +create-ecdh@^4.0.0: + version "4.0.4" + resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.4.tgz#d6e7f4bffa66736085a0762fd3a632684dabcc4e" + integrity sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A== + dependencies: + bn.js "^4.1.0" + elliptic "^6.5.3" + +create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" + integrity sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg== + dependencies: + cipher-base "^1.0.1" + inherits "^2.0.1" + md5.js "^1.3.4" + ripemd160 "^2.0.1" + sha.js "^2.4.0" + +create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" + integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== + dependencies: + cipher-base "^1.0.3" + create-hash "^1.1.0" + inherits "^2.0.1" + ripemd160 "^2.0.0" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +cross-spawn@7.0.3, cross-spawn@^7.0.0, cross-spawn@^7.0.2, cross-spawn@^7.0.3: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +cross-spawn@^6.0.0: + version "6.0.5" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz#4a5ec7c64dfae22c3a14124dbacdee846d80cbc4" + integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== + dependencies: + nice-try "^1.0.4" + path-key "^2.0.1" + semver "^5.5.0" + shebang-command "^1.2.0" + which "^1.2.9" + +crypto-browserify@^3.11.0: + version "3.12.0" + resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" + integrity sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg== + dependencies: + browserify-cipher "^1.0.0" + browserify-sign "^4.0.0" + create-ecdh "^4.0.0" + create-hash "^1.1.0" + create-hmac "^1.1.0" + diffie-hellman "^5.0.0" + inherits "^2.0.1" + pbkdf2 "^3.0.3" + public-encrypt "^4.0.0" + randombytes "^2.0.0" + randomfill "^1.0.3" + +crypto-random-string@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-1.0.0.tgz#a230f64f568310e1498009940790ec99545bca7e" + integrity sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4= + +css-blank-pseudo@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/css-blank-pseudo/-/css-blank-pseudo-0.1.4.tgz#dfdefd3254bf8a82027993674ccf35483bfcb3c5" + integrity sha512-LHz35Hr83dnFeipc7oqFDmsjHdljj3TQtxGGiNWSOsTLIAubSm4TEz8qCaKFpk7idaQ1GfWscF4E6mgpBysA1w== + dependencies: + postcss "^7.0.5" + +css-color-names@0.0.4, css-color-names@^0.0.4: + version "0.0.4" + resolved "https://registry.yarnpkg.com/css-color-names/-/css-color-names-0.0.4.tgz#808adc2e79cf84738069b646cb20ec27beb629e0" + integrity sha1-gIrcLnnPhHOAabZGyyDsJ762KeA= + +css-declaration-sorter@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/css-declaration-sorter/-/css-declaration-sorter-4.0.1.tgz#c198940f63a76d7e36c1e71018b001721054cb22" + integrity sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA== + dependencies: + postcss "^7.0.1" + timsort "^0.3.0" + +css-has-pseudo@^0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/css-has-pseudo/-/css-has-pseudo-0.10.0.tgz#3c642ab34ca242c59c41a125df9105841f6966ee" + integrity sha512-Z8hnfsZu4o/kt+AuFzeGpLVhFOGO9mluyHBaA2bA8aCGTwah5sT3WV/fTHH8UNZUytOIImuGPrl/prlb4oX4qQ== + dependencies: + postcss "^7.0.6" + postcss-selector-parser "^5.0.0-rc.4" + +css-loader@4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-4.3.0.tgz#c888af64b2a5b2e85462c72c0f4a85c7e2e0821e" + integrity sha512-rdezjCjScIrsL8BSYszgT4s476IcNKt6yX69t0pHjJVnPUTDpn4WfIpDQTN3wCJvUvfsz/mFjuGOekf3PY3NUg== + dependencies: + camelcase "^6.0.0" + cssesc "^3.0.0" + icss-utils "^4.1.1" + loader-utils "^2.0.0" + postcss "^7.0.32" + postcss-modules-extract-imports "^2.0.0" + postcss-modules-local-by-default "^3.0.3" + postcss-modules-scope "^2.2.0" + postcss-modules-values "^3.0.0" + postcss-value-parser "^4.1.0" + schema-utils "^2.7.1" + semver "^7.3.2" + +css-prefers-color-scheme@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/css-prefers-color-scheme/-/css-prefers-color-scheme-3.1.1.tgz#6f830a2714199d4f0d0d0bb8a27916ed65cff1f4" + integrity sha512-MTu6+tMs9S3EUqzmqLXEcgNRbNkkD/TGFvowpeoWJn5Vfq7FMgsmRQs9X5NXAURiOBmOxm/lLjsDNXDE6k9bhg== + dependencies: + postcss "^7.0.5" + +css-select-base-adapter@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz#3b2ff4972cc362ab88561507a95408a1432135d7" + integrity sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w== + +css-select@^2.0.0, css-select@^2.0.2: + version "2.1.0" + resolved "https://registry.yarnpkg.com/css-select/-/css-select-2.1.0.tgz#6a34653356635934a81baca68d0255432105dbef" + integrity sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ== + dependencies: + boolbase "^1.0.0" + css-what "^3.2.1" + domutils "^1.7.0" + nth-check "^1.0.2" + +css-tree@1.0.0-alpha.37: + version "1.0.0-alpha.37" + resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.0.0-alpha.37.tgz#98bebd62c4c1d9f960ec340cf9f7522e30709a22" + integrity sha512-DMxWJg0rnz7UgxKT0Q1HU/L9BeJI0M6ksor0OgqOnF+aRCDWg/N2641HmVyU9KVIu0OVVWOb2IpC9A+BJRnejg== + dependencies: + mdn-data "2.0.4" + source-map "^0.6.1" + +css-tree@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.2.tgz#9ae393b5dafd7dae8a622475caec78d3d8fbd7b5" + integrity sha512-wCoWush5Aeo48GLhfHPbmvZs59Z+M7k5+B1xDnXbdWNcEF423DoFdqSWE0PM5aNk5nI5cp1q7ms36zGApY/sKQ== + dependencies: + mdn-data "2.0.14" + source-map "^0.6.1" + +css-what@^3.2.1: + version "3.4.2" + resolved "https://registry.yarnpkg.com/css-what/-/css-what-3.4.2.tgz#ea7026fcb01777edbde52124e21f327e7ae950e4" + integrity sha512-ACUm3L0/jiZTqfzRM3Hi9Q8eZqd6IK37mMWPLz9PJxkLWllYeRf+EHUSHYEtFop2Eqytaq1FizFVh7XfBnXCDQ== + +css.escape@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/css.escape/-/css.escape-1.5.1.tgz#42e27d4fa04ae32f931a4b4d4191fa9cddee97cb" + integrity sha1-QuJ9T6BK4y+TGktNQZH6nN3ul8s= + +css@^2.0.0: + version "2.2.4" + resolved "https://registry.yarnpkg.com/css/-/css-2.2.4.tgz#c646755c73971f2bba6a601e2cf2fd71b1298929" + integrity sha512-oUnjmWpy0niI3x/mPL8dVEI1l7MnG3+HHyRPHf+YFSbK+svOhXpmSOcDURUh2aOCgl2grzrOPt1nHLuCVFULLw== + dependencies: + inherits "^2.0.3" + source-map "^0.6.1" + source-map-resolve "^0.5.2" + urix "^0.1.0" + +css@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/css/-/css-3.0.0.tgz#4447a4d58fdd03367c516ca9f64ae365cee4aa5d" + integrity sha512-DG9pFfwOrzc+hawpmqX/dHYHJG+Bsdb0klhyi1sDneOgGOXy9wQIC8hzyVp1e4NRYDBdxcylvywPkkXCHAzTyQ== + dependencies: + inherits "^2.0.4" + source-map "^0.6.1" + source-map-resolve "^0.6.0" + +cssdb@^4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/cssdb/-/cssdb-4.4.0.tgz#3bf2f2a68c10f5c6a08abd92378331ee803cddb0" + integrity sha512-LsTAR1JPEM9TpGhl/0p3nQecC2LJ0kD8X5YARu1hk/9I1gril5vDtMZyNxcEpxxDj34YNck/ucjuoUd66K03oQ== + +cssesc@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-2.0.0.tgz#3b13bd1bb1cb36e1bcb5a4dcd27f54c5dcb35703" + integrity sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg== + +cssesc@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" + integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg== + +cssnano-preset-default@^4.0.7: + version "4.0.7" + resolved "https://registry.yarnpkg.com/cssnano-preset-default/-/cssnano-preset-default-4.0.7.tgz#51ec662ccfca0f88b396dcd9679cdb931be17f76" + integrity sha512-x0YHHx2h6p0fCl1zY9L9roD7rnlltugGu7zXSKQx6k2rYw0Hi3IqxcoAGF7u9Q5w1nt7vK0ulxV8Lo+EvllGsA== + dependencies: + css-declaration-sorter "^4.0.1" + cssnano-util-raw-cache "^4.0.1" + postcss "^7.0.0" + postcss-calc "^7.0.1" + postcss-colormin "^4.0.3" + postcss-convert-values "^4.0.1" + postcss-discard-comments "^4.0.2" + postcss-discard-duplicates "^4.0.2" + postcss-discard-empty "^4.0.1" + postcss-discard-overridden "^4.0.1" + postcss-merge-longhand "^4.0.11" + postcss-merge-rules "^4.0.3" + postcss-minify-font-values "^4.0.2" + postcss-minify-gradients "^4.0.2" + postcss-minify-params "^4.0.2" + postcss-minify-selectors "^4.0.2" + postcss-normalize-charset "^4.0.1" + postcss-normalize-display-values "^4.0.2" + postcss-normalize-positions "^4.0.2" + postcss-normalize-repeat-style "^4.0.2" + postcss-normalize-string "^4.0.2" + postcss-normalize-timing-functions "^4.0.2" + postcss-normalize-unicode "^4.0.1" + postcss-normalize-url "^4.0.1" + postcss-normalize-whitespace "^4.0.2" + postcss-ordered-values "^4.1.2" + postcss-reduce-initial "^4.0.3" + postcss-reduce-transforms "^4.0.2" + postcss-svgo "^4.0.2" + postcss-unique-selectors "^4.0.1" + +cssnano-util-get-arguments@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/cssnano-util-get-arguments/-/cssnano-util-get-arguments-4.0.0.tgz#ed3a08299f21d75741b20f3b81f194ed49cc150f" + integrity sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8= + +cssnano-util-get-match@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/cssnano-util-get-match/-/cssnano-util-get-match-4.0.0.tgz#c0e4ca07f5386bb17ec5e52250b4f5961365156d" + integrity sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0= + +cssnano-util-raw-cache@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/cssnano-util-raw-cache/-/cssnano-util-raw-cache-4.0.1.tgz#b26d5fd5f72a11dfe7a7846fb4c67260f96bf282" + integrity sha512-qLuYtWK2b2Dy55I8ZX3ky1Z16WYsx544Q0UWViebptpwn/xDBmog2TLg4f+DBMg1rJ6JDWtn96WHbOKDWt1WQA== + dependencies: + postcss "^7.0.0" + +cssnano-util-same-parent@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz#574082fb2859d2db433855835d9a8456ea18bbf3" + integrity sha512-WcKx5OY+KoSIAxBW6UBBRay1U6vkYheCdjyVNDm85zt5K9mHoGOfsOsqIszfAqrQQFIIKgjh2+FDgIj/zsl21Q== + +cssnano@^4.1.10: + version "4.1.10" + resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-4.1.10.tgz#0ac41f0b13d13d465487e111b778d42da631b8b2" + integrity sha512-5wny+F6H4/8RgNlaqab4ktc3e0/blKutmq8yNlBFXA//nSFFAqAngjNVRzUvCgYROULmZZUoosL/KSoZo5aUaQ== + dependencies: + cosmiconfig "^5.0.0" + cssnano-preset-default "^4.0.7" + is-resolvable "^1.0.0" + postcss "^7.0.0" + +csso@^4.0.2: + version "4.2.0" + resolved "https://registry.yarnpkg.com/csso/-/csso-4.2.0.tgz#ea3a561346e8dc9f546d6febedd50187cf389529" + integrity sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA== + dependencies: + css-tree "^1.1.2" + +cssom@^0.4.4: + version "0.4.4" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" + integrity sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw== + +cssom@~0.3.6: + version "0.3.8" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" + integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg== + +cssstyle@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852" + integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A== + dependencies: + cssom "~0.3.6" + +csstype@^3.0.2: + version "3.0.7" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.7.tgz#2a5fb75e1015e84dd15692f71e89a1450290950b" + integrity sha512-KxnUB0ZMlnUWCsx2Z8MUsr6qV6ja1w9ArPErJaJaF8a5SOWoHLIszeCTKGRGRgtLgYrs1E8CHkNSP1VZTTPc9g== + +cyclist@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/cyclist/-/cyclist-1.0.1.tgz#596e9698fd0c80e12038c2b82d6eb1b35b6224d9" + integrity sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk= + +d@1, d@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/d/-/d-1.0.1.tgz#8698095372d58dbee346ffd0c7093f99f8f9eb5a" + integrity sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA== + dependencies: + es5-ext "^0.10.50" + type "^1.0.1" + +damerau-levenshtein@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.6.tgz#143c1641cb3d85c60c32329e26899adea8701791" + integrity sha512-JVrozIeElnj3QzfUIt8tB8YMluBJom4Vw9qTPpjGYQ9fYlB3D/rb6OordUxf3xeFB35LKWs0xqcO5U6ySvBtug== + +dashdash@^1.12.0: + version "1.14.1" + resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" + integrity sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA= + dependencies: + assert-plus "^1.0.0" + +data-urls@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-2.0.0.tgz#156485a72963a970f5d5821aaf642bef2bf2db9b" + integrity sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ== + dependencies: + abab "^2.0.3" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.0.0" + +debug@2.6.9, debug@^2.2.0, debug@^2.3.3, debug@^2.6.0, debug@^2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@^3.1.1, debug@^3.2.6: + version "3.2.7" + resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" + integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== + dependencies: + ms "^2.1.1" + +debug@^4.0.1, debug@^4.1.0, debug@^4.1.1: + version "4.3.1" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.1.tgz#f0d229c505e0c6d8c49ac553d1b13dc183f6b2ee" + integrity sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ== + dependencies: + ms "2.1.2" + +decamelize@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" + integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= + +decimal.js@^10.2.1: + version "10.2.1" + resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.2.1.tgz#238ae7b0f0c793d3e3cea410108b35a2c01426a3" + integrity sha512-KaL7+6Fw6i5A2XSnsbhm/6B+NuEA7TZ4vqxnd5tXz9sbKtrN9Srj8ab4vKVdK8YAqZO9P1kg45Y6YLoduPf+kw== + +decode-uri-component@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" + integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= + +dedent@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" + integrity sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw= + +deep-equal@^1.0.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-1.1.1.tgz#b5c98c942ceffaf7cb051e24e1434a25a2e6076a" + integrity sha512-yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g== + dependencies: + is-arguments "^1.0.4" + is-date-object "^1.0.1" + is-regex "^1.0.4" + object-is "^1.0.1" + object-keys "^1.1.1" + regexp.prototype.flags "^1.2.0" + +deep-is@^0.1.3, deep-is@~0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" + integrity sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ= + +deepmerge@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" + integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + +default-gateway@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-4.2.0.tgz#167104c7500c2115f6dd69b0a536bb8ed720552b" + integrity sha512-h6sMrVB1VMWVrW13mSc6ia/DwYYw5MN6+exNu1OaJeFac5aSAvwM7lZ0NVfTABuSkQelr4h5oebg3KB1XPdjgA== + dependencies: + execa "^1.0.0" + ip-regex "^2.1.0" + +define-properties@^1.1.2, define-properties@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.3.tgz#cf88da6cbee26fe6db7094f61d870cbd84cee9f1" + integrity sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ== + dependencies: + object-keys "^1.0.12" + +define-property@^0.2.5: + version "0.2.5" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz#c35b1ef918ec3c990f9a5bc57be04aacec5c8116" + integrity sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY= + dependencies: + is-descriptor "^0.1.0" + +define-property@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz#769ebaaf3f4a63aad3af9e8d304c9bbe79bfb0e6" + integrity sha1-dp66rz9KY6rTr56NMEybvnm/sOY= + dependencies: + is-descriptor "^1.0.0" + +define-property@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz#d459689e8d654ba77e02a817f8710d702cb16e9d" + integrity sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ== + dependencies: + is-descriptor "^1.0.2" + isobject "^3.0.1" + +del@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/del/-/del-4.1.1.tgz#9e8f117222ea44a31ff3a156c049b99052a9f0b4" + integrity sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ== + dependencies: + "@types/glob" "^7.1.1" + globby "^6.1.0" + is-path-cwd "^2.0.0" + is-path-in-cwd "^2.0.0" + p-map "^2.0.0" + pify "^4.0.1" + rimraf "^2.6.3" + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk= + +depd@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" + integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= + +des.js@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.0.1.tgz#5382142e1bdc53f85d86d53e5f4aa7deb91e0843" + integrity sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA== + dependencies: + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + +destroy@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" + integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= + +detect-newline@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" + integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA== + +detect-node@^2.0.4: + version "2.0.5" + resolved "https://registry.yarnpkg.com/detect-node/-/detect-node-2.0.5.tgz#9d270aa7eaa5af0b72c4c9d9b814e7f4ce738b79" + integrity sha512-qi86tE6hRcFHy8jI1m2VG+LaPUR1LhqDa5G8tVjuUXmOrpuAgqsA1pN0+ldgr3aKUH+QLI9hCY/OcRYisERejw== + +detect-port-alt@1.1.6: + version "1.1.6" + resolved "https://registry.yarnpkg.com/detect-port-alt/-/detect-port-alt-1.1.6.tgz#24707deabe932d4a3cf621302027c2b266568275" + integrity sha512-5tQykt+LqfJFBEYaDITx7S7cR7mJ/zQmLXZ2qt5w04ainYZw6tBf9dBunMjVeVOdYVRUzUOE4HkY5J7+uttb5Q== + dependencies: + address "^1.0.1" + debug "^2.6.0" + +diff-sequences@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-26.6.2.tgz#48ba99157de1923412eed41db6b6d4aa9ca7c0b1" + integrity sha512-Mv/TDa3nZ9sbc5soK+OoA74BsS3mL37yixCvUAQkiuA4Wz6YtwP/K47n2rv2ovzHZvoiQeA5FTQOschKkEwB0Q== + +diffie-hellman@^5.0.0: + version "5.0.3" + resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz#40e8ee98f55a2149607146921c63e1ae5f3d2875" + integrity sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg== + dependencies: + bn.js "^4.1.0" + miller-rabin "^4.0.0" + randombytes "^2.0.0" + +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +dns-equal@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/dns-equal/-/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d" + integrity sha1-s55/HabrCnW6nBcySzR1PEfgZU0= + +dns-packet@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/dns-packet/-/dns-packet-1.3.1.tgz#12aa426981075be500b910eedcd0b47dd7deda5a" + integrity sha512-0UxfQkMhYAUaZI+xrNZOz/as5KgDU0M/fQ9b6SpkyLbk3GEswDi6PADJVaYJradtRVsRIlF1zLyOodbcTCDzUg== + dependencies: + ip "^1.1.0" + safe-buffer "^5.0.1" + +dns-txt@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/dns-txt/-/dns-txt-2.0.2.tgz#b91d806f5d27188e4ab3e7d107d881a1cc4642b6" + integrity sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY= + dependencies: + buffer-indexof "^1.0.0" + +doctrine@1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-1.5.0.tgz#379dce730f6166f76cefa4e6707a159b02c5a6fa" + integrity sha1-N53Ocw9hZvds76TmcHoVmwLFpvo= + dependencies: + esutils "^2.0.2" + isarray "^1.0.0" + +doctrine@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz#5cd01fc101621b42c4cd7f5d1a66243716d3f39d" + integrity sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw== + dependencies: + esutils "^2.0.2" + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + +dom-accessibility-api@^0.5.4: + version "0.5.4" + resolved "https://registry.yarnpkg.com/dom-accessibility-api/-/dom-accessibility-api-0.5.4.tgz#b06d059cdd4a4ad9a79275f9d414a5c126241166" + integrity sha512-TvrjBckDy2c6v6RLxPv5QXOnU+SmF9nBII5621Ve5fu6Z/BDrENurBEvlC1f44lKEUVqOpK4w9E5Idc5/EgkLQ== + +dom-converter@^0.2: + version "0.2.0" + resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.2.0.tgz#6721a9daee2e293682955b6afe416771627bb768" + integrity sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA== + dependencies: + utila "~0.4" + +dom-serializer@0: + version "0.2.2" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-0.2.2.tgz#1afb81f533717175d478655debc5e332d9f9bb51" + integrity sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g== + dependencies: + domelementtype "^2.0.1" + entities "^2.0.0" + +dom-walk@^0.1.0: + version "0.1.2" + resolved "https://registry.yarnpkg.com/dom-walk/-/dom-walk-0.1.2.tgz#0c548bef048f4d1f2a97249002236060daa3fd84" + integrity sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w== + +domain-browser@^1.1.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.2.0.tgz#3d31f50191a6749dd1375a7f522e823d42e54eda" + integrity sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA== + +domelementtype@1, domelementtype@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-1.3.1.tgz#d048c44b37b0d10a7f2a3d5fee3f4333d790481f" + integrity sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w== + +domelementtype@^2.0.1: + version "2.1.0" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.1.0.tgz#a851c080a6d1c3d94344aed151d99f669edf585e" + integrity sha512-LsTgx/L5VpD+Q8lmsXSHW2WpA+eBlZ9HPf3erD1IoPF00/3JKHZ3BknUVA2QGDNu69ZNmyFmCWBSO45XjYKC5w== + +domexception@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" + integrity sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg== + dependencies: + webidl-conversions "^5.0.0" + +domhandler@^2.3.0: + version "2.4.2" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-2.4.2.tgz#8805097e933d65e85546f726d60f5eb88b44f803" + integrity sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA== + dependencies: + domelementtype "1" + +domutils@^1.5.1, domutils@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.7.0.tgz#56ea341e834e06e6748af7a1cb25da67ea9f8c2a" + integrity sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg== + dependencies: + dom-serializer "0" + domelementtype "1" + +dot-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" + integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + +dot-prop@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.3.0.tgz#90ccce708cd9cd82cc4dc8c3ddd9abdd55b20e88" + integrity sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q== + dependencies: + is-obj "^2.0.0" + +dotenv-expand@5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/dotenv-expand/-/dotenv-expand-5.1.0.tgz#3fbaf020bfd794884072ea26b1e9791d45a629f0" + integrity sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA== + +dotenv@8.2.0: + version "8.2.0" + resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-8.2.0.tgz#97e619259ada750eea3e4ea3e26bceea5424b16a" + integrity sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw== + +duplexer@^0.1.1, duplexer@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.2.tgz#3abe43aef3835f8ae077d136ddce0f276b0400e6" + integrity sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg== + +duplexify@^3.4.2, duplexify@^3.6.0: + version "3.7.1" + resolved "https://registry.yarnpkg.com/duplexify/-/duplexify-3.7.1.tgz#2a4df5317f6ccfd91f86d6fd25d8d8a103b88309" + integrity sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g== + dependencies: + end-of-stream "^1.0.0" + inherits "^2.0.1" + readable-stream "^2.0.0" + stream-shift "^1.0.0" + +ecc-jsbn@~0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" + integrity sha1-OoOpBOVDUyh4dMVkt1SThoSamMk= + dependencies: + jsbn "~0.1.0" + safer-buffer "^2.1.0" + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" + integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= + +ejs@^2.6.1: + version "2.7.4" + resolved "https://registry.yarnpkg.com/ejs/-/ejs-2.7.4.tgz#48661287573dcc53e366c7a1ae52c3a120eec9ba" + integrity sha512-7vmuyh5+kuUyJKePhQfRQBhXV5Ce+RnaeeQArKu1EAMpL3WbgMt5WG6uQZpEVvYSSsxMXRKOewtDk9RaTKXRlA== + +electron-to-chromium@^1.3.564, electron-to-chromium@^1.3.649: + version "1.3.702" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.702.tgz#39b8b6860b22806482ad07a8eaf35f861d4f3ce0" + integrity sha512-qJVUKFWQnF6wP7MmTngDkmm8/KPzaiTXNFOAg5j7DSa6J7kPou7mTBqC8jpUOxauQWwHR3pn4dMRdV8IE1xdtA== + +elliptic@^6.5.3: + version "6.5.4" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.4.tgz#da37cebd31e79a1367e941b592ed1fbebd58abbb" + integrity sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ== + dependencies: + bn.js "^4.11.9" + brorand "^1.1.0" + hash.js "^1.0.0" + hmac-drbg "^1.0.1" + inherits "^2.0.4" + minimalistic-assert "^1.0.1" + minimalistic-crypto-utils "^1.0.1" + +emittery@^0.7.1: + version "0.7.2" + resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.7.2.tgz#25595908e13af0f5674ab419396e2fb394cdfa82" + integrity sha512-A8OG5SR/ij3SsJdWDJdkkSYUjQdCUx6APQXem0SaEePBSRg4eymGYwBkKo1Y6DU+af/Jn2dBQqDBvjnr9Vi8nQ== + +emoji-regex@^7.0.1: + version "7.0.3" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" + integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== + +emoji-regex@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" + integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== + +emoji-regex@^9.0.0: + version "9.2.2" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" + integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== + +emojis-list@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389" + integrity sha1-TapNnbAPmBmIDHn6RXrlsJof04k= + +emojis-list@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" + integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" + integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= + +encoding@^0.1.11: + version "0.1.13" + resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" + integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== + dependencies: + iconv-lite "^0.6.2" + +end-of-stream@^1.0.0, end-of-stream@^1.1.0: + version "1.4.4" + resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" + integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== + dependencies: + once "^1.4.0" + +enhanced-resolve@^4.0.0, enhanced-resolve@^4.3.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-4.5.0.tgz#2f3cfd84dbe3b487f18f2db2ef1e064a571ca5ec" + integrity sha512-Nv9m36S/vxpsI+Hc4/ZGRs0n9mXqSWGGq49zxb/cJfPAQMbUtttJAlNPS4AQzaBdw/pKskw5bMbekT/Y7W/Wlg== + dependencies: + graceful-fs "^4.1.2" + memory-fs "^0.5.0" + tapable "^1.0.0" + +enquirer@^2.3.5, enquirer@^2.3.6: + version "2.3.6" + resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" + integrity sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg== + dependencies: + ansi-colors "^4.1.1" + +entities@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/entities/-/entities-1.1.2.tgz#bdfa735299664dfafd34529ed4f8522a275fea56" + integrity sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w== + +entities@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" + integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== + +envinfo@^7.7.3: + version "7.7.4" + resolved "https://registry.yarnpkg.com/envinfo/-/envinfo-7.7.4.tgz#c6311cdd38a0e86808c1c9343f667e4267c4a320" + integrity sha512-TQXTYFVVwwluWSFis6K2XKxgrD22jEv0FTuLCQI+OjH7rn93+iY0fSSFM5lrSxFY+H1+B0/cvvlamr3UsBivdQ== + +errno@^0.1.3, errno@~0.1.7: + version "0.1.8" + resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.8.tgz#8bb3e9c7d463be4976ff888f76b4809ebc2e811f" + integrity sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A== + dependencies: + prr "~1.0.1" + +error-ex@^1.2.0, error-ex@^1.3.1: + version "1.3.2" + resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" + integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== + dependencies: + is-arrayish "^0.2.1" + +error-stack-parser@^1.3.6: + version "1.3.6" + resolved "https://registry.yarnpkg.com/error-stack-parser/-/error-stack-parser-1.3.6.tgz#e0e73b93e417138d1cd7c0b746b1a4a14854c292" + integrity sha1-4Oc7k+QXE40c18C3RrGkoUhUwpI= + dependencies: + stackframe "^0.3.1" + +error-stack-parser@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/error-stack-parser/-/error-stack-parser-2.0.6.tgz#5a99a707bd7a4c58a797902d48d82803ede6aad8" + integrity sha512-d51brTeqC+BHlwF0BhPtcYgF5nlzf9ZZ0ZIUQNZpc9ZB9qw5IJ2diTrBY9jlCJkTLITYPjmiX6OWCwH+fuyNgQ== + dependencies: + stackframe "^1.1.1" + +es-abstract@^1.17.2, es-abstract@^1.18.0-next.1, es-abstract@^1.18.0-next.2: + version "1.18.0" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.0.tgz#ab80b359eecb7ede4c298000390bc5ac3ec7b5a4" + integrity sha512-LJzK7MrQa8TS0ja2w3YNLzUgJCGPdPOV1yVvezjNnS89D+VR08+Szt2mz3YB2Dck/+w5tfIq/RoUAFqJJGM2yw== + dependencies: + call-bind "^1.0.2" + es-to-primitive "^1.2.1" + function-bind "^1.1.1" + get-intrinsic "^1.1.1" + has "^1.0.3" + has-symbols "^1.0.2" + is-callable "^1.2.3" + is-negative-zero "^2.0.1" + is-regex "^1.1.2" + is-string "^1.0.5" + object-inspect "^1.9.0" + object-keys "^1.1.1" + object.assign "^4.1.2" + string.prototype.trimend "^1.0.4" + string.prototype.trimstart "^1.0.4" + unbox-primitive "^1.0.0" + +es-to-primitive@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz#e55cd4c9cdc188bcefb03b366c736323fc5c898a" + integrity sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA== + dependencies: + is-callable "^1.1.4" + is-date-object "^1.0.1" + is-symbol "^1.0.2" + +es5-ext@^0.10.35, es5-ext@^0.10.50: + version "0.10.53" + resolved "https://registry.yarnpkg.com/es5-ext/-/es5-ext-0.10.53.tgz#93c5a3acfdbef275220ad72644ad02ee18368de1" + integrity sha512-Xs2Stw6NiNHWypzRTY1MtaG/uJlwCk8kH81920ma8mvN8Xq1gsfhZvpkImLQArw8AHnv8MT2I45J3c0R8slE+Q== + dependencies: + es6-iterator "~2.0.3" + es6-symbol "~3.1.3" + next-tick "~1.0.0" + +es6-iterator@2.0.3, es6-iterator@~2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/es6-iterator/-/es6-iterator-2.0.3.tgz#a7de889141a05a94b0854403b2d0a0fbfa98f3b7" + integrity sha1-p96IkUGgWpSwhUQDstCg+/qY87c= + dependencies: + d "1" + es5-ext "^0.10.35" + es6-symbol "^3.1.1" + +es6-symbol@^3.1.1, es6-symbol@~3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/es6-symbol/-/es6-symbol-3.1.3.tgz#bad5d3c1bcdac28269f4cb331e431c78ac705d18" + integrity sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA== + dependencies: + d "^1.0.1" + ext "^1.1.2" + +escalade@^3.0.2, escalade@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" + integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== + +escape-html@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" + integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= + +escape-string-regexp@2.0.0, escape-string-regexp@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344" + integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== + +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= + +escodegen@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-2.0.0.tgz#5e32b12833e8aa8fa35e1bf0befa89380484c7dd" + integrity sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw== + dependencies: + esprima "^4.0.1" + estraverse "^5.2.0" + esutils "^2.0.2" + optionator "^0.8.1" + optionalDependencies: + source-map "~0.6.1" + +eslint-config-react-app@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/eslint-config-react-app/-/eslint-config-react-app-6.0.0.tgz#ccff9fc8e36b322902844cbd79197982be355a0e" + integrity sha512-bpoAAC+YRfzq0dsTk+6v9aHm/uqnDwayNAXleMypGl6CpxI9oXXscVHo4fk3eJPIn+rsbtNetB4r/ZIidFIE8A== + dependencies: + confusing-browser-globals "^1.0.10" + +eslint-import-resolver-node@^0.3.4: + version "0.3.4" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.4.tgz#85ffa81942c25012d8231096ddf679c03042c717" + integrity sha512-ogtf+5AB/O+nM6DIeBUNr2fuT7ot9Qg/1harBfBtaP13ekEWFQEEMP94BCB7zaNW3gyY+8SHYF00rnqYwXKWOA== + dependencies: + debug "^2.6.9" + resolve "^1.13.1" + +eslint-module-utils@^2.6.0: + version "2.6.0" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz#579ebd094f56af7797d19c9866c9c9486629bfa6" + integrity sha512-6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA== + dependencies: + debug "^2.6.9" + pkg-dir "^2.0.0" + +eslint-plugin-flowtype@^5.2.0: + version "5.4.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-flowtype/-/eslint-plugin-flowtype-5.4.0.tgz#a559526e56403cb97b470b524957fc526e2485fe" + integrity sha512-O0s0iTT5UxYuoOpHMLSIO2qZMyvrb9shhk1EM5INNGtJ2CffrfUmsnh6TVsnoT41fkXIEndP630WNovhoO87xQ== + dependencies: + lodash "^4.17.15" + string-natural-compare "^3.0.1" + +eslint-plugin-import@^2.22.1: + version "2.22.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.22.1.tgz#0896c7e6a0cf44109a2d97b95903c2bb689d7702" + integrity sha512-8K7JjINHOpH64ozkAhpT3sd+FswIZTfMZTjdx052pnWrgRCVfp8op9tbjpAk3DdUeI/Ba4C8OjdC0r90erHEOw== + dependencies: + array-includes "^3.1.1" + array.prototype.flat "^1.2.3" + contains-path "^0.1.0" + debug "^2.6.9" + doctrine "1.5.0" + eslint-import-resolver-node "^0.3.4" + eslint-module-utils "^2.6.0" + has "^1.0.3" + minimatch "^3.0.4" + object.values "^1.1.1" + read-pkg-up "^2.0.0" + resolve "^1.17.0" + tsconfig-paths "^3.9.0" + +eslint-plugin-jest@^24.1.0: + version "24.3.2" + resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-24.3.2.tgz#30a8b2dea6278d0da1d6fb9d6cd530aaf58050a1" + integrity sha512-cicWDr+RvTAOKS3Q/k03+Z3odt3VCiWamNUHWd6QWbVQWcYJyYgUTu8x0mx9GfeDEimawU5kQC+nQ3MFxIM6bw== + dependencies: + "@typescript-eslint/experimental-utils" "^4.0.1" + +eslint-plugin-jsx-a11y@^6.3.1: + version "6.4.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.4.1.tgz#a2d84caa49756942f42f1ffab9002436391718fd" + integrity sha512-0rGPJBbwHoGNPU73/QCLP/vveMlM1b1Z9PponxO87jfr6tuH5ligXbDT6nHSSzBC8ovX2Z+BQu7Bk5D/Xgq9zg== + dependencies: + "@babel/runtime" "^7.11.2" + aria-query "^4.2.2" + array-includes "^3.1.1" + ast-types-flow "^0.0.7" + axe-core "^4.0.2" + axobject-query "^2.2.0" + damerau-levenshtein "^1.0.6" + emoji-regex "^9.0.0" + has "^1.0.3" + jsx-ast-utils "^3.1.0" + language-tags "^1.0.5" + +eslint-plugin-react-hooks@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.2.0.tgz#8c229c268d468956334c943bb45fc860280f5556" + integrity sha512-623WEiZJqxR7VdxFCKLI6d6LLpwJkGPYKODnkH3D7WpOG5KM8yWueBd8TLsNAetEJNF5iJmolaAKO3F8yzyVBQ== + +eslint-plugin-react@^7.21.5: + version "7.23.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.23.1.tgz#f1a2e844c0d1967c822388204a8bc4dee8415b11" + integrity sha512-MvFGhZjI8Z4HusajmSw0ougGrq3Gs4vT/0WgwksZgf5RrLrRa2oYAw56okU4tZJl8+j7IYNuTM+2RnFEuTSdRQ== + dependencies: + array-includes "^3.1.3" + array.prototype.flatmap "^1.2.4" + doctrine "^2.1.0" + has "^1.0.3" + jsx-ast-utils "^2.4.1 || ^3.0.0" + minimatch "^3.0.4" + object.entries "^1.1.3" + object.fromentries "^2.0.4" + object.values "^1.1.3" + prop-types "^15.7.2" + resolve "^2.0.0-next.3" + string.prototype.matchall "^4.0.4" + +eslint-plugin-testing-library@^3.9.2: + version "3.10.2" + resolved "https://registry.yarnpkg.com/eslint-plugin-testing-library/-/eslint-plugin-testing-library-3.10.2.tgz#609ec2b0369da7cf2e6d9edff5da153cc31d87bd" + integrity sha512-WAmOCt7EbF1XM8XfbCKAEzAPnShkNSwcIsAD2jHdsMUT9mZJPjLCG7pMzbcC8kK366NOuGip8HKLDC+Xk4yIdA== + dependencies: + "@typescript-eslint/experimental-utils" "^3.10.1" + +eslint-scope@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-4.0.3.tgz#ca03833310f6889a3264781aa82e63eb9cfe7848" + integrity sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg== + dependencies: + esrecurse "^4.1.0" + estraverse "^4.1.1" + +eslint-scope@^5.0.0, eslint-scope@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== + dependencies: + esrecurse "^4.3.0" + estraverse "^4.1.1" + +eslint-utils@^2.0.0, eslint-utils@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-2.1.0.tgz#d2de5e03424e707dc10c74068ddedae708741b27" + integrity sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg== + dependencies: + eslint-visitor-keys "^1.1.0" + +eslint-visitor-keys@^1.0.0, eslint-visitor-keys@^1.1.0, eslint-visitor-keys@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz#30ebd1ef7c2fdff01c3a4f151044af25fab0523e" + integrity sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ== + +eslint-visitor-keys@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz#21fdc8fbcd9c795cc0321f0563702095751511a8" + integrity sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ== + +eslint-webpack-plugin@^2.5.2: + version "2.5.3" + resolved "https://registry.yarnpkg.com/eslint-webpack-plugin/-/eslint-webpack-plugin-2.5.3.tgz#a125585a1d8bb9c939f2a920a9bc9be4a21cdb58" + integrity sha512-LewNevZf9ghDCxCGT6QltNWVi8KIYWc4LKcin8K9Azh1hypG7YAmobUDIU67fAPa+eMjRnU4rjEkLbYI1w5/UA== + dependencies: + "@types/eslint" "^7.2.6" + arrify "^2.0.1" + jest-worker "^26.6.2" + micromatch "^4.0.2" + schema-utils "^3.0.0" + +eslint@^7.11.0: + version "7.23.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.23.0.tgz#8d029d252f6e8cf45894b4bee08f5493f8e94325" + integrity sha512-kqvNVbdkjzpFy0XOszNwjkKzZ+6TcwCQ/h+ozlcIWwaimBBuhlQ4nN6kbiM2L+OjDcznkTJxzYfRFH92sx4a0Q== + dependencies: + "@babel/code-frame" "7.12.11" + "@eslint/eslintrc" "^0.4.0" + ajv "^6.10.0" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.0.1" + doctrine "^3.0.0" + enquirer "^2.3.5" + eslint-scope "^5.1.1" + eslint-utils "^2.1.0" + eslint-visitor-keys "^2.0.0" + espree "^7.3.1" + esquery "^1.4.0" + esutils "^2.0.2" + file-entry-cache "^6.0.1" + functional-red-black-tree "^1.0.1" + glob-parent "^5.0.0" + globals "^13.6.0" + ignore "^4.0.6" + import-fresh "^3.0.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + js-yaml "^3.13.1" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash "^4.17.21" + minimatch "^3.0.4" + natural-compare "^1.4.0" + optionator "^0.9.1" + progress "^2.0.0" + regexpp "^3.1.0" + semver "^7.2.1" + strip-ansi "^6.0.0" + strip-json-comments "^3.1.0" + table "^6.0.4" + text-table "^0.2.0" + v8-compile-cache "^2.0.3" + +espree@^7.3.0, espree@^7.3.1: + version "7.3.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-7.3.1.tgz#f2df330b752c6f55019f8bd89b7660039c1bbbb6" + integrity sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g== + dependencies: + acorn "^7.4.0" + acorn-jsx "^5.3.1" + eslint-visitor-keys "^1.3.0" + +esprima@^4.0.0, esprima@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" + integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== + +esquery@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.4.0.tgz#2148ffc38b82e8c7057dfed48425b3e61f0f24a5" + integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.1.0, esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^4.1.1: + version "4.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" + integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.2.0.tgz#307df42547e6cc7324d3cf03c155d5cdb8c53880" + integrity sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ== + +estree-walker@^0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-0.6.1.tgz#53049143f40c6eb918b23671d1fe3219f3a1b362" + integrity sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w== + +estree-walker@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-1.0.1.tgz#31bc5d612c96b704106b477e6dd5d8aa138cb700" + integrity sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" + integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= + +eventemitter3@^4.0.0: + version "4.0.7" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.7.tgz#2de9b68f6528d5644ef5c59526a1b4a07306169f" + integrity sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw== + +events@^3.0.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" + integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== + +eventsource@^1.0.7: + version "1.1.0" + resolved "https://registry.yarnpkg.com/eventsource/-/eventsource-1.1.0.tgz#00e8ca7c92109e94b0ddf32dac677d841028cfaf" + integrity sha512-VSJjT5oCNrFvCS6igjzPAt5hBzQ2qPBFIbJ03zLI9SE0mxwZpMw6BfJrbFHm1a141AavMEB8JHmBhWAd66PfCg== + dependencies: + original "^1.0.0" + +evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" + integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== + dependencies: + md5.js "^1.3.4" + safe-buffer "^5.1.1" + +exec-sh@^0.3.2: + version "0.3.6" + resolved "https://registry.yarnpkg.com/exec-sh/-/exec-sh-0.3.6.tgz#ff264f9e325519a60cb5e273692943483cca63bc" + integrity sha512-nQn+hI3yp+oD0huYhKwvYI32+JFeq+XkNcD1GAo3Y/MjxsfVGmrrzrnzjWiNY6f+pUCP440fThsFh5gZrRAU/w== + +execa@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/execa/-/execa-1.0.0.tgz#c6236a5bb4df6d6f15e88e7f017798216749ddd8" + integrity sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA== + dependencies: + cross-spawn "^6.0.0" + get-stream "^4.0.0" + is-stream "^1.1.0" + npm-run-path "^2.0.0" + p-finally "^1.0.0" + signal-exit "^3.0.0" + strip-eof "^1.0.0" + +execa@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/execa/-/execa-4.1.0.tgz#4e5491ad1572f2f17a77d388c6c857135b22847a" + integrity sha512-j5W0//W7f8UxAn8hXVnwG8tLwdiUy4FJLcSupCg6maBYZDpyBvTApK7KyuI4bKj8KOh1r2YH+6ucuYtJv1bTZA== + dependencies: + cross-spawn "^7.0.0" + get-stream "^5.0.0" + human-signals "^1.1.1" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.0" + onetime "^5.1.0" + signal-exit "^3.0.2" + strip-final-newline "^2.0.0" + +execa@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/execa/-/execa-5.0.0.tgz#4029b0007998a841fbd1032e5f4de86a3c1e3376" + integrity sha512-ov6w/2LCiuyO4RLYGdpFGjkcs0wMTgGE8PrkTHikeUy5iJekXyPIKUjifk5CsE0pt7sMCrMZ3YNqoCj6idQOnQ== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + +exit@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/exit/-/exit-0.1.2.tgz#0632638f8d877cc82107d30a0fff1a17cba1cd0c" + integrity sha1-BjJjj42HfMghB9MKD/8aF8uhzQw= + +expand-brackets@^2.1.4: + version "2.1.4" + resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz#b77735e315ce30f6b6eff0f83b04151a22449622" + integrity sha1-t3c14xXOMPa27/D4OwQVGiJEliI= + dependencies: + debug "^2.3.3" + define-property "^0.2.5" + extend-shallow "^2.0.1" + posix-character-classes "^0.1.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +expect@^26.6.0, expect@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/expect/-/expect-26.6.2.tgz#c6b996bf26bf3fe18b67b2d0f51fc981ba934417" + integrity sha512-9/hlOBkQl2l/PLHJx6JjoDF6xPKcJEsUlWKb23rKE7KzeDqUZKXKNMW27KIue5JMdBV9HgmoJPcc8HtO85t9IA== + dependencies: + "@jest/types" "^26.6.2" + ansi-styles "^4.0.0" + jest-get-type "^26.3.0" + jest-matcher-utils "^26.6.2" + jest-message-util "^26.6.2" + jest-regex-util "^26.0.0" + +express@^4.17.1: + version "4.17.1" + resolved "https://registry.yarnpkg.com/express/-/express-4.17.1.tgz#4491fc38605cf51f8629d39c2b5d026f98a4c134" + integrity sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g== + dependencies: + accepts "~1.3.7" + array-flatten "1.1.1" + body-parser "1.19.0" + content-disposition "0.5.3" + content-type "~1.0.4" + cookie "0.4.0" + cookie-signature "1.0.6" + debug "2.6.9" + depd "~1.1.2" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "~1.1.2" + fresh "0.5.2" + merge-descriptors "1.0.1" + methods "~1.1.2" + on-finished "~2.3.0" + parseurl "~1.3.3" + path-to-regexp "0.1.7" + proxy-addr "~2.0.5" + qs "6.7.0" + range-parser "~1.2.1" + safe-buffer "5.1.2" + send "0.17.1" + serve-static "1.14.1" + setprototypeof "1.1.1" + statuses "~1.5.0" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +ext@^1.1.2: + version "1.4.0" + resolved "https://registry.yarnpkg.com/ext/-/ext-1.4.0.tgz#89ae7a07158f79d35517882904324077e4379244" + integrity sha512-Key5NIsUxdqKg3vIsdw9dSuXpPCQ297y6wBjL30edxwPgt2E44WcWBZey/ZvUc6sERLTxKdyCu4gZFmUbk1Q7A== + dependencies: + type "^2.0.0" + +extend-shallow@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" + integrity sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8= + dependencies: + is-extendable "^0.1.0" + +extend-shallow@^3.0.0, extend-shallow@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8" + integrity sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg= + dependencies: + assign-symbols "^1.0.0" + is-extendable "^1.0.1" + +extend@~3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" + integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== + +extglob@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543" + integrity sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw== + dependencies: + array-unique "^0.3.2" + define-property "^1.0.0" + expand-brackets "^2.1.4" + extend-shallow "^2.0.1" + fragment-cache "^0.2.1" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +extsprintf@1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" + integrity sha1-lpGEQOMEGnpBT4xS48V06zw+HgU= + +extsprintf@^1.2.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.0.tgz#e2689f8f356fad62cca65a3a91c5df5f9551692f" + integrity sha1-4mifjzVvrWLMplo6kcXfX5VRaS8= + +fast-deep-equal@^3.1.1: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-glob@^3.1.1, fast-glob@^3.2.4: + version "3.2.5" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.5.tgz#7939af2a656de79a4f1901903ee8adcaa7cb9661" + integrity sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.0" + merge2 "^1.3.0" + micromatch "^4.0.2" + picomatch "^2.2.1" + +fast-json-stable-stringify@^2.0.0, fast-json-stable-stringify@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@^2.0.6, fast-levenshtein@~2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= + +fastest-levenshtein@^1.0.12: + version "1.0.12" + resolved "https://registry.yarnpkg.com/fastest-levenshtein/-/fastest-levenshtein-1.0.12.tgz#9990f7d3a88cc5a9ffd1f1745745251700d497e2" + integrity sha512-On2N+BpYJ15xIC974QNVuYGMOlEVt4s0EOI3wwMqOmK1fdDY+FN/zltPV8vosq4ad4c/gJ1KHScUn/6AWIgiow== + +fastq@^1.6.0: + version "1.11.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.11.0.tgz#bb9fb955a07130a918eb63c1f5161cc32a5d0858" + integrity sha512-7Eczs8gIPDrVzT+EksYBcupqMyxSHXXrHOLRRxU2/DicV8789MRBRR8+Hc2uWzUupOs4YS4JzBmBxjjCVBxD/g== + dependencies: + reusify "^1.0.4" + +faye-websocket@^0.11.3: + version "0.11.3" + resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.3.tgz#5c0e9a8968e8912c286639fde977a8b209f2508e" + integrity sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA== + dependencies: + websocket-driver ">=0.5.1" + +fb-watchman@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85" + integrity sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg== + dependencies: + bser "2.1.1" + +figgy-pudding@^3.5.1: + version "3.5.2" + resolved "https://registry.yarnpkg.com/figgy-pudding/-/figgy-pudding-3.5.2.tgz#b4eee8148abb01dcf1d1ac34367d59e12fa61d6e" + integrity sha512-0btnI/H8f2pavGMN8w40mlSKOfTK2SVJmBfBeVIj3kNw0swwgzyRq0d5TJVOwodFmtvpPeWPN/MCcfuWF0Ezbw== + +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + +file-loader@6.1.1: + version "6.1.1" + resolved "https://registry.yarnpkg.com/file-loader/-/file-loader-6.1.1.tgz#a6f29dfb3f5933a1c350b2dbaa20ac5be0539baa" + integrity sha512-Klt8C4BjWSXYQAfhpYYkG4qHNTna4toMHEbWrI5IuVoxbU6uiDKeKAP99R8mmbJi3lvewn/jQBOgU4+NS3tDQw== + dependencies: + loader-utils "^2.0.0" + schema-utils "^3.0.0" + +file-uri-to-path@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" + integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== + +filesize@6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/filesize/-/filesize-6.1.0.tgz#e81bdaa780e2451d714d71c0d7a4f3238d37ad00" + integrity sha512-LpCHtPQ3sFx67z+uh2HnSyWSLLu5Jxo21795uRDuar/EOuYWXib5EmPaGIBuSnRqH2IODiKA2k5re/K9OnN/Yg== + +fill-range@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7" + integrity sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc= + dependencies: + extend-shallow "^2.0.1" + is-number "^3.0.0" + repeat-string "^1.6.1" + to-regex-range "^2.1.0" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +finalhandler@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d" + integrity sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA== + dependencies: + debug "2.6.9" + encodeurl "~1.0.2" + escape-html "~1.0.3" + on-finished "~2.3.0" + parseurl "~1.3.3" + statuses "~1.5.0" + unpipe "~1.0.0" + +find-cache-dir@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-2.1.0.tgz#8d0f94cd13fe43c6c7c261a0d86115ca918c05f7" + integrity sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ== + dependencies: + commondir "^1.0.1" + make-dir "^2.0.0" + pkg-dir "^3.0.0" + +find-cache-dir@^3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-3.3.1.tgz#89b33fad4a4670daa94f855f7fbe31d6d84fe880" + integrity sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ== + dependencies: + commondir "^1.0.1" + make-dir "^3.0.2" + pkg-dir "^4.1.0" + +find-up@4.1.0, find-up@^4.0.0, find-up@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" + integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== + dependencies: + locate-path "^5.0.0" + path-exists "^4.0.0" + +find-up@^2.0.0, find-up@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7" + integrity sha1-RdG35QbHF93UgndaK3eSCjwMV6c= + dependencies: + locate-path "^2.0.0" + +find-up@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" + integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== + dependencies: + locate-path "^3.0.0" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flatted@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.1.tgz#c4b489e80096d9df1dfc97c79871aea7c617c469" + integrity sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA== + +flatten@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/flatten/-/flatten-1.0.3.tgz#c1283ac9f27b368abc1e36d1ff7b04501a30356b" + integrity sha512-dVsPA/UwQ8+2uoFe5GHtiBMu48dWLTdsuEd7CKGlZlD78r1TTWBvDuFaFGKCo/ZfEr95Uk56vZoX86OsHkUeIg== + +flush-write-stream@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/flush-write-stream/-/flush-write-stream-1.1.1.tgz#8dd7d873a1babc207d94ead0c2e0e44276ebf2e8" + integrity sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w== + dependencies: + inherits "^2.0.3" + readable-stream "^2.3.6" + +follow-redirects@^1.0.0: + version "1.13.3" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.13.3.tgz#e5598ad50174c1bc4e872301e82ac2cd97f90267" + integrity sha512-DUgl6+HDzB0iEptNQEXLx/KhTmDb8tZUHSeLqpnjpknR70H0nC2t9N73BK6fN4hOvJ84pKlIQVQ4k5FFlBedKA== + +for-in@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" + integrity sha1-gQaNKVqBQuwKxybG4iAMMPttXoA= + +forever-agent@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" + integrity sha1-+8cfDEGt6zf5bFd60e1C2P2sypE= + +fork-ts-checker-webpack-plugin@4.1.6: + version "4.1.6" + resolved "https://registry.yarnpkg.com/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-4.1.6.tgz#5055c703febcf37fa06405d400c122b905167fc5" + integrity sha512-DUxuQaKoqfNne8iikd14SAkh5uw4+8vNifp6gmA73yYNS6ywLIWSLD/n/mBzHQRpW3J7rbATEakmiA8JvkTyZw== + dependencies: + "@babel/code-frame" "^7.5.5" + chalk "^2.4.1" + micromatch "^3.1.10" + minimatch "^3.0.4" + semver "^5.6.0" + tapable "^1.0.0" + worker-rpc "^0.1.0" + +form-data@~2.3.2: + version "2.3.3" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6" + integrity sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.6" + mime-types "^2.1.12" + +forwarded@~0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" + integrity sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ= + +fragment-cache@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" + integrity sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk= + dependencies: + map-cache "^0.2.2" + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" + integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= + +from2@^2.1.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/from2/-/from2-2.3.0.tgz#8bfb5502bde4a4d36cfdeea007fcca21d7e382af" + integrity sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8= + dependencies: + inherits "^2.0.1" + readable-stream "^2.0.0" + +fs-extra@^7.0.0: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" + integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== + dependencies: + graceful-fs "^4.1.2" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-extra@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" + integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== + dependencies: + graceful-fs "^4.2.0" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-extra@^9.0.1: + version "9.1.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" + integrity sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ== + dependencies: + at-least-node "^1.0.0" + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + +fs-minipass@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" + integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== + dependencies: + minipass "^3.0.0" + +fs-write-stream-atomic@^1.0.8: + version "1.0.10" + resolved "https://registry.yarnpkg.com/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz#b47df53493ef911df75731e70a9ded0189db40c9" + integrity sha1-tH31NJPvkR33VzHnCp3tAYnbQMk= + dependencies: + graceful-fs "^4.1.2" + iferr "^0.1.5" + imurmurhash "^0.1.4" + readable-stream "1 || 2" + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= + +fsevents@^1.2.7: + version "1.2.13" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.13.tgz#f325cb0455592428bcf11b383370ef70e3bfcc38" + integrity sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw== + dependencies: + bindings "^1.5.0" + nan "^2.12.1" + +fsevents@^2.1.2, fsevents@^2.1.3, fsevents@~2.3.1: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + +function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" + integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== + +functional-red-black-tree@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" + integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= + +gensync@^1.0.0-beta.1, gensync@^1.0.0-beta.2: + version "1.0.0-beta.2" + resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" + integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== + +get-caller-file@^2.0.1: + version "2.0.5" + resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" + integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== + +get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.1.tgz#15f59f376f855c446963948f0d24cd3637b4abc6" + integrity sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q== + dependencies: + function-bind "^1.1.1" + has "^1.0.3" + has-symbols "^1.0.1" + +get-own-enumerable-property-symbols@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz#b5fde77f22cbe35f390b4e089922c50bce6ef664" + integrity sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g== + +get-package-type@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" + integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== + +get-stream@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" + integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== + dependencies: + pump "^3.0.0" + +get-stream@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" + integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== + dependencies: + pump "^3.0.0" + +get-stream@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.0.tgz#3e0012cb6827319da2706e601a1583e8629a6718" + integrity sha512-A1B3Bh1UmL0bidM/YX2NsCOTnGJePL9rO/M+Mw3m9f2gUpfokS0hi5Eah0WSUEWZdZhIZtMjkIYS7mDfOqNHbg== + +get-value@^2.0.3, get-value@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" + integrity sha1-3BXKHGcjh8p2vTesCjlbogQqLCg= + +getpass@^0.1.1: + version "0.1.7" + resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" + integrity sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo= + dependencies: + assert-plus "^1.0.0" + +glob-parent@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-3.1.0.tgz#9e6af6299d8d3bd2bd40430832bd113df906c5ae" + integrity sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4= + dependencies: + is-glob "^3.1.0" + path-dirname "^1.0.0" + +glob-parent@^5.0.0, glob-parent@^5.1.0, glob-parent@^5.1.1, glob-parent@~5.1.0: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob@^7.0.3, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: + version "7.1.6" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" + integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" + +global-modules@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/global-modules/-/global-modules-2.0.0.tgz#997605ad2345f27f51539bea26574421215c7780" + integrity sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A== + dependencies: + global-prefix "^3.0.0" + +global-prefix@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/global-prefix/-/global-prefix-3.0.0.tgz#fc85f73064df69f50421f47f883fe5b913ba9b97" + integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== + dependencies: + ini "^1.3.5" + kind-of "^6.0.2" + which "^1.3.1" + +global@^4.3.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/global/-/global-4.4.0.tgz#3e7b105179006a323ed71aafca3e9c57a5cc6406" + integrity sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w== + dependencies: + min-document "^2.19.0" + process "^0.11.10" + +globals@^11.1.0: + version "11.12.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" + integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== + +globals@^12.1.0: + version "12.4.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-12.4.0.tgz#a18813576a41b00a24a97e7f815918c2e19925f8" + integrity sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg== + dependencies: + type-fest "^0.8.1" + +globals@^13.6.0: + version "13.7.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.7.0.tgz#aed3bcefd80ad3ec0f0be2cf0c895110c0591795" + integrity sha512-Aipsz6ZKRxa/xQkZhNg0qIWXT6x6rD46f6x/PCnBomlttdIyAPak4YD9jTmKpZ72uROSMU87qJtcgpgHaVchiA== + dependencies: + type-fest "^0.20.2" + +globby@11.0.1: + version "11.0.1" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.1.tgz#9a2bf107a068f3ffeabc49ad702c79ede8cfd357" + integrity sha512-iH9RmgwCmUJHi2z5o2l3eTtGBtXek1OYlHrbcxOYugyHLmAsZrPj43OtHThd62Buh/Vv6VyCBD2bdyWcGNQqoQ== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.1.1" + ignore "^5.1.4" + merge2 "^1.3.0" + slash "^3.0.0" + +globby@^11.0.1: + version "11.0.3" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.3.tgz#9b1f0cb523e171dd1ad8c7b2a9fb4b644b9593cb" + integrity sha512-ffdmosjA807y7+lA1NM0jELARVmYul/715xiILEjo3hBLPTcirgQNnXECn5g3mtR8TOLCVbkfua1Hpen25/Xcg== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.1.1" + ignore "^5.1.4" + merge2 "^1.3.0" + slash "^3.0.0" + +globby@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz#f5a6d70e8395e21c858fb0489d64df02424d506c" + integrity sha1-9abXDoOV4hyFj7BInWTfAkJNUGw= + dependencies: + array-union "^1.0.1" + glob "^7.0.3" + object-assign "^4.0.1" + pify "^2.0.0" + pinkie-promise "^2.0.0" + +graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4: + version "4.2.6" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.6.tgz#ff040b2b0853b23c3d31027523706f1885d76bee" + integrity sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ== + +growly@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081" + integrity sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE= + +gzip-size@5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/gzip-size/-/gzip-size-5.1.1.tgz#cb9bee692f87c0612b232840a873904e4c135274" + integrity sha512-FNHi6mmoHvs1mxZAds4PpdCS6QG8B4C1krxJsMutgxl5t3+GlRTzzI3NEkifXx2pVsOvJdOGSmIgDhQ55FwdPA== + dependencies: + duplexer "^0.1.1" + pify "^4.0.1" + +gzip-size@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/gzip-size/-/gzip-size-6.0.0.tgz#065367fd50c239c0671cbcbad5be3e2eeb10e462" + integrity sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q== + dependencies: + duplexer "^0.1.2" + +handle-thing@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/handle-thing/-/handle-thing-2.0.1.tgz#857f79ce359580c340d43081cc648970d0bb234e" + integrity sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg== + +har-schema@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" + integrity sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI= + +har-validator@~5.1.3: + version "5.1.5" + resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd" + integrity sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w== + dependencies: + ajv "^6.12.3" + har-schema "^2.0.0" + +harmony-reflect@^1.4.6: + version "1.6.1" + resolved "https://registry.yarnpkg.com/harmony-reflect/-/harmony-reflect-1.6.1.tgz#c108d4f2bb451efef7a37861fdbdae72c9bdefa9" + integrity sha512-WJTeyp0JzGtHcuMsi7rw2VwtkvLa+JyfEKJCFyfcS0+CDkjQ5lHPu7zEhFZP+PDSRrEgXa5Ah0l1MbgbE41XjA== + +has-bigints@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.1.tgz#64fe6acb020673e3b78db035a5af69aa9d07b113" + integrity sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA== + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" + integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has-symbols@^1.0.1, has-symbols@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" + integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== + +has-value@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" + integrity sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8= + dependencies: + get-value "^2.0.3" + has-values "^0.1.4" + isobject "^2.0.0" + +has-value@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz#18b281da585b1c5c51def24c930ed29a0be6b177" + integrity sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc= + dependencies: + get-value "^2.0.6" + has-values "^1.0.0" + isobject "^3.0.0" + +has-values@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz#6d61de95d91dfca9b9a02089ad384bff8f62b771" + integrity sha1-bWHeldkd/Km5oCCJrThL/49it3E= + +has-values@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz#95b0b63fec2146619a6fe57fe75628d5a39efe4f" + integrity sha1-lbC2P+whRmGab+V/51Yo1aOe/k8= + dependencies: + is-number "^3.0.0" + kind-of "^4.0.0" + +has@^1.0.0, has@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" + integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== + dependencies: + function-bind "^1.1.1" + +hash-base@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.1.0.tgz#55c381d9e06e1d2997a883b4a3fddfe7f0d3af33" + integrity sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA== + dependencies: + inherits "^2.0.4" + readable-stream "^3.6.0" + safe-buffer "^5.2.0" + +hash.js@^1.0.0, hash.js@^1.0.3: + version "1.1.7" + resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.7.tgz#0babca538e8d4ee4a0f8988d68866537a003cf42" + integrity sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA== + dependencies: + inherits "^2.0.3" + minimalistic-assert "^1.0.1" + +he@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" + integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== + +hex-color-regex@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/hex-color-regex/-/hex-color-regex-1.1.0.tgz#4c06fccb4602fe2602b3c93df82d7e7dbf1a8a8e" + integrity sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ== + +history@^4.9.0: + version "4.10.1" + resolved "https://registry.yarnpkg.com/history/-/history-4.10.1.tgz#33371a65e3a83b267434e2b3f3b1b4c58aad4cf3" + integrity sha512-36nwAD620w12kuzPAsyINPWJqlNbij+hpK1k9XRloDtym8mxzGYl2c17LnV6IAGB2Dmg4tEa7G7DlawS0+qjew== + dependencies: + "@babel/runtime" "^7.1.2" + loose-envify "^1.2.0" + resolve-pathname "^3.0.0" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + value-equal "^1.0.1" + +hmac-drbg@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" + integrity sha1-0nRXAQJabHdabFRXk+1QL8DGSaE= + dependencies: + hash.js "^1.0.3" + minimalistic-assert "^1.0.0" + minimalistic-crypto-utils "^1.0.1" + +hoist-non-react-statics@^3.1.0: + version "3.3.2" + resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" + integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== + dependencies: + react-is "^16.7.0" + +hoopy@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/hoopy/-/hoopy-0.1.4.tgz#609207d661100033a9a9402ad3dea677381c1b1d" + integrity sha512-HRcs+2mr52W0K+x8RzcLzuPPmVIKMSv97RGHy0Ea9y/mpcaK+xTrjICA04KAHi4GRzxliNqNJEFYWHghy3rSfQ== + +hosted-git-info@^2.1.4: + version "2.8.8" + resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.8.tgz#7539bd4bc1e0e0a895815a2e0262420b12858488" + integrity sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg== + +hpack.js@^2.1.6: + version "2.1.6" + resolved "https://registry.yarnpkg.com/hpack.js/-/hpack.js-2.1.6.tgz#87774c0949e513f42e84575b3c45681fade2a0b2" + integrity sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI= + dependencies: + inherits "^2.0.1" + obuf "^1.0.0" + readable-stream "^2.0.1" + wbuf "^1.1.0" + +hsl-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/hsl-regex/-/hsl-regex-1.0.0.tgz#d49330c789ed819e276a4c0d272dffa30b18fe6e" + integrity sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4= + +hsla-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/hsla-regex/-/hsla-regex-1.0.0.tgz#c1ce7a3168c8c6614033a4b5f7877f3b225f9c38" + integrity sha1-wc56MWjIxmFAM6S194d/OyJfnDg= + +html-comment-regex@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/html-comment-regex/-/html-comment-regex-1.1.2.tgz#97d4688aeb5c81886a364faa0cad1dda14d433a7" + integrity sha512-P+M65QY2JQ5Y0G9KKdlDpo0zK+/OHptU5AaBwUfAIDJZk1MYf32Frm84EcOytfJE0t5JvkAnKlmjsXDnWzCJmQ== + +html-encoding-sniffer@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz#42a6dc4fd33f00281176e8b23759ca4e4fa185f3" + integrity sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ== + dependencies: + whatwg-encoding "^1.0.5" + +html-entities@^1.2.1, html-entities@^1.3.1: + version "1.4.0" + resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-1.4.0.tgz#cfbd1b01d2afaf9adca1b10ae7dffab98c71d2dc" + integrity sha512-8nxjcBcd8wovbeKx7h3wTji4e6+rhaVuPNpMqwWgnHh+N9ToqsCs6XztWRBPQ+UtzsoMAdKZtUENoVzU/EMtZA== + +html-escaper@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" + integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== + +html-minifier-terser@^5.0.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-5.1.1.tgz#922e96f1f3bb60832c2634b79884096389b1f054" + integrity sha512-ZPr5MNObqnV/T9akshPKbVgyOqLmy+Bxo7juKCfTfnjNniTAMdy4hz21YQqoofMBJD2kdREaqPPdThoR78Tgxg== + dependencies: + camel-case "^4.1.1" + clean-css "^4.2.3" + commander "^4.1.1" + he "^1.2.0" + param-case "^3.0.3" + relateurl "^0.2.7" + terser "^4.6.3" + +html-webpack-plugin@4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-4.5.0.tgz#625097650886b97ea5dae331c320e3238f6c121c" + integrity sha512-MouoXEYSjTzCrjIxWwg8gxL5fE2X2WZJLmBYXlaJhQUH5K/b5OrqmV7T4dB7iu0xkmJ6JlUuV6fFVtnqbPopZw== + dependencies: + "@types/html-minifier-terser" "^5.0.0" + "@types/tapable" "^1.0.5" + "@types/webpack" "^4.41.8" + html-minifier-terser "^5.0.1" + loader-utils "^1.2.3" + lodash "^4.17.15" + pretty-error "^2.1.1" + tapable "^1.1.3" + util.promisify "1.0.0" + +htmlparser2@^3.10.1: + version "3.10.1" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-3.10.1.tgz#bd679dc3f59897b6a34bb10749c855bb53a9392f" + integrity sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ== + dependencies: + domelementtype "^1.3.1" + domhandler "^2.3.0" + domutils "^1.5.1" + entities "^1.1.1" + inherits "^2.0.1" + readable-stream "^3.1.1" + +http-deceiver@^1.2.7: + version "1.2.7" + resolved "https://registry.yarnpkg.com/http-deceiver/-/http-deceiver-1.2.7.tgz#fa7168944ab9a519d337cb0bec7284dc3e723d87" + integrity sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc= + +http-errors@1.7.2: + version "1.7.2" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.2.tgz#4f5029cf13239f31036e5b2e55292bcfbcc85c8f" + integrity sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg== + dependencies: + depd "~1.1.2" + inherits "2.0.3" + setprototypeof "1.1.1" + statuses ">= 1.5.0 < 2" + toidentifier "1.0.0" + +http-errors@~1.6.2: + version "1.6.3" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" + integrity sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0= + dependencies: + depd "~1.1.2" + inherits "2.0.3" + setprototypeof "1.1.0" + statuses ">= 1.4.0 < 2" + +http-errors@~1.7.2: + version "1.7.3" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" + integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== + dependencies: + depd "~1.1.2" + inherits "2.0.4" + setprototypeof "1.1.1" + statuses ">= 1.5.0 < 2" + toidentifier "1.0.0" + +http-parser-js@>=0.5.1: + version "0.5.3" + resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.3.tgz#01d2709c79d41698bb01d4decc5e9da4e4a033d9" + integrity sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg== + +http-proxy-middleware@0.19.1: + version "0.19.1" + resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz#183c7dc4aa1479150306498c210cdaf96080a43a" + integrity sha512-yHYTgWMQO8VvwNS22eLLloAkvungsKdKTLO8AJlftYIKNfJr3GK3zK0ZCfzDDGUBttdGc8xFy1mCitvNKQtC3Q== + dependencies: + http-proxy "^1.17.0" + is-glob "^4.0.0" + lodash "^4.17.11" + micromatch "^3.1.10" + +http-proxy@^1.17.0: + version "1.18.1" + resolved "https://registry.yarnpkg.com/http-proxy/-/http-proxy-1.18.1.tgz#401541f0534884bbf95260334e72f88ee3976549" + integrity sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ== + dependencies: + eventemitter3 "^4.0.0" + follow-redirects "^1.0.0" + requires-port "^1.0.0" + +http-signature@~1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" + integrity sha1-muzZJRFHcvPZW2WmCruPfBj7rOE= + dependencies: + assert-plus "^1.0.0" + jsprim "^1.2.2" + sshpk "^1.7.0" + +https-browserify@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73" + integrity sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM= + +human-signals@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-1.1.1.tgz#c5b1cd14f50aeae09ab6c59fe63ba3395fe4dfa3" + integrity sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw== + +human-signals@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" + integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== + +iconv-lite@0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +iconv-lite@^0.6.2: + version "0.6.2" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.2.tgz#ce13d1875b0c3a674bd6a04b7f76b01b1b6ded01" + integrity sha512-2y91h5OpQlolefMPmUlivelittSWy0rP+oYVpn6A7GwVHNE8AWzoYOBNmlwks3LobaJxgHCYZAnyNo2GgpNRNQ== + dependencies: + safer-buffer ">= 2.1.2 < 3.0.0" + +icss-utils@^4.0.0, icss-utils@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-4.1.1.tgz#21170b53789ee27447c2f47dd683081403f9a467" + integrity sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA== + dependencies: + postcss "^7.0.14" + +identity-obj-proxy@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/identity-obj-proxy/-/identity-obj-proxy-3.0.0.tgz#94d2bda96084453ef36fbc5aaec37e0f79f1fc14" + integrity sha1-lNK9qWCERT7zb7xarsN+D3nx/BQ= + dependencies: + harmony-reflect "^1.4.6" + +ieee754@^1.1.4: + version "1.2.1" + resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" + integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== + +iferr@^0.1.5: + version "0.1.5" + resolved "https://registry.yarnpkg.com/iferr/-/iferr-0.1.5.tgz#c60eed69e6d8fdb6b3104a1fcbca1c192dc5b501" + integrity sha1-xg7taebY/bazEEofy8ocGS3FtQE= + +ignore@^4.0.6: + version "4.0.6" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" + integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== + +ignore@^5.1.4: + version "5.1.8" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.8.tgz#f150a8b50a34289b33e22f5889abd4d8016f0e57" + integrity sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw== + +immer@8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/immer/-/immer-8.0.1.tgz#9c73db683e2b3975c424fb0572af5889877ae656" + integrity sha512-aqXhGP7//Gui2+UrEtvxZxSquQVXTpZ7KDxfCcKAF3Vysvw0CViVaW9RZ1j1xlIYqaaaipBoqdqeibkc18PNvA== + +import-cwd@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/import-cwd/-/import-cwd-2.1.0.tgz#aa6cf36e722761285cb371ec6519f53e2435b0a9" + integrity sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk= + dependencies: + import-from "^2.1.0" + +import-fresh@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-2.0.0.tgz#d81355c15612d386c61f9ddd3922d4304822a546" + integrity sha1-2BNVwVYS04bGH53dOSLUMEgipUY= + dependencies: + caller-path "^2.0.0" + resolve-from "^3.0.0" + +import-fresh@^3.0.0, import-fresh@^3.1.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +import-from@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/import-from/-/import-from-2.1.0.tgz#335db7f2a7affd53aaa471d4b8021dee36b7f3b1" + integrity sha1-M1238qev/VOqpHHUuAId7ja387E= + dependencies: + resolve-from "^3.0.0" + +import-local@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/import-local/-/import-local-2.0.0.tgz#55070be38a5993cf18ef6db7e961f5bee5c5a09d" + integrity sha512-b6s04m3O+s3CGSbqDIyP4R6aAwAeYlVq9+WUWep6iHa8ETRf9yei1U48C5MmfJmV9AiLYYBKPMq/W+/WRpQmCQ== + dependencies: + pkg-dir "^3.0.0" + resolve-cwd "^2.0.0" + +import-local@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/import-local/-/import-local-3.0.2.tgz#a8cfd0431d1de4a2199703d003e3e62364fa6db6" + integrity sha512-vjL3+w0oulAVZ0hBHnxa/Nm5TAurf9YLQJDhqRZyqb+VKGOB6LU8t9H1Nr5CIo16vh9XfJTOoHwU0B71S557gA== + dependencies: + pkg-dir "^4.2.0" + resolve-cwd "^3.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= + +indent-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" + integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== + +indexes-of@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/indexes-of/-/indexes-of-1.0.1.tgz#f30f716c8e2bd346c7b67d3df3915566a7c05607" + integrity sha1-8w9xbI4r00bHtn0985FVZqfAVgc= + +infer-owner@^1.0.3, infer-owner@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" + integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.1, inherits@~2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +inherits@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1" + integrity sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE= + +inherits@2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" + integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= + +ini@^1.3.5: + version "1.3.8" + resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" + integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== + +internal-ip@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/internal-ip/-/internal-ip-4.3.0.tgz#845452baad9d2ca3b69c635a137acb9a0dad0907" + integrity sha512-S1zBo1D6zcsyuC6PMmY5+55YMILQ9av8lotMx447Bq6SAgo/sDK6y6uUKmuYhW7eacnIhFfsPmCNYdDzsnnDCg== + dependencies: + default-gateway "^4.2.0" + ipaddr.js "^1.9.0" + +internal-slot@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" + integrity sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA== + dependencies: + get-intrinsic "^1.1.0" + has "^1.0.3" + side-channel "^1.0.4" + +interpret@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/interpret/-/interpret-2.2.0.tgz#1a78a0b5965c40a5416d007ad6f50ad27c417df9" + integrity sha512-Ju0Bz/cEia55xDwUWEa8+olFpCiQoypjnQySseKtmjNrnps3P+xfpUmGr90T7yjlVJmOtybRvPXhKMbHr+fWnw== + +ip-regex@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/ip-regex/-/ip-regex-2.1.0.tgz#fa78bf5d2e6913c911ce9f819ee5146bb6d844e9" + integrity sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk= + +ip@^1.1.0, ip@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/ip/-/ip-1.1.5.tgz#bdded70114290828c0a039e72ef25f5aaec4354a" + integrity sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo= + +ipaddr.js@1.9.1, ipaddr.js@^1.9.0: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +is-absolute-url@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-absolute-url/-/is-absolute-url-2.1.0.tgz#50530dfb84fcc9aa7dbe7852e83a37b93b9f2aa6" + integrity sha1-UFMN+4T8yap9vnhS6Do3uTufKqY= + +is-absolute-url@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-absolute-url/-/is-absolute-url-3.0.3.tgz#96c6a22b6a23929b11ea0afb1836c36ad4a5d698" + integrity sha512-opmNIX7uFnS96NtPmhWQgQx6/NYFgsUXYMllcfzwWKUMwfo8kku1TvE6hkNcH+Q1ts5cMVrsY7j0bxXQDciu9Q== + +is-accessor-descriptor@^0.1.6: + version "0.1.6" + resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz#a9e12cb3ae8d876727eeef3843f8a0897b5c98d6" + integrity sha1-qeEss66Nh2cn7u84Q/igiXtcmNY= + dependencies: + kind-of "^3.0.2" + +is-accessor-descriptor@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz#169c2f6d3df1f992618072365c9b0ea1f6878656" + integrity sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ== + dependencies: + kind-of "^6.0.0" + +is-arguments@^1.0.4: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.1.0.tgz#62353031dfbee07ceb34656a6bde59efecae8dd9" + integrity sha512-1Ij4lOMPl/xB5kBDn7I+b2ttPMKa8szhEIrXDuXQD/oe3HJLTLhqhgGspwgyGd6MOywBUqVvYicF72lkgDnIHg== + dependencies: + call-bind "^1.0.0" + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" + integrity sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0= + +is-arrayish@^0.3.1: + version "0.3.2" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.3.2.tgz#4574a2ae56f7ab206896fb431eaeed066fdf8f03" + integrity sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ== + +is-bigint@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.1.tgz#6923051dfcbc764278540b9ce0e6b3213aa5ebc2" + integrity sha512-J0ELF4yHFxHy0cmSxZuheDOz2luOdVvqjwmEcj8H/L1JHeuEDSDbeRP+Dk9kFVk5RTFzbucJ2Kb9F7ixY2QaCg== + +is-binary-path@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" + integrity sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg= + dependencies: + binary-extensions "^1.0.0" + +is-binary-path@~2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" + integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + dependencies: + binary-extensions "^2.0.0" + +is-boolean-object@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.0.tgz#e2aaad3a3a8fca34c28f6eee135b156ed2587ff0" + integrity sha512-a7Uprx8UtD+HWdyYwnD1+ExtTgqQtD2k/1yJgtXP6wnMm8byhkoTZRl+95LLThpzNZJ5aEvi46cdH+ayMFRwmA== + dependencies: + call-bind "^1.0.0" + +is-buffer@^1.1.5: + version "1.1.6" + resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" + integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w== + +is-callable@^1.1.4, is-callable@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.3.tgz#8b1e0500b73a1d76c70487636f368e519de8db8e" + integrity sha512-J1DcMe8UYTBSrKezuIUTUwjXsho29693unXM2YhJUTR2txK/eG47bvNa/wipPFmZFgr/N6f1GA66dv0mEyTIyQ== + +is-ci@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" + integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== + dependencies: + ci-info "^2.0.0" + +is-color-stop@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-color-stop/-/is-color-stop-1.1.0.tgz#cfff471aee4dd5c9e158598fbe12967b5cdad345" + integrity sha1-z/9HGu5N1cnhWFmPvhKWe1za00U= + dependencies: + css-color-names "^0.0.4" + hex-color-regex "^1.1.0" + hsl-regex "^1.0.0" + hsla-regex "^1.0.0" + rgb-regex "^1.0.1" + rgba-regex "^1.0.0" + +is-core-module@^2.0.0, is-core-module@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.2.0.tgz#97037ef3d52224d85163f5597b2b63d9afed981a" + integrity sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ== + dependencies: + has "^1.0.3" + +is-data-descriptor@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56" + integrity sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y= + dependencies: + kind-of "^3.0.2" + +is-data-descriptor@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz#d84876321d0e7add03990406abbbbd36ba9268c7" + integrity sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ== + dependencies: + kind-of "^6.0.0" + +is-date-object@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.2.tgz#bda736f2cd8fd06d32844e7743bfa7494c3bfd7e" + integrity sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g== + +is-descriptor@^0.1.0: + version "0.1.6" + resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz#366d8240dde487ca51823b1ab9f07a10a78251ca" + integrity sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg== + dependencies: + is-accessor-descriptor "^0.1.6" + is-data-descriptor "^0.1.4" + kind-of "^5.0.0" + +is-descriptor@^1.0.0, is-descriptor@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz#3b159746a66604b04f8c81524ba365c5f14d86ec" + integrity sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg== + dependencies: + is-accessor-descriptor "^1.0.0" + is-data-descriptor "^1.0.0" + kind-of "^6.0.2" + +is-directory@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/is-directory/-/is-directory-0.3.1.tgz#61339b6f2475fc772fd9c9d83f5c8575dc154ae1" + integrity sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE= + +is-docker@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.1.1.tgz#4125a88e44e450d384e09047ede71adc2d144156" + integrity sha512-ZOoqiXfEwtGknTiuDEy8pN2CfE3TxMHprvNer1mXiqwkOT77Rw3YVrUQ52EqAOU3QAWDQ+bQdx7HJzrv7LS2Hw== + +is-extendable@^0.1.0, is-extendable@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" + integrity sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik= + +is-extendable@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4" + integrity sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA== + dependencies: + is-plain-object "^2.0.4" + +is-extglob@^2.1.0, is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= + +is-fullwidth-code-point@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" + integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= + +is-fullwidth-code-point@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" + integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== + +is-generator-fn@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-generator-fn/-/is-generator-fn-2.1.0.tgz#7d140adc389aaf3011a8f2a2a4cfa6faadffb118" + integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== + +is-glob@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-3.1.0.tgz#7ba5ae24217804ac70707b96922567486cc3e84a" + integrity sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo= + dependencies: + is-extglob "^2.1.0" + +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@~4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" + integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== + dependencies: + is-extglob "^2.1.1" + +is-module@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-module/-/is-module-1.0.0.tgz#3258fb69f78c14d5b815d664336b4cffb6441591" + integrity sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE= + +is-negative-zero@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.1.tgz#3de746c18dda2319241a53675908d8f766f11c24" + integrity sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w== + +is-number-object@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.4.tgz#36ac95e741cf18b283fc1ddf5e83da798e3ec197" + integrity sha512-zohwelOAur+5uXtk8O3GPQ1eAcu4ZX3UwxQhUlfFFMNpUd83gXgjbhJh6HmB6LUNV/ieOLQuDwJO3dWJosUeMw== + +is-number@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" + integrity sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU= + dependencies: + kind-of "^3.0.2" + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-obj@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" + integrity sha1-PkcprB9f3gJc19g6iW2rn09n2w8= + +is-obj@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" + integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== + +is-path-cwd@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-2.2.0.tgz#67d43b82664a7b5191fd9119127eb300048a9fdb" + integrity sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ== + +is-path-in-cwd@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz#bfe2dca26c69f397265a4009963602935a053acb" + integrity sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ== + dependencies: + is-path-inside "^2.1.0" + +is-path-inside@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-2.1.0.tgz#7c9810587d659a40d27bcdb4d5616eab059494b2" + integrity sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg== + dependencies: + path-is-inside "^1.0.2" + +is-plain-obj@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e" + integrity sha1-caUMhCnfync8kqOQpKA7OfzVHT4= + +is-plain-object@^2.0.3, is-plain-object@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" + integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== + dependencies: + isobject "^3.0.1" + +is-potential-custom-element-name@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.0.tgz#0c52e54bcca391bb2c494b21e8626d7336c6e397" + integrity sha1-DFLlS8yjkbssSUsh6GJtczbG45c= + +is-regex@^1.0.4, is-regex@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.2.tgz#81c8ebde4db142f2cf1c53fc86d6a45788266251" + integrity sha512-axvdhb5pdhEVThqJzYXwMlVuZwC+FF2DpcOhTS+y/8jVq4trxyPgfcwIxIKiyeuLlSQYKkmUaPQJ8ZE4yNKXDg== + dependencies: + call-bind "^1.0.2" + has-symbols "^1.0.1" + +is-regexp@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz#fd2d883545c46bac5a633e7b9a09e87fa2cb5069" + integrity sha1-/S2INUXEa6xaYz57mgnof6LLUGk= + +is-resolvable@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz#fb18f87ce1feb925169c9a407c19318a3206ed88" + integrity sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg== + +is-root@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-root/-/is-root-2.1.0.tgz#809e18129cf1129644302a4f8544035d51984a9c" + integrity sha512-AGOriNp96vNBd3HtU+RzFEc75FfR5ymiYv8E553I71SCeXBiMsVDUtdio1OEFvrPyLIQ9tVR5RxXIFe5PUFjMg== + +is-stream@^1.0.1, is-stream@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" + integrity sha1-EtSj3U5o4Lec6428hBc66A2RykQ= + +is-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.0.tgz#bde9c32680d6fae04129d6ac9d921ce7815f78e3" + integrity sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw== + +is-string@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.5.tgz#40493ed198ef3ff477b8c7f92f644ec82a5cd3a6" + integrity sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ== + +is-svg@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-svg/-/is-svg-3.0.0.tgz#9321dbd29c212e5ca99c4fa9794c714bcafa2f75" + integrity sha512-gi4iHK53LR2ujhLVVj+37Ykh9GLqYHX6JOVXbLAucaG/Cqw9xwdFOjDM2qeifLs1sF1npXXFvDu0r5HNgCMrzQ== + dependencies: + html-comment-regex "^1.1.0" + +is-symbol@^1.0.2, is-symbol@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz#38e1014b9e6329be0de9d24a414fd7441ec61937" + integrity sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ== + dependencies: + has-symbols "^1.0.1" + +is-typedarray@^1.0.0, is-typedarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" + integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo= + +is-windows@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz#d1850eb9791ecd18e6182ce12a30f396634bb19d" + integrity sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA== + +is-wsl@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-1.1.0.tgz#1f16e4aa22b04d1336b66188a66af3c600c3a66d" + integrity sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0= + +is-wsl@^2.1.1, is-wsl@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" + integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== + dependencies: + is-docker "^2.0.0" + +isarray@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" + integrity sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8= + +isarray@1.0.0, isarray@^1.0.0, isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" + integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= + +isobject@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" + integrity sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk= + dependencies: + isarray "1.0.0" + +isobject@^3.0.0, isobject@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" + integrity sha1-TkMekrEalzFjaqH5yNHMvP2reN8= + +isstream@~0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" + integrity sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo= + +istanbul-lib-coverage@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz#f5944a37c70b550b02a78a5c3b2055b280cec8ec" + integrity sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg== + +istanbul-lib-instrument@^4.0.0, istanbul-lib-instrument@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz#873c6fff897450118222774696a3f28902d77c1d" + integrity sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ== + dependencies: + "@babel/core" "^7.7.5" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-coverage "^3.0.0" + semver "^6.3.0" + +istanbul-lib-report@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#7518fe52ea44de372f460a76b5ecda9ffb73d8a6" + integrity sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw== + dependencies: + istanbul-lib-coverage "^3.0.0" + make-dir "^3.0.0" + supports-color "^7.1.0" + +istanbul-lib-source-maps@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz#75743ce6d96bb86dc7ee4352cf6366a23f0b1ad9" + integrity sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg== + dependencies: + debug "^4.1.1" + istanbul-lib-coverage "^3.0.0" + source-map "^0.6.1" + +istanbul-reports@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/istanbul-reports/-/istanbul-reports-3.0.2.tgz#d593210e5000683750cb09fc0644e4b6e27fd53b" + integrity sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw== + dependencies: + html-escaper "^2.0.0" + istanbul-lib-report "^3.0.0" + +jest-changed-files@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-26.6.2.tgz#f6198479e1cc66f22f9ae1e22acaa0b429c042d0" + integrity sha512-fDS7szLcY9sCtIip8Fjry9oGf3I2ht/QT21bAHm5Dmf0mD4X3ReNUf17y+bO6fR8WgbIZTlbyG1ak/53cbRzKQ== + dependencies: + "@jest/types" "^26.6.2" + execa "^4.0.0" + throat "^5.0.0" + +jest-circus@26.6.0: + version "26.6.0" + resolved "https://registry.yarnpkg.com/jest-circus/-/jest-circus-26.6.0.tgz#7d9647b2e7f921181869faae1f90a2629fd70705" + integrity sha512-L2/Y9szN6FJPWFK8kzWXwfp+FOR7xq0cUL4lIsdbIdwz3Vh6P1nrpcqOleSzr28zOtSHQNV9Z7Tl+KkuK7t5Ng== + dependencies: + "@babel/traverse" "^7.1.0" + "@jest/environment" "^26.6.0" + "@jest/test-result" "^26.6.0" + "@jest/types" "^26.6.0" + "@types/babel__traverse" "^7.0.4" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + dedent "^0.7.0" + expect "^26.6.0" + is-generator-fn "^2.0.0" + jest-each "^26.6.0" + jest-matcher-utils "^26.6.0" + jest-message-util "^26.6.0" + jest-runner "^26.6.0" + jest-runtime "^26.6.0" + jest-snapshot "^26.6.0" + jest-util "^26.6.0" + pretty-format "^26.6.0" + stack-utils "^2.0.2" + throat "^5.0.0" + +jest-cli@^26.6.0: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-26.6.3.tgz#43117cfef24bc4cd691a174a8796a532e135e92a" + integrity sha512-GF9noBSa9t08pSyl3CY4frMrqp+aQXFGFkf5hEPbh/pIUFYWMK6ZLTfbmadxJVcJrdRoChlWQsA2VkJcDFK8hg== + dependencies: + "@jest/core" "^26.6.3" + "@jest/test-result" "^26.6.2" + "@jest/types" "^26.6.2" + chalk "^4.0.0" + exit "^0.1.2" + graceful-fs "^4.2.4" + import-local "^3.0.2" + is-ci "^2.0.0" + jest-config "^26.6.3" + jest-util "^26.6.2" + jest-validate "^26.6.2" + prompts "^2.0.1" + yargs "^15.4.1" + +jest-config@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-26.6.3.tgz#64f41444eef9eb03dc51d5c53b75c8c71f645349" + integrity sha512-t5qdIj/bCj2j7NFVHb2nFB4aUdfucDn3JRKgrZnplb8nieAirAzRSHP8uDEd+qV6ygzg9Pz4YG7UTJf94LPSyg== + dependencies: + "@babel/core" "^7.1.0" + "@jest/test-sequencer" "^26.6.3" + "@jest/types" "^26.6.2" + babel-jest "^26.6.3" + chalk "^4.0.0" + deepmerge "^4.2.2" + glob "^7.1.1" + graceful-fs "^4.2.4" + jest-environment-jsdom "^26.6.2" + jest-environment-node "^26.6.2" + jest-get-type "^26.3.0" + jest-jasmine2 "^26.6.3" + jest-regex-util "^26.0.0" + jest-resolve "^26.6.2" + jest-util "^26.6.2" + jest-validate "^26.6.2" + micromatch "^4.0.2" + pretty-format "^26.6.2" + +jest-diff@^26.0.0, jest-diff@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-26.6.2.tgz#1aa7468b52c3a68d7d5c5fdcdfcd5e49bd164394" + integrity sha512-6m+9Z3Gv9wN0WFVasqjCL/06+EFCMTqDEUl/b87HYK2rAPTyfz4ZIuSlPhY51PIQRWx5TaxeF1qmXKe9gfN3sA== + dependencies: + chalk "^4.0.0" + diff-sequences "^26.6.2" + jest-get-type "^26.3.0" + pretty-format "^26.6.2" + +jest-docblock@^26.0.0: + version "26.0.0" + resolved "https://registry.yarnpkg.com/jest-docblock/-/jest-docblock-26.0.0.tgz#3e2fa20899fc928cb13bd0ff68bd3711a36889b5" + integrity sha512-RDZ4Iz3QbtRWycd8bUEPxQsTlYazfYn/h5R65Fc6gOfwozFhoImx+affzky/FFBuqISPTqjXomoIGJVKBWoo0w== + dependencies: + detect-newline "^3.0.0" + +jest-each@^26.6.0, jest-each@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-each/-/jest-each-26.6.2.tgz#02526438a77a67401c8a6382dfe5999952c167cb" + integrity sha512-Mer/f0KaATbjl8MCJ+0GEpNdqmnVmDYqCTJYTvoo7rqmRiDllmp2AYN+06F93nXcY3ur9ShIjS+CO/uD+BbH4A== + dependencies: + "@jest/types" "^26.6.2" + chalk "^4.0.0" + jest-get-type "^26.3.0" + jest-util "^26.6.2" + pretty-format "^26.6.2" + +jest-environment-jsdom@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-26.6.2.tgz#78d09fe9cf019a357009b9b7e1f101d23bd1da3e" + integrity sha512-jgPqCruTlt3Kwqg5/WVFyHIOJHsiAvhcp2qiR2QQstuG9yWox5+iHpU3ZrcBxW14T4fe5Z68jAfLRh7joCSP2Q== + dependencies: + "@jest/environment" "^26.6.2" + "@jest/fake-timers" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + jest-mock "^26.6.2" + jest-util "^26.6.2" + jsdom "^16.4.0" + +jest-environment-node@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-26.6.2.tgz#824e4c7fb4944646356f11ac75b229b0035f2b0c" + integrity sha512-zhtMio3Exty18dy8ee8eJ9kjnRyZC1N4C1Nt/VShN1apyXc8rWGtJ9lI7vqiWcyyXS4BVSEn9lxAM2D+07/Tag== + dependencies: + "@jest/environment" "^26.6.2" + "@jest/fake-timers" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + jest-mock "^26.6.2" + jest-util "^26.6.2" + +jest-get-type@^26.3.0: + version "26.3.0" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-26.3.0.tgz#e97dc3c3f53c2b406ca7afaed4493b1d099199e0" + integrity sha512-TpfaviN1R2pQWkIihlfEanwOXK0zcxrKEE4MlU6Tn7keoXdN6/3gK/xl0yEh8DOunn5pOVGKf8hB4R9gVh04ig== + +jest-haste-map@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-26.6.2.tgz#dd7e60fe7dc0e9f911a23d79c5ff7fb5c2cafeaa" + integrity sha512-easWIJXIw71B2RdR8kgqpjQrbMRWQBgiBwXYEhtGUTaX+doCjBheluShdDMeR8IMfJiTqH4+zfhtg29apJf/8w== + dependencies: + "@jest/types" "^26.6.2" + "@types/graceful-fs" "^4.1.2" + "@types/node" "*" + anymatch "^3.0.3" + fb-watchman "^2.0.0" + graceful-fs "^4.2.4" + jest-regex-util "^26.0.0" + jest-serializer "^26.6.2" + jest-util "^26.6.2" + jest-worker "^26.6.2" + micromatch "^4.0.2" + sane "^4.0.3" + walker "^1.0.7" + optionalDependencies: + fsevents "^2.1.2" + +jest-jasmine2@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-26.6.3.tgz#adc3cf915deacb5212c93b9f3547cd12958f2edd" + integrity sha512-kPKUrQtc8aYwBV7CqBg5pu+tmYXlvFlSFYn18ev4gPFtrRzB15N2gW/Roew3187q2w2eHuu0MU9TJz6w0/nPEg== + dependencies: + "@babel/traverse" "^7.1.0" + "@jest/environment" "^26.6.2" + "@jest/source-map" "^26.6.2" + "@jest/test-result" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + expect "^26.6.2" + is-generator-fn "^2.0.0" + jest-each "^26.6.2" + jest-matcher-utils "^26.6.2" + jest-message-util "^26.6.2" + jest-runtime "^26.6.3" + jest-snapshot "^26.6.2" + jest-util "^26.6.2" + pretty-format "^26.6.2" + throat "^5.0.0" + +jest-leak-detector@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-leak-detector/-/jest-leak-detector-26.6.2.tgz#7717cf118b92238f2eba65054c8a0c9c653a91af" + integrity sha512-i4xlXpsVSMeKvg2cEKdfhh0H39qlJlP5Ex1yQxwF9ubahboQYMgTtz5oML35AVA3B4Eu+YsmwaiKVev9KCvLxg== + dependencies: + jest-get-type "^26.3.0" + pretty-format "^26.6.2" + +jest-matcher-utils@^26.6.0, jest-matcher-utils@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-26.6.2.tgz#8e6fd6e863c8b2d31ac6472eeb237bc595e53e7a" + integrity sha512-llnc8vQgYcNqDrqRDXWwMr9i7rS5XFiCwvh6DTP7Jqa2mqpcCBBlpCbn+trkG0KNhPu/h8rzyBkriOtBstvWhw== + dependencies: + chalk "^4.0.0" + jest-diff "^26.6.2" + jest-get-type "^26.3.0" + pretty-format "^26.6.2" + +jest-message-util@^26.6.0, jest-message-util@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07" + integrity sha512-rGiLePzQ3AzwUshu2+Rn+UMFk0pHN58sOG+IaJbk5Jxuqo3NYO1U2/MIR4S1sKgsoYSXSzdtSa0TgrmtUwEbmA== + dependencies: + "@babel/code-frame" "^7.0.0" + "@jest/types" "^26.6.2" + "@types/stack-utils" "^2.0.0" + chalk "^4.0.0" + graceful-fs "^4.2.4" + micromatch "^4.0.2" + pretty-format "^26.6.2" + slash "^3.0.0" + stack-utils "^2.0.2" + +jest-mock@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302" + integrity sha512-YyFjePHHp1LzpzYcmgqkJ0nm0gg/lJx2aZFzFy1S6eUqNjXsOqTK10zNRff2dNfssgokjkG65OlWNcIlgd3zew== + dependencies: + "@jest/types" "^26.6.2" + "@types/node" "*" + +jest-pnp-resolver@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz#b704ac0ae028a89108a4d040b3f919dfddc8e33c" + integrity sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w== + +jest-regex-util@^26.0.0: + version "26.0.0" + resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-26.0.0.tgz#d25e7184b36e39fd466c3bc41be0971e821fee28" + integrity sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A== + +jest-resolve-dependencies@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-26.6.3.tgz#6680859ee5d22ee5dcd961fe4871f59f4c784fb6" + integrity sha512-pVwUjJkxbhe4RY8QEWzN3vns2kqyuldKpxlxJlzEYfKSvY6/bMvxoFrYYzUO1Gx28yKWN37qyV7rIoIp2h8fTg== + dependencies: + "@jest/types" "^26.6.2" + jest-regex-util "^26.0.0" + jest-snapshot "^26.6.2" + +jest-resolve@26.6.0: + version "26.6.0" + resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-26.6.0.tgz#070fe7159af87b03e50f52ea5e17ee95bbee40e1" + integrity sha512-tRAz2bwraHufNp+CCmAD8ciyCpXCs1NQxB5EJAmtCFy6BN81loFEGWKzYu26Y62lAJJe4X4jg36Kf+NsQyiStQ== + dependencies: + "@jest/types" "^26.6.0" + chalk "^4.0.0" + graceful-fs "^4.2.4" + jest-pnp-resolver "^1.2.2" + jest-util "^26.6.0" + read-pkg-up "^7.0.1" + resolve "^1.17.0" + slash "^3.0.0" + +jest-resolve@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-26.6.2.tgz#a3ab1517217f469b504f1b56603c5bb541fbb507" + integrity sha512-sOxsZOq25mT1wRsfHcbtkInS+Ek7Q8jCHUB0ZUTP0tc/c41QHriU/NunqMfCUWsL4H3MHpvQD4QR9kSYhS7UvQ== + dependencies: + "@jest/types" "^26.6.2" + chalk "^4.0.0" + graceful-fs "^4.2.4" + jest-pnp-resolver "^1.2.2" + jest-util "^26.6.2" + read-pkg-up "^7.0.1" + resolve "^1.18.1" + slash "^3.0.0" + +jest-runner@^26.6.0, jest-runner@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-26.6.3.tgz#2d1fed3d46e10f233fd1dbd3bfaa3fe8924be159" + integrity sha512-atgKpRHnaA2OvByG/HpGA4g6CSPS/1LK0jK3gATJAoptC1ojltpmVlYC3TYgdmGp+GLuhzpH30Gvs36szSL2JQ== + dependencies: + "@jest/console" "^26.6.2" + "@jest/environment" "^26.6.2" + "@jest/test-result" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + chalk "^4.0.0" + emittery "^0.7.1" + exit "^0.1.2" + graceful-fs "^4.2.4" + jest-config "^26.6.3" + jest-docblock "^26.0.0" + jest-haste-map "^26.6.2" + jest-leak-detector "^26.6.2" + jest-message-util "^26.6.2" + jest-resolve "^26.6.2" + jest-runtime "^26.6.3" + jest-util "^26.6.2" + jest-worker "^26.6.2" + source-map-support "^0.5.6" + throat "^5.0.0" + +jest-runtime@^26.6.0, jest-runtime@^26.6.3: + version "26.6.3" + resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-26.6.3.tgz#4f64efbcfac398331b74b4b3c82d27d401b8fa2b" + integrity sha512-lrzyR3N8sacTAMeonbqpnSka1dHNux2uk0qqDXVkMv2c/A3wYnvQ4EXuI013Y6+gSKSCxdaczvf4HF0mVXHRdw== + dependencies: + "@jest/console" "^26.6.2" + "@jest/environment" "^26.6.2" + "@jest/fake-timers" "^26.6.2" + "@jest/globals" "^26.6.2" + "@jest/source-map" "^26.6.2" + "@jest/test-result" "^26.6.2" + "@jest/transform" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/yargs" "^15.0.0" + chalk "^4.0.0" + cjs-module-lexer "^0.6.0" + collect-v8-coverage "^1.0.0" + exit "^0.1.2" + glob "^7.1.3" + graceful-fs "^4.2.4" + jest-config "^26.6.3" + jest-haste-map "^26.6.2" + jest-message-util "^26.6.2" + jest-mock "^26.6.2" + jest-regex-util "^26.0.0" + jest-resolve "^26.6.2" + jest-snapshot "^26.6.2" + jest-util "^26.6.2" + jest-validate "^26.6.2" + slash "^3.0.0" + strip-bom "^4.0.0" + yargs "^15.4.1" + +jest-serializer@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-serializer/-/jest-serializer-26.6.2.tgz#d139aafd46957d3a448f3a6cdabe2919ba0742d1" + integrity sha512-S5wqyz0DXnNJPd/xfIzZ5Xnp1HrJWBczg8mMfMpN78OJ5eDxXyf+Ygld9wX1DnUWbIbhM1YDY95NjR4CBXkb2g== + dependencies: + "@types/node" "*" + graceful-fs "^4.2.4" + +jest-snapshot@^26.6.0, jest-snapshot@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-26.6.2.tgz#f3b0af1acb223316850bd14e1beea9837fb39c84" + integrity sha512-OLhxz05EzUtsAmOMzuupt1lHYXCNib0ECyuZ/PZOx9TrZcC8vL0x+DUG3TL+GLX3yHG45e6YGjIm0XwDc3q3og== + dependencies: + "@babel/types" "^7.0.0" + "@jest/types" "^26.6.2" + "@types/babel__traverse" "^7.0.4" + "@types/prettier" "^2.0.0" + chalk "^4.0.0" + expect "^26.6.2" + graceful-fs "^4.2.4" + jest-diff "^26.6.2" + jest-get-type "^26.3.0" + jest-haste-map "^26.6.2" + jest-matcher-utils "^26.6.2" + jest-message-util "^26.6.2" + jest-resolve "^26.6.2" + natural-compare "^1.4.0" + pretty-format "^26.6.2" + semver "^7.3.2" + +jest-util@^26.6.0, jest-util@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1" + integrity sha512-MDW0fKfsn0OI7MS7Euz6h8HNDXVQ0gaM9uW6RjfDmd1DAFcaxX9OqIakHIqhbnmF08Cf2DLDG+ulq8YQQ0Lp0Q== + dependencies: + "@jest/types" "^26.6.2" + "@types/node" "*" + chalk "^4.0.0" + graceful-fs "^4.2.4" + is-ci "^2.0.0" + micromatch "^4.0.2" + +jest-validate@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-26.6.2.tgz#23d380971587150467342911c3d7b4ac57ab20ec" + integrity sha512-NEYZ9Aeyj0i5rQqbq+tpIOom0YS1u2MVu6+euBsvpgIme+FOfRmoC4R5p0JiAUpaFvFy24xgrpMknarR/93XjQ== + dependencies: + "@jest/types" "^26.6.2" + camelcase "^6.0.0" + chalk "^4.0.0" + jest-get-type "^26.3.0" + leven "^3.1.0" + pretty-format "^26.6.2" + +jest-watch-typeahead@0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/jest-watch-typeahead/-/jest-watch-typeahead-0.6.1.tgz#45221b86bb6710b7e97baaa1640ae24a07785e63" + integrity sha512-ITVnHhj3Jd/QkqQcTqZfRgjfyRhDFM/auzgVo2RKvSwi18YMvh0WvXDJFoFED6c7jd/5jxtu4kSOb9PTu2cPVg== + dependencies: + ansi-escapes "^4.3.1" + chalk "^4.0.0" + jest-regex-util "^26.0.0" + jest-watcher "^26.3.0" + slash "^3.0.0" + string-length "^4.0.1" + strip-ansi "^6.0.0" + +jest-watcher@^26.3.0, jest-watcher@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-26.6.2.tgz#a5b683b8f9d68dbcb1d7dae32172d2cca0592975" + integrity sha512-WKJob0P/Em2csiVthsI68p6aGKTIcsfjH9Gsx1f0A3Italz43e3ho0geSAVsmj09RWOELP1AZ/DXyJgOgDKxXQ== + dependencies: + "@jest/test-result" "^26.6.2" + "@jest/types" "^26.6.2" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + jest-util "^26.6.2" + string-length "^4.0.1" + +jest-worker@^24.9.0: + version "24.9.0" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-24.9.0.tgz#5dbfdb5b2d322e98567898238a9697bcce67b3e5" + integrity sha512-51PE4haMSXcHohnSMdM42anbvZANYTqMrr52tVKPqqsPJMzoP6FYYDVqahX/HrAoKEKz3uUPzSvKs9A3qR4iVw== + dependencies: + merge-stream "^2.0.0" + supports-color "^6.1.0" + +jest-worker@^26.5.0, jest-worker@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-26.6.2.tgz#7f72cbc4d643c365e27b9fd775f9d0eaa9c7a8ed" + integrity sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^7.0.0" + +jest@26.6.0: + version "26.6.0" + resolved "https://registry.yarnpkg.com/jest/-/jest-26.6.0.tgz#546b25a1d8c888569dbbe93cae131748086a4a25" + integrity sha512-jxTmrvuecVISvKFFhOkjsWRZV7sFqdSUAd1ajOKY+/QE/aLBVstsJ/dX8GczLzwiT6ZEwwmZqtCUHLHHQVzcfA== + dependencies: + "@jest/core" "^26.6.0" + import-local "^3.0.2" + jest-cli "^26.6.0" + +"js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@^3.13.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537" + integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g== + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +jsbn@~0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" + integrity sha1-peZUwuWi3rXyAdls77yoDA7y9RM= + +jsdom@^16.4.0: + version "16.5.2" + resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.5.2.tgz#583fac89a0aea31dbf6237e7e4bedccd9beab472" + integrity sha512-JxNtPt9C1ut85boCbJmffaQ06NBnzkQY/MWO3YxPW8IWS38A26z+B1oBvA9LwKrytewdfymnhi4UNH3/RAgZrg== + dependencies: + abab "^2.0.5" + acorn "^8.1.0" + acorn-globals "^6.0.0" + cssom "^0.4.4" + cssstyle "^2.3.0" + data-urls "^2.0.0" + decimal.js "^10.2.1" + domexception "^2.0.1" + escodegen "^2.0.0" + html-encoding-sniffer "^2.0.1" + is-potential-custom-element-name "^1.0.0" + nwsapi "^2.2.0" + parse5 "6.0.1" + request "^2.88.2" + request-promise-native "^1.0.9" + saxes "^5.0.1" + symbol-tree "^3.2.4" + tough-cookie "^4.0.0" + w3c-hr-time "^1.0.2" + w3c-xmlserializer "^2.0.0" + webidl-conversions "^6.1.0" + whatwg-encoding "^1.0.5" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.5.0" + ws "^7.4.4" + xml-name-validator "^3.0.0" + +jsesc@^2.5.1: + version "2.5.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" + integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== + +jsesc@~0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" + integrity sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0= + +json-parse-better-errors@^1.0.1, json-parse-better-errors@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9" + integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw== + +json-parse-even-better-errors@^2.3.0: + version "2.3.1" + resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" + integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== + +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-schema-traverse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" + integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== + +json-schema@0.2.3: + version "0.2.3" + resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13" + integrity sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM= + +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= + +json-stringify-safe@~5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" + integrity sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus= + +json3@^3.3.3: + version "3.3.3" + resolved "https://registry.yarnpkg.com/json3/-/json3-3.3.3.tgz#7fc10e375fc5ae42c4705a5cc0aa6f62be305b81" + integrity sha512-c7/8mbUsKigAbLkD5B010BK4D9LZm7A1pNItkEwiUZRpIN66exu/e7YQWysGun+TRKaJp8MhemM+VkfWv42aCA== + +json5@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" + integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== + dependencies: + minimist "^1.2.0" + +json5@^2.1.2: + version "2.2.0" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.0.tgz#2dfefe720c6ba525d9ebd909950f0515316c89a3" + integrity sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA== + dependencies: + minimist "^1.2.5" + +jsonfile@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" + integrity sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss= + optionalDependencies: + graceful-fs "^4.1.6" + +jsonfile@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" + integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== + dependencies: + universalify "^2.0.0" + optionalDependencies: + graceful-fs "^4.1.6" + +jsprim@^1.2.2: + version "1.4.1" + resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.1.tgz#313e66bc1e5cc06e438bc1b7499c2e5c56acb6a2" + integrity sha1-MT5mvB5cwG5Di8G3SZwuXFastqI= + dependencies: + assert-plus "1.0.0" + extsprintf "1.3.0" + json-schema "0.2.3" + verror "1.10.0" + +"jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.1.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-3.2.0.tgz#41108d2cec408c3453c1bbe8a4aae9e1e2bd8f82" + integrity sha512-EIsmt3O3ljsU6sot/J4E1zDRxfBNrhjyf/OKjlydwgEimQuznlM4Wv7U+ueONJMyEn1WRE0K8dhi3dVAXYT24Q== + dependencies: + array-includes "^3.1.2" + object.assign "^4.1.2" + +killable@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/killable/-/killable-1.0.1.tgz#4c8ce441187a061c7474fb87ca08e2a638194892" + integrity sha512-LzqtLKlUwirEUyl/nicirVmNiPvYs7l5n8wOPP7fyJVpUPkvCnW/vuiXGpylGUlnPDnB7311rARzAt3Mhswpjg== + +kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0: + version "3.2.2" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" + integrity sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ= + dependencies: + is-buffer "^1.1.5" + +kind-of@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" + integrity sha1-IIE989cSkosgc3hpGkUGb65y3Vc= + dependencies: + is-buffer "^1.1.5" + +kind-of@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz#729c91e2d857b7a419a1f9aa65685c4c33f5845d" + integrity sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw== + +kind-of@^6.0.0, kind-of@^6.0.2: + version "6.0.3" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" + integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== + +kleur@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/kleur/-/kleur-3.0.3.tgz#a79c9ecc86ee1ce3fa6206d1216c501f147fc07e" + integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== + +klona@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/klona/-/klona-2.0.4.tgz#7bb1e3affb0cb8624547ef7e8f6708ea2e39dfc0" + integrity sha512-ZRbnvdg/NxqzC7L9Uyqzf4psi1OM4Cuc+sJAkQPjO6XkQIJTNbfK2Rsmbw8fx1p2mkZdp2FZYo2+LwXYY/uwIA== + +language-subtag-registry@~0.3.2: + version "0.3.21" + resolved "https://registry.yarnpkg.com/language-subtag-registry/-/language-subtag-registry-0.3.21.tgz#04ac218bea46f04cb039084602c6da9e788dd45a" + integrity sha512-L0IqwlIXjilBVVYKFT37X9Ih11Um5NEl9cbJIuU/SwP/zEEAbBPOnEeeuxVMf45ydWQRDQN3Nqc96OgbH1K+Pg== + +language-tags@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/language-tags/-/language-tags-1.0.5.tgz#d321dbc4da30ba8bf3024e040fa5c14661f9193a" + integrity sha1-0yHbxNowuovzAk4ED6XBRmH5GTo= + dependencies: + language-subtag-registry "~0.3.2" + +last-call-webpack-plugin@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/last-call-webpack-plugin/-/last-call-webpack-plugin-3.0.0.tgz#9742df0e10e3cf46e5c0381c2de90d3a7a2d7555" + integrity sha512-7KI2l2GIZa9p2spzPIVZBYyNKkN+e/SQPpnjlTiPhdbDW3F86tdKKELxKpzJ5sgU19wQWsACULZmpTPYHeWO5w== + dependencies: + lodash "^4.17.5" + webpack-sources "^1.1.0" + +leven@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" + integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + +levn@~0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" + integrity sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4= + dependencies: + prelude-ls "~1.1.2" + type-check "~0.3.2" + +lines-and-columns@^1.1.6: + version "1.1.6" + resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.1.6.tgz#1c00c743b433cd0a4e80758f7b64a57440d9ff00" + integrity sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA= + +load-json-file@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-2.0.0.tgz#7947e42149af80d696cbf797bcaabcfe1fe29ca8" + integrity sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg= + dependencies: + graceful-fs "^4.1.2" + parse-json "^2.2.0" + pify "^2.0.0" + strip-bom "^3.0.0" + +loader-runner@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-2.4.0.tgz#ed47066bfe534d7e84c4c7b9998c2a75607d9357" + integrity sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw== + +loader-utils@1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.2.3.tgz#1ff5dc6911c9f0a062531a4c04b609406108c2c7" + integrity sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA== + dependencies: + big.js "^5.2.2" + emojis-list "^2.0.0" + json5 "^1.0.1" + +loader-utils@2.0.0, loader-utils@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.0.tgz#e4cace5b816d425a166b5f097e10cd12b36064b0" + integrity sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ== + dependencies: + big.js "^5.2.2" + emojis-list "^3.0.0" + json5 "^2.1.2" + +loader-utils@^1.1.0, loader-utils@^1.2.3, loader-utils@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.4.0.tgz#c579b5e34cb34b1a74edc6c1fb36bfa371d5a613" + integrity sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA== + dependencies: + big.js "^5.2.2" + emojis-list "^3.0.0" + json5 "^1.0.1" + +locate-path@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" + integrity sha1-K1aLJl7slExtnA3pw9u7ygNUzY4= + dependencies: + p-locate "^2.0.0" + path-exists "^3.0.0" + +locate-path@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" + integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== + dependencies: + p-locate "^3.0.0" + path-exists "^3.0.0" + +locate-path@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" + integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== + dependencies: + p-locate "^4.1.0" + +lodash._reinterpolate@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz#0ccf2d89166af03b3663c796538b75ac6e114d9d" + integrity sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0= + +lodash.clonedeep@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef" + integrity sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8= + +lodash.debounce@^4.0.8: + version "4.0.8" + resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" + integrity sha1-gteb/zCmfEAF/9XiUVMArZyk168= + +lodash.flatten@^4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/lodash.flatten/-/lodash.flatten-4.4.0.tgz#f31c22225a9632d2bbf8e4addbef240aa765a61f" + integrity sha1-8xwiIlqWMtK7+OSt2+8kCqdlph8= + +lodash.memoize@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" + integrity sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4= + +lodash.template@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/lodash.template/-/lodash.template-4.5.0.tgz#f976195cf3f347d0d5f52483569fe8031ccce8ab" + integrity sha512-84vYFxIkmidUiFxidA/KjjH9pAycqW+h980j7Fuz5qxRtO9pgB7MDFTdys1N7A5mcucRiDyEq4fusljItR1T/A== + dependencies: + lodash._reinterpolate "^3.0.0" + lodash.templatesettings "^4.0.0" + +lodash.templatesettings@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/lodash.templatesettings/-/lodash.templatesettings-4.2.0.tgz#e481310f049d3cf6d47e912ad09313b154f0fb33" + integrity sha512-stgLz+i3Aa9mZgnjr/O+v9ruKZsPsndy7qPZOchbqk2cnTU1ZaldKK+v7m54WoKIyxiuMZTKT2H81F8BeAc3ZQ== + dependencies: + lodash._reinterpolate "^3.0.0" + +lodash.truncate@^4.4.2: + version "4.4.2" + resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193" + integrity sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM= + +lodash.uniq@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" + integrity sha1-0CJTc662Uq3BvILklFM5qEJ1R3M= + +"lodash@>=3.5 <5", lodash@^4.17.11, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.5, lodash@^4.6.1, lodash@^4.7.0: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== + +loglevel@^1.6.8: + version "1.7.1" + resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.7.1.tgz#005fde2f5e6e47068f935ff28573e125ef72f197" + integrity sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw== + +loose-envify@^1.1.0, loose-envify@^1.2.0, loose-envify@^1.3.1, loose-envify@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" + integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== + dependencies: + js-tokens "^3.0.0 || ^4.0.0" + +lower-case@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" + integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== + dependencies: + tslib "^2.0.3" + +lru-cache@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" + integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== + dependencies: + yallist "^3.0.2" + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +lz-string@^1.4.4: + version "1.4.4" + resolved "https://registry.yarnpkg.com/lz-string/-/lz-string-1.4.4.tgz#c0d8eaf36059f705796e1e344811cf4c498d3a26" + integrity sha1-wNjq82BZ9wV5bh40SBHPTEmNOiY= + +magic-string@^0.25.0, magic-string@^0.25.7: + version "0.25.7" + resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.25.7.tgz#3f497d6fd34c669c6798dcb821f2ef31f5445051" + integrity sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA== + dependencies: + sourcemap-codec "^1.4.4" + +make-dir@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" + integrity sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA== + dependencies: + pify "^4.0.1" + semver "^5.6.0" + +make-dir@^3.0.0, make-dir@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" + integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== + dependencies: + semver "^6.0.0" + +makeerror@1.0.x: + version "1.0.11" + resolved "https://registry.yarnpkg.com/makeerror/-/makeerror-1.0.11.tgz#e01a5c9109f2af79660e4e8b9587790184f5a96c" + integrity sha1-4BpckQnyr3lmDk6LlYd5AYT1qWw= + dependencies: + tmpl "1.0.x" + +map-cache@^0.2.2: + version "0.2.2" + resolved "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz#c32abd0bd6525d9b051645bb4f26ac5dc98a0dbf" + integrity sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8= + +map-visit@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz#ecdca8f13144e660f1b5bd41f12f3479d98dfb8f" + integrity sha1-7Nyo8TFE5mDxtb1B8S80edmN+48= + dependencies: + object-visit "^1.0.0" + +md5.js@^1.3.4: + version "1.3.5" + resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" + integrity sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + +mdn-data@2.0.14: + version "2.0.14" + resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50" + integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow== + +mdn-data@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.4.tgz#699b3c38ac6f1d728091a64650b65d388502fd5b" + integrity sha512-iV3XNKw06j5Q7mi6h+9vbx23Tv7JkjEVgKHW4pimwyDGWm0OIQntJJ+u1C6mg6mK1EaTv42XQ7w76yuzH7M2cA== + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" + integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= + +memory-fs@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.4.1.tgz#3a9a20b8462523e447cfbc7e8bb80ed667bfc552" + integrity sha1-OpoguEYlI+RHz7x+i7gO1me/xVI= + dependencies: + errno "^0.1.3" + readable-stream "^2.0.1" + +memory-fs@^0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.5.0.tgz#324c01288b88652966d161db77838720845a8e3c" + integrity sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA== + dependencies: + errno "^0.1.3" + readable-stream "^2.0.1" + +merge-descriptors@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" + integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= + +merge-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" + integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== + +merge2@^1.3.0: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +methods@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" + integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= + +microevent.ts@~0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/microevent.ts/-/microevent.ts-0.1.1.tgz#70b09b83f43df5172d0205a63025bce0f7357fa0" + integrity sha512-jo1OfR4TaEwd5HOrt5+tAZ9mqT4jmpNAusXtyfNzqVm9uiSYFZlKM1wYL4oU7azZW/PxQW53wM0S6OR1JHNa2g== + +micromatch@^3.1.10, micromatch@^3.1.4: + version "3.1.10" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz#70859bc95c9840952f359a068a3fc49f9ecfac23" + integrity sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg== + dependencies: + arr-diff "^4.0.0" + array-unique "^0.3.2" + braces "^2.3.1" + define-property "^2.0.2" + extend-shallow "^3.0.2" + extglob "^2.0.4" + fragment-cache "^0.2.1" + kind-of "^6.0.2" + nanomatch "^1.2.9" + object.pick "^1.3.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.2" + +micromatch@^4.0.0, micromatch@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.2.tgz#4fcb0999bf9fbc2fcbdd212f6d629b9a56c39259" + integrity sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q== + dependencies: + braces "^3.0.1" + picomatch "^2.0.5" + +miller-rabin@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" + integrity sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA== + dependencies: + bn.js "^4.0.0" + brorand "^1.0.1" + +mime-db@1.46.0, "mime-db@>= 1.43.0 < 2": + version "1.46.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.46.0.tgz#6267748a7f799594de3cbc8cde91def349661cee" + integrity sha512-svXaP8UQRZ5K7or+ZmfNhg2xX3yKDMUzqadsSqi4NCH/KomcH75MAMYAGVlvXn4+b/xOPhS3I2uHKRUzvjY7BQ== + +mime-types@^2.1.12, mime-types@^2.1.27, mime-types@~2.1.17, mime-types@~2.1.19, mime-types@~2.1.24: + version "2.1.29" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.29.tgz#1d4ab77da64b91f5f72489df29236563754bb1b2" + integrity sha512-Y/jMt/S5sR9OaqteJtslsFZKWOIIqMACsJSiHghlCAyhf7jfVYjKBmLiX8OgpWeW+fjJ2b+Az69aPFPkUOY6xQ== + dependencies: + mime-db "1.46.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +mime@^2.3.1, mime@^2.4.4: + version "2.5.2" + resolved "https://registry.yarnpkg.com/mime/-/mime-2.5.2.tgz#6e3dc6cc2b9510643830e5f19d5cb753da5eeabe" + integrity sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg== + +mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +min-document@^2.19.0: + version "2.19.0" + resolved "https://registry.yarnpkg.com/min-document/-/min-document-2.19.0.tgz#7bd282e3f5842ed295bb748cdd9f1ffa2c824685" + integrity sha1-e9KC4/WELtKVu3SM3Z8f+iyCRoU= + dependencies: + dom-walk "^0.1.0" + +min-indent@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/min-indent/-/min-indent-1.0.1.tgz#a63f681673b30571fbe8bc25686ae746eefa9869" + integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg== + +mini-create-react-context@^0.4.0: + version "0.4.1" + resolved "https://registry.yarnpkg.com/mini-create-react-context/-/mini-create-react-context-0.4.1.tgz#072171561bfdc922da08a60c2197a497cc2d1d5e" + integrity sha512-YWCYEmd5CQeHGSAKrYvXgmzzkrvssZcuuQDDeqkT+PziKGMgE+0MCCtcKbROzocGBG1meBLl2FotlRwf4gAzbQ== + dependencies: + "@babel/runtime" "^7.12.1" + tiny-warning "^1.0.3" + +mini-css-extract-plugin@0.11.3: + version "0.11.3" + resolved "https://registry.yarnpkg.com/mini-css-extract-plugin/-/mini-css-extract-plugin-0.11.3.tgz#15b0910a7f32e62ffde4a7430cfefbd700724ea6" + integrity sha512-n9BA8LonkOkW1/zn+IbLPQmovsL0wMb9yx75fMJQZf2X1Zoec9yTZtyMePcyu19wPkmFbzZZA6fLTotpFhQsOA== + dependencies: + loader-utils "^1.1.0" + normalize-url "1.9.1" + schema-utils "^1.0.0" + webpack-sources "^1.1.0" + +mini-css-extract-plugin@^1.3.9: + version "1.4.0" + resolved "https://registry.yarnpkg.com/mini-css-extract-plugin/-/mini-css-extract-plugin-1.4.0.tgz#c8e571c4b6d63afa56c47260343adf623349c473" + integrity sha512-DyQr5DhXXARKZoc4kwvCvD95kh69dUupfuKOmBUqZ4kBTmRaRZcU32lYu3cLd6nEGXhQ1l7LzZ3F/CjItaY6VQ== + dependencies: + loader-utils "^2.0.0" + schema-utils "^3.0.0" + webpack-sources "^1.1.0" + +minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" + integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== + +minimalistic-crypto-utils@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" + integrity sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo= + +minimatch@3.0.4, minimatch@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" + integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== + dependencies: + brace-expansion "^1.1.7" + +minimist@^1.1.1, minimist@^1.2.0, minimist@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" + integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== + +minipass-collect@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" + integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== + dependencies: + minipass "^3.0.0" + +minipass-flush@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" + integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== + dependencies: + minipass "^3.0.0" + +minipass-pipeline@^1.2.2: + version "1.2.4" + resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" + integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== + dependencies: + minipass "^3.0.0" + +minipass@^3.0.0, minipass@^3.1.1: + version "3.1.3" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.1.3.tgz#7d42ff1f39635482e15f9cdb53184deebd5815fd" + integrity sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg== + dependencies: + yallist "^4.0.0" + +minizlib@^2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" + integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== + dependencies: + minipass "^3.0.0" + yallist "^4.0.0" + +mississippi@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mississippi/-/mississippi-3.0.0.tgz#ea0a3291f97e0b5e8776b363d5f0a12d94c67022" + integrity sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA== + dependencies: + concat-stream "^1.5.0" + duplexify "^3.4.2" + end-of-stream "^1.1.0" + flush-write-stream "^1.0.0" + from2 "^2.1.0" + parallel-transform "^1.1.0" + pump "^3.0.0" + pumpify "^1.3.3" + stream-each "^1.1.0" + through2 "^2.0.0" + +mixin-deep@^1.2.0: + version "1.3.2" + resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" + integrity sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA== + dependencies: + for-in "^1.0.2" + is-extendable "^1.0.1" + +mkdirp@^0.5.1, mkdirp@^0.5.3, mkdirp@^0.5.5, mkdirp@~0.5.1: + version "0.5.5" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" + integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== + dependencies: + minimist "^1.2.5" + +mkdirp@^1.0.3, mkdirp@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" + integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== + +moment-timezone@^0.5.33: + version "0.5.33" + resolved "https://registry.yarnpkg.com/moment-timezone/-/moment-timezone-0.5.33.tgz#b252fd6bb57f341c9b59a5ab61a8e51a73bbd22c" + integrity sha512-PTc2vcT8K9J5/9rDEPe5czSIKgLoGsH8UNpA4qZTVw0Vd/Uz19geE9abbIOQKaAQFcnQ3v5YEXrbSc5BpshH+w== + dependencies: + moment ">= 2.9.0" + +"moment@>= 2.9.0", moment@^2.29.1: + version "2.29.1" + resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.1.tgz#b2be769fa31940be9eeea6469c075e35006fa3d3" + integrity sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ== + +move-concurrently@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/move-concurrently/-/move-concurrently-1.0.1.tgz#be2c005fda32e0b29af1f05d7c4b33214c701f92" + integrity sha1-viwAX9oy4LKa8fBdfEszIUxwH5I= + dependencies: + aproba "^1.1.1" + copy-concurrently "^1.0.0" + fs-write-stream-atomic "^1.0.8" + mkdirp "^0.5.1" + rimraf "^2.5.4" + run-queue "^1.0.3" + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= + +ms@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" + integrity sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg== + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@^2.1.1: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +multicast-dns-service-types@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/multicast-dns-service-types/-/multicast-dns-service-types-1.1.0.tgz#899f11d9686e5e05cb91b35d5f0e63b773cfc901" + integrity sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE= + +multicast-dns@^6.0.1: + version "6.2.3" + resolved "https://registry.yarnpkg.com/multicast-dns/-/multicast-dns-6.2.3.tgz#a0ec7bd9055c4282f790c3c82f4e28db3b31b229" + integrity sha512-ji6J5enbMyGRHIAkAOu3WdV8nggqviKCEKtXcOqfphZZtQrmHKycfynJ2V7eVPUA4NhJ6V7Wf4TmGbTwKE9B6g== + dependencies: + dns-packet "^1.3.1" + thunky "^1.0.2" + +nan@^2.12.1: + version "2.14.2" + resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.2.tgz#f5376400695168f4cc694ac9393d0c9585eeea19" + integrity sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ== + +nanoid@^3.1.20: + version "3.1.22" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.22.tgz#b35f8fb7d151990a8aebd5aa5015c03cf726f844" + integrity sha512-/2ZUaJX2ANuLtTvqTlgqBQNJoQO398KyJgZloL0PZkC0dpysjncRUPsFe3DUPzz/y3h+u7C46np8RMuvF3jsSQ== + +nanomatch@^1.2.9: + version "1.2.13" + resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" + integrity sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA== + dependencies: + arr-diff "^4.0.0" + array-unique "^0.3.2" + define-property "^2.0.2" + extend-shallow "^3.0.2" + fragment-cache "^0.2.1" + is-windows "^1.0.2" + kind-of "^6.0.2" + object.pick "^1.3.0" + regex-not "^1.0.0" + snapdragon "^0.8.1" + to-regex "^3.0.1" + +native-url@^0.2.6: + version "0.2.6" + resolved "https://registry.yarnpkg.com/native-url/-/native-url-0.2.6.tgz#ca1258f5ace169c716ff44eccbddb674e10399ae" + integrity sha512-k4bDC87WtgrdD362gZz6zoiXQrl40kYlBmpfmSjwRO1VU0V5ccwJTlxuE72F6m3V0vc1xOf6n3UCP9QyerRqmA== + dependencies: + querystring "^0.2.0" + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc= + +negotiator@0.6.2: + version "0.6.2" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" + integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== + +neo-async@^2.5.0, neo-async@^2.6.1, neo-async@^2.6.2: + version "2.6.2" + resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" + integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== + +next-tick@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/next-tick/-/next-tick-1.0.0.tgz#ca86d1fe8828169b0120208e3dc8424b9db8342c" + integrity sha1-yobR/ogoFpsBICCOPchCS524NCw= + +nice-try@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" + integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== + +no-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" + integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== + dependencies: + lower-case "^2.0.2" + tslib "^2.0.3" + +node-fetch@^1.0.1: + version "1.7.3" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.7.3.tgz#980f6f72d85211a5347c6b2bc18c5b84c3eb47ef" + integrity sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ== + dependencies: + encoding "^0.1.11" + is-stream "^1.0.1" + +node-forge@^0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-0.10.0.tgz#32dea2afb3e9926f02ee5ce8794902691a676bf3" + integrity sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA== + +node-int64@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" + integrity sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs= + +node-libs-browser@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/node-libs-browser/-/node-libs-browser-2.2.1.tgz#b64f513d18338625f90346d27b0d235e631f6425" + integrity sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q== + dependencies: + assert "^1.1.1" + browserify-zlib "^0.2.0" + buffer "^4.3.0" + console-browserify "^1.1.0" + constants-browserify "^1.0.0" + crypto-browserify "^3.11.0" + domain-browser "^1.1.1" + events "^3.0.0" + https-browserify "^1.0.0" + os-browserify "^0.3.0" + path-browserify "0.0.1" + process "^0.11.10" + punycode "^1.2.4" + querystring-es3 "^0.2.0" + readable-stream "^2.3.3" + stream-browserify "^2.0.1" + stream-http "^2.7.2" + string_decoder "^1.0.0" + timers-browserify "^2.0.4" + tty-browserify "0.0.0" + url "^0.11.0" + util "^0.11.0" + vm-browserify "^1.0.1" + +node-modules-regexp@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz#8d9dbe28964a4ac5712e9131642107c71e90ec40" + integrity sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA= + +node-notifier@^8.0.0: + version "8.0.2" + resolved "https://registry.yarnpkg.com/node-notifier/-/node-notifier-8.0.2.tgz#f3167a38ef0d2c8a866a83e318c1ba0efeb702c5" + integrity sha512-oJP/9NAdd9+x2Q+rfphB2RJCHjod70RcRLjosiPMMu5gjIfwVnOUGq2nbTjTUbmy0DJ/tFIVT30+Qe3nzl4TJg== + dependencies: + growly "^1.3.0" + is-wsl "^2.2.0" + semver "^7.3.2" + shellwords "^0.1.1" + uuid "^8.3.0" + which "^2.0.2" + +node-releases@^1.1.61, node-releases@^1.1.70: + version "1.1.71" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.71.tgz#cb1334b179896b1c89ecfdd4b725fb7bbdfc7dbb" + integrity sha512-zR6HoT6LrLCRBwukmrVbHv0EpEQjksO6GmFcZQQuCAy139BEsoVKPYnf3jongYW83fAa1torLGYwxxky/p28sg== + +normalize-package-data@^2.3.2, normalize-package-data@^2.5.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" + integrity sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA== + dependencies: + hosted-git-info "^2.1.4" + resolve "^1.10.0" + semver "2 || 3 || 4 || 5" + validate-npm-package-license "^3.0.1" + +normalize-path@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9" + integrity sha1-GrKLVW4Zg2Oowab35vogE3/mrtk= + dependencies: + remove-trailing-separator "^1.0.1" + +normalize-path@^3.0.0, normalize-path@~3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +normalize-range@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942" + integrity sha1-LRDAa9/TEuqXd2laTShDlFa3WUI= + +normalize-url@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-1.9.1.tgz#2cc0d66b31ea23036458436e3620d85954c66c3c" + integrity sha1-LMDWazHqIwNkWENuNiDYWVTGbDw= + dependencies: + object-assign "^4.0.1" + prepend-http "^1.0.0" + query-string "^4.1.0" + sort-keys "^1.0.0" + +normalize-url@^3.0.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-3.3.0.tgz#b2e1c4dc4f7c6d57743df733a4f5978d18650559" + integrity sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg== + +npm-run-path@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" + integrity sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8= + dependencies: + path-key "^2.0.0" + +npm-run-path@^4.0.0, npm-run-path@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" + integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== + dependencies: + path-key "^3.0.0" + +nth-check@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-1.0.2.tgz#b2bd295c37e3dd58a3bf0700376663ba4d9cf05c" + integrity sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg== + dependencies: + boolbase "~1.0.0" + +num2fraction@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/num2fraction/-/num2fraction-1.2.2.tgz#6f682b6a027a4e9ddfa4564cd2589d1d4e669ede" + integrity sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4= + +nwsapi@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7" + integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ== + +oauth-sign@~0.9.0: + version "0.9.0" + resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455" + integrity sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ== + +object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= + +object-copy@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" + integrity sha1-fn2Fi3gb18mRpBupde04EnVOmYw= + dependencies: + copy-descriptor "^0.1.0" + define-property "^0.2.5" + kind-of "^3.0.3" + +object-inspect@^1.9.0: + version "1.9.0" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.9.0.tgz#c90521d74e1127b67266ded3394ad6116986533a" + integrity sha512-i3Bp9iTqwhaLZBxGkRfo5ZbE07BQRT7MGu8+nNgwW9ItGp1TzCTw2DLEoWwjClxBjOFI/hWljTAmYGCEwmtnOw== + +object-is@^1.0.1: + version "1.1.5" + resolved "https://registry.yarnpkg.com/object-is/-/object-is-1.1.5.tgz#b9deeaa5fc7f1846a0faecdceec138e5778f53ac" + integrity sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + +object-keys@^1.0.12, object-keys@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" + integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== + +object-visit@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz#f79c4493af0c5377b59fe39d395e41042dd045bb" + integrity sha1-95xEk68MU3e1n+OdOV5BBC3QRbs= + dependencies: + isobject "^3.0.0" + +object.assign@^4.1.0, object.assign@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.2.tgz#0ed54a342eceb37b38ff76eb831a0e788cb63940" + integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + has-symbols "^1.0.1" + object-keys "^1.1.1" + +object.entries@^1.1.0, object.entries@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.3.tgz#c601c7f168b62374541a07ddbd3e2d5e4f7711a6" + integrity sha512-ym7h7OZebNS96hn5IJeyUmaWhaSM4SVtAPPfNLQEI2MYWCO2egsITb9nab2+i/Pwibx+R0mtn+ltKJXRSeTMGg== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.1" + has "^1.0.3" + +object.fromentries@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.4.tgz#26e1ba5c4571c5c6f0890cef4473066456a120b8" + integrity sha512-EsFBshs5RUUpQEY1D4q/m59kMfz4YJvxuNCJcv/jWwOJr34EaVnG11ZrZa0UHB3wnzV1wx8m58T4hQL8IuNXlQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.2" + has "^1.0.3" + +object.getownpropertydescriptors@^2.0.3, object.getownpropertydescriptors@^2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.2.tgz#1bd63aeacf0d5d2d2f31b5e393b03a7c601a23f7" + integrity sha512-WtxeKSzfBjlzL+F9b7M7hewDzMwy+C8NRssHd1YrNlzHzIDrXcXiNOMrezdAEM4UXixgV+vvnyBeN7Rygl2ttQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.2" + +object.pick@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" + integrity sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c= + dependencies: + isobject "^3.0.1" + +object.values@^1.1.0, object.values@^1.1.1, object.values@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.3.tgz#eaa8b1e17589f02f698db093f7c62ee1699742ee" + integrity sha512-nkF6PfDB9alkOUxpf1HNm/QlkeW3SReqL5WXeBLpEJJnlPSvRaDQpW3gQTksTN3fgJX4hL42RzKyOin6ff3tyw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.2" + has "^1.0.3" + +obuf@^1.0.0, obuf@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/obuf/-/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e" + integrity sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg== + +on-finished@~2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" + integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= + dependencies: + ee-first "1.1.1" + +on-headers@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" + integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== + +once@^1.3.0, once@^1.3.1, once@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= + dependencies: + wrappy "1" + +onetime@^5.1.0, onetime@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +open@^7.0.2: + version "7.4.2" + resolved "https://registry.yarnpkg.com/open/-/open-7.4.2.tgz#b8147e26dcf3e426316c730089fd71edd29c2321" + integrity sha512-MVHddDVweXZF3awtlAS+6pgKLlm/JgxZ90+/NBurBoQctVOOB/zDdVjcyPzQ+0laDGbsWgrRkflI65sQeOgT9Q== + dependencies: + is-docker "^2.0.0" + is-wsl "^2.1.1" + +opener@^1.5.2: + version "1.5.2" + resolved "https://registry.yarnpkg.com/opener/-/opener-1.5.2.tgz#5d37e1f35077b9dcac4301372271afdeb2a13598" + integrity sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A== + +opn@^5.5.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/opn/-/opn-5.5.0.tgz#fc7164fab56d235904c51c3b27da6758ca3b9bfc" + integrity sha512-PqHpggC9bLV0VeWcdKhkpxY+3JTzetLSqTCWL/z/tFIbI6G8JCjondXklT1JinczLz2Xib62sSp0T/gKT4KksA== + dependencies: + is-wsl "^1.1.0" + +optimize-css-assets-webpack-plugin@5.0.4: + version "5.0.4" + resolved "https://registry.yarnpkg.com/optimize-css-assets-webpack-plugin/-/optimize-css-assets-webpack-plugin-5.0.4.tgz#85883c6528aaa02e30bbad9908c92926bb52dc90" + integrity sha512-wqd6FdI2a5/FdoiCNNkEvLeA//lHHfG24Ln2Xm2qqdIk4aOlsR18jwpyOihqQ8849W3qu2DX8fOYxpvTMj+93A== + dependencies: + cssnano "^4.1.10" + last-call-webpack-plugin "^3.0.0" + +optionator@^0.8.1: + version "0.8.3" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz#84fa1d036fe9d3c7e21d99884b601167ec8fb495" + integrity sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA== + dependencies: + deep-is "~0.1.3" + fast-levenshtein "~2.0.6" + levn "~0.3.0" + prelude-ls "~1.1.2" + type-check "~0.3.2" + word-wrap "~1.2.3" + +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.3" + +original@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/original/-/original-1.0.2.tgz#e442a61cffe1c5fd20a65f3261c26663b303f25f" + integrity sha512-hyBVl6iqqUOJ8FqRe+l/gS8H+kKYjrEndd5Pm1MfBtsEKA038HkkdbAl/72EAXGyonD/PFsvmVG+EvcIpliMBg== + dependencies: + url-parse "^1.4.3" + +os-browserify@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.3.0.tgz#854373c7f5c2315914fc9bfc6bd8238fdda1ec27" + integrity sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc= + +p-each-series@^2.1.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/p-each-series/-/p-each-series-2.2.0.tgz#105ab0357ce72b202a8a8b94933672657b5e2a9a" + integrity sha512-ycIL2+1V32th+8scbpTvyHNaHe02z0sjgh91XXjAk+ZeXoPN4Z46DVUnzdso0aX4KckKw0FNNFHdjZ2UsZvxiA== + +p-finally@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae" + integrity sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4= + +p-limit@^1.1.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz#b86bd5f0c25690911c7590fcbfc2010d54b3ccb8" + integrity sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q== + dependencies: + p-try "^1.0.0" + +p-limit@^2.0.0, p-limit@^2.2.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" + integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== + dependencies: + p-try "^2.0.0" + +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" + integrity sha1-IKAQOyIqcMj9OcwuWAaA893l7EM= + dependencies: + p-limit "^1.1.0" + +p-locate@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" + integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== + dependencies: + p-limit "^2.0.0" + +p-locate@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" + integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== + dependencies: + p-limit "^2.2.0" + +p-map@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz#310928feef9c9ecc65b68b17693018a665cea175" + integrity sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw== + +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + +p-retry@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/p-retry/-/p-retry-3.0.1.tgz#316b4c8893e2c8dc1cfa891f406c4b422bebf328" + integrity sha512-XE6G4+YTTkT2a0UWb2kjZe8xNwf8bIbnqpc/IS/idOBVhyves0mK5OJgeocjx7q5pvX/6m23xuzVPYT1uGM73w== + dependencies: + retry "^0.12.0" + +p-try@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz#cbc79cdbaf8fd4228e13f621f2b1a237c1b207b3" + integrity sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M= + +p-try@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" + integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== + +pako@~1.0.5: + version "1.0.11" + resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" + integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== + +parallel-transform@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/parallel-transform/-/parallel-transform-1.2.0.tgz#9049ca37d6cb2182c3b1d2c720be94d14a5814fc" + integrity sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg== + dependencies: + cyclist "^1.0.1" + inherits "^2.0.3" + readable-stream "^2.1.5" + +param-case@^3.0.3: + version "3.0.4" + resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" + integrity sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A== + dependencies: + dot-case "^3.0.4" + tslib "^2.0.3" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +parse-asn1@^5.0.0, parse-asn1@^5.1.5: + version "5.1.6" + resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.6.tgz#385080a3ec13cb62a62d39409cb3e88844cdaed4" + integrity sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw== + dependencies: + asn1.js "^5.2.0" + browserify-aes "^1.0.0" + evp_bytestokey "^1.0.0" + pbkdf2 "^3.0.3" + safe-buffer "^5.1.1" + +parse-json@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz#f480f40434ef80741f8469099f8dea18f55a4dc9" + integrity sha1-9ID0BDTvgHQfhGkJn43qGPVaTck= + dependencies: + error-ex "^1.2.0" + +parse-json@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz#be35f5425be1f7f6c747184f98a788cb99477ee0" + integrity sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA= + dependencies: + error-ex "^1.3.1" + json-parse-better-errors "^1.0.1" + +parse-json@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" + integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== + dependencies: + "@babel/code-frame" "^7.0.0" + error-ex "^1.3.1" + json-parse-even-better-errors "^2.3.0" + lines-and-columns "^1.1.6" + +parse5@6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" + integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== + +parseurl@~1.3.2, parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +pascal-case@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" + integrity sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + +pascalcase@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14" + integrity sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ= + +path-browserify@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.1.tgz#e6c4ddd7ed3aa27c68a20cc4e50e1a4ee83bbc4a" + integrity sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ== + +path-dirname@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/path-dirname/-/path-dirname-1.0.2.tgz#cc33d24d525e099a5388c0336c6e32b9160609e0" + integrity sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA= + +path-exists@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" + integrity sha1-zg6+ql94yxiSXqfYENe1mwEP1RU= + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= + +path-is-inside@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53" + integrity sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM= + +path-key@^2.0.0, path-key@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" + integrity sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A= + +path-key@^3.0.0, path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz#d62dbb5679405d72c4737ec58600e9ddcf06d24c" + integrity sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw== + +path-to-regexp@0.1.7: + version "0.1.7" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" + integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= + +path-to-regexp@^1.7.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-1.8.0.tgz#887b3ba9d84393e87a0a0b9f4cb756198b53548a" + integrity sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA== + dependencies: + isarray "0.0.1" + +path-type@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-2.0.0.tgz#f012ccb8415b7096fc2daa1054c3d72389594c73" + integrity sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM= + dependencies: + pify "^2.0.0" + +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + +pbkdf2@^3.0.3: + version "3.1.1" + resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.1.tgz#cb8724b0fada984596856d1a6ebafd3584654b94" + integrity sha512-4Ejy1OPxi9f2tt1rRV7Go7zmfDQ+ZectEQz3VGUQhgq62HtIRPDyG/JtnwIxs6x3uNMwo2V7q1fMvKjb+Tnpqg== + dependencies: + create-hash "^1.1.2" + create-hmac "^1.1.4" + ripemd160 "^2.0.1" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +performance-now@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" + integrity sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns= + +picomatch@^2.0.4, picomatch@^2.0.5, picomatch@^2.2.1, picomatch@^2.2.2: + version "2.2.2" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" + integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== + +pify@^2.0.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" + integrity sha1-7RQaasBDqEnqWISY59yosVMw6Qw= + +pify@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/pify/-/pify-4.0.1.tgz#4b2cd25c50d598735c50292224fd8c6df41e3231" + integrity sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g== + +pinkie-promise@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" + integrity sha1-ITXW36ejWMBprJsXh3YogihFD/o= + dependencies: + pinkie "^2.0.0" + +pinkie@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" + integrity sha1-clVrgM+g1IqXToDnckjoDtT3+HA= + +pirates@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/pirates/-/pirates-4.0.1.tgz#643a92caf894566f91b2b986d2c66950a8e2fb87" + integrity sha512-WuNqLTbMI3tmfef2TKxlQmAiLHKtFhlsCZnPIpuv2Ow0RDVO8lfy1Opf4NUzlMXLjPl+Men7AuVdX6TA+s+uGA== + dependencies: + node-modules-regexp "^1.0.0" + +pkg-dir@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-2.0.0.tgz#f6d5d1109e19d63edf428e0bd57e12777615334b" + integrity sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s= + dependencies: + find-up "^2.1.0" + +pkg-dir@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-3.0.0.tgz#2749020f239ed990881b1f71210d51eb6523bea3" + integrity sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw== + dependencies: + find-up "^3.0.0" + +pkg-dir@^4.1.0, pkg-dir@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" + integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== + dependencies: + find-up "^4.0.0" + +pkg-up@3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/pkg-up/-/pkg-up-3.1.0.tgz#100ec235cc150e4fd42519412596a28512a0def5" + integrity sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA== + dependencies: + find-up "^3.0.0" + +pnp-webpack-plugin@1.6.4: + version "1.6.4" + resolved "https://registry.yarnpkg.com/pnp-webpack-plugin/-/pnp-webpack-plugin-1.6.4.tgz#c9711ac4dc48a685dabafc86f8b6dd9f8df84149" + integrity sha512-7Wjy+9E3WwLOEL30D+m8TSTF7qJJUJLONBnwQp0518siuMxUQUbgZwssaFX+QKlZkjHZcw/IpZCt/H0srrntSg== + dependencies: + ts-pnp "^1.1.6" + +portable-fetch@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/portable-fetch/-/portable-fetch-3.0.0.tgz#3cbf4aa6dbc5a5734b41c0419c9273313bfd9ad8" + integrity sha1-PL9KptvFpXNLQcBBnJJzMTv9mtg= + dependencies: + node-fetch "^1.0.1" + whatwg-fetch ">=0.10.0" + +portfinder@^1.0.26: + version "1.0.28" + resolved "https://registry.yarnpkg.com/portfinder/-/portfinder-1.0.28.tgz#67c4622852bd5374dd1dd900f779f53462fac778" + integrity sha512-Se+2isanIcEqf2XMHjyUKskczxbPH7dQnlMjXX6+dybayyHvAf/TCgyMRlzf/B6QDhAEFOGes0pzRo3by4AbMA== + dependencies: + async "^2.6.2" + debug "^3.1.1" + mkdirp "^0.5.5" + +posix-character-classes@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" + integrity sha1-AerA/jta9xoqbAL+q7jB/vfgDqs= + +postcss-attribute-case-insensitive@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-4.0.2.tgz#d93e46b504589e94ac7277b0463226c68041a880" + integrity sha512-clkFxk/9pcdb4Vkn0hAHq3YnxBQ2p0CGD1dy24jN+reBck+EWxMbxSUqN4Yj7t0w8csl87K6p0gxBe1utkJsYA== + dependencies: + postcss "^7.0.2" + postcss-selector-parser "^6.0.2" + +postcss-browser-comments@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-browser-comments/-/postcss-browser-comments-3.0.0.tgz#1248d2d935fb72053c8e1f61a84a57292d9f65e9" + integrity sha512-qfVjLfq7HFd2e0HW4s1dvU8X080OZdG46fFbIBFjW7US7YPDcWfRvdElvwMJr2LI6hMmD+7LnH2HcmXTs+uOig== + dependencies: + postcss "^7" + +postcss-calc@^7.0.1: + version "7.0.5" + resolved "https://registry.yarnpkg.com/postcss-calc/-/postcss-calc-7.0.5.tgz#f8a6e99f12e619c2ebc23cf6c486fdc15860933e" + integrity sha512-1tKHutbGtLtEZF6PT4JSihCHfIVldU72mZ8SdZHIYriIZ9fh9k9aWSppaT8rHsyI3dX+KSR+W+Ix9BMY3AODrg== + dependencies: + postcss "^7.0.27" + postcss-selector-parser "^6.0.2" + postcss-value-parser "^4.0.2" + +postcss-color-functional-notation@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/postcss-color-functional-notation/-/postcss-color-functional-notation-2.0.1.tgz#5efd37a88fbabeb00a2966d1e53d98ced93f74e0" + integrity sha512-ZBARCypjEDofW4P6IdPVTLhDNXPRn8T2s1zHbZidW6rPaaZvcnCS2soYFIQJrMZSxiePJ2XIYTlcb2ztr/eT2g== + dependencies: + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-color-gray@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/postcss-color-gray/-/postcss-color-gray-5.0.0.tgz#532a31eb909f8da898ceffe296fdc1f864be8547" + integrity sha512-q6BuRnAGKM/ZRpfDascZlIZPjvwsRye7UDNalqVz3s7GDxMtqPY6+Q871liNxsonUw8oC61OG+PSaysYpl1bnw== + dependencies: + "@csstools/convert-colors" "^1.4.0" + postcss "^7.0.5" + postcss-values-parser "^2.0.0" + +postcss-color-hex-alpha@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/postcss-color-hex-alpha/-/postcss-color-hex-alpha-5.0.3.tgz#a8d9ca4c39d497c9661e374b9c51899ef0f87388" + integrity sha512-PF4GDel8q3kkreVXKLAGNpHKilXsZ6xuu+mOQMHWHLPNyjiUBOr75sp5ZKJfmv1MCus5/DWUGcK9hm6qHEnXYw== + dependencies: + postcss "^7.0.14" + postcss-values-parser "^2.0.1" + +postcss-color-mod-function@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/postcss-color-mod-function/-/postcss-color-mod-function-3.0.3.tgz#816ba145ac11cc3cb6baa905a75a49f903e4d31d" + integrity sha512-YP4VG+xufxaVtzV6ZmhEtc+/aTXH3d0JLpnYfxqTvwZPbJhWqp8bSY3nfNzNRFLgB4XSaBA82OE4VjOOKpCdVQ== + dependencies: + "@csstools/convert-colors" "^1.4.0" + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-color-rebeccapurple@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-4.0.1.tgz#c7a89be872bb74e45b1e3022bfe5748823e6de77" + integrity sha512-aAe3OhkS6qJXBbqzvZth2Au4V3KieR5sRQ4ptb2b2O8wgvB3SJBsdG+jsn2BZbbwekDG8nTfcCNKcSfe/lEy8g== + dependencies: + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-colormin@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/postcss-colormin/-/postcss-colormin-4.0.3.tgz#ae060bce93ed794ac71264f08132d550956bd381" + integrity sha512-WyQFAdDZpExQh32j0U0feWisZ0dmOtPl44qYmJKkq9xFWY3p+4qnRzCHeNrkeRhwPHz9bQ3mo0/yVkaply0MNw== + dependencies: + browserslist "^4.0.0" + color "^3.0.0" + has "^1.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-convert-values@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-convert-values/-/postcss-convert-values-4.0.1.tgz#ca3813ed4da0f812f9d43703584e449ebe189a7f" + integrity sha512-Kisdo1y77KUC0Jmn0OXU/COOJbzM8cImvw1ZFsBgBgMgb1iL23Zs/LXRe3r+EZqM3vGYKdQ2YJVQ5VkJI+zEJQ== + dependencies: + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-custom-media@^7.0.8: + version "7.0.8" + resolved "https://registry.yarnpkg.com/postcss-custom-media/-/postcss-custom-media-7.0.8.tgz#fffd13ffeffad73621be5f387076a28b00294e0c" + integrity sha512-c9s5iX0Ge15o00HKbuRuTqNndsJUbaXdiNsksnVH8H4gdc+zbLzr/UasOwNG6CTDpLFekVY4672eWdiiWu2GUg== + dependencies: + postcss "^7.0.14" + +postcss-custom-properties@^8.0.11: + version "8.0.11" + resolved "https://registry.yarnpkg.com/postcss-custom-properties/-/postcss-custom-properties-8.0.11.tgz#2d61772d6e92f22f5e0d52602df8fae46fa30d97" + integrity sha512-nm+o0eLdYqdnJ5abAJeXp4CEU1c1k+eB2yMCvhgzsds/e0umabFrN6HoTy/8Q4K5ilxERdl/JD1LO5ANoYBeMA== + dependencies: + postcss "^7.0.17" + postcss-values-parser "^2.0.1" + +postcss-custom-selectors@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/postcss-custom-selectors/-/postcss-custom-selectors-5.1.2.tgz#64858c6eb2ecff2fb41d0b28c9dd7b3db4de7fba" + integrity sha512-DSGDhqinCqXqlS4R7KGxL1OSycd1lydugJ1ky4iRXPHdBRiozyMHrdu0H3o7qNOCiZwySZTUI5MV0T8QhCLu+w== + dependencies: + postcss "^7.0.2" + postcss-selector-parser "^5.0.0-rc.3" + +postcss-dir-pseudo-class@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-5.0.0.tgz#6e3a4177d0edb3abcc85fdb6fbb1c26dabaeaba2" + integrity sha512-3pm4oq8HYWMZePJY+5ANriPs3P07q+LW6FAdTlkFH2XqDdP4HeeJYMOzn0HYLhRSjBO3fhiqSwwU9xEULSrPgw== + dependencies: + postcss "^7.0.2" + postcss-selector-parser "^5.0.0-rc.3" + +postcss-discard-comments@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-discard-comments/-/postcss-discard-comments-4.0.2.tgz#1fbabd2c246bff6aaad7997b2b0918f4d7af4033" + integrity sha512-RJutN259iuRf3IW7GZyLM5Sw4GLTOH8FmsXBnv8Ab/Tc2k4SR4qbV4DNbyyY4+Sjo362SyDmW2DQ7lBSChrpkg== + dependencies: + postcss "^7.0.0" + +postcss-discard-duplicates@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-discard-duplicates/-/postcss-discard-duplicates-4.0.2.tgz#3fe133cd3c82282e550fc9b239176a9207b784eb" + integrity sha512-ZNQfR1gPNAiXZhgENFfEglF93pciw0WxMkJeVmw8eF+JZBbMD7jp6C67GqJAXVZP2BWbOztKfbsdmMp/k8c6oQ== + dependencies: + postcss "^7.0.0" + +postcss-discard-empty@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-discard-empty/-/postcss-discard-empty-4.0.1.tgz#c8c951e9f73ed9428019458444a02ad90bb9f765" + integrity sha512-B9miTzbznhDjTfjvipfHoqbWKwd0Mj+/fL5s1QOz06wufguil+Xheo4XpOnc4NqKYBCNqqEzgPv2aPBIJLox0w== + dependencies: + postcss "^7.0.0" + +postcss-discard-overridden@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-discard-overridden/-/postcss-discard-overridden-4.0.1.tgz#652aef8a96726f029f5e3e00146ee7a4e755ff57" + integrity sha512-IYY2bEDD7g1XM1IDEsUT4//iEYCxAmP5oDSFMVU/JVvT7gh+l4fmjciLqGgwjdWpQIdb0Che2VX00QObS5+cTg== + dependencies: + postcss "^7.0.0" + +postcss-double-position-gradients@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/postcss-double-position-gradients/-/postcss-double-position-gradients-1.0.0.tgz#fc927d52fddc896cb3a2812ebc5df147e110522e" + integrity sha512-G+nV8EnQq25fOI8CH/B6krEohGWnF5+3A6H/+JEpOncu5dCnkS1QQ6+ct3Jkaepw1NGVqqOZH6lqrm244mCftA== + dependencies: + postcss "^7.0.5" + postcss-values-parser "^2.0.0" + +postcss-env-function@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/postcss-env-function/-/postcss-env-function-2.0.2.tgz#0f3e3d3c57f094a92c2baf4b6241f0b0da5365d7" + integrity sha512-rwac4BuZlITeUbiBq60h/xbLzXY43qOsIErngWa4l7Mt+RaSkT7QBjXVGTcBHupykkblHMDrBFh30zchYPaOUw== + dependencies: + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-flexbugs-fixes@4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/postcss-flexbugs-fixes/-/postcss-flexbugs-fixes-4.2.1.tgz#9218a65249f30897deab1033aced8578562a6690" + integrity sha512-9SiofaZ9CWpQWxOwRh1b/r85KD5y7GgvsNt1056k6OYLvWUun0czCvogfJgylC22uJTwW1KzY3Gz65NZRlvoiQ== + dependencies: + postcss "^7.0.26" + +postcss-focus-visible@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/postcss-focus-visible/-/postcss-focus-visible-4.0.0.tgz#477d107113ade6024b14128317ade2bd1e17046e" + integrity sha512-Z5CkWBw0+idJHSV6+Bgf2peDOFf/x4o+vX/pwcNYrWpXFrSfTkQ3JQ1ojrq9yS+upnAlNRHeg8uEwFTgorjI8g== + dependencies: + postcss "^7.0.2" + +postcss-focus-within@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-focus-within/-/postcss-focus-within-3.0.0.tgz#763b8788596cee9b874c999201cdde80659ef680" + integrity sha512-W0APui8jQeBKbCGZudW37EeMCjDeVxKgiYfIIEo8Bdh5SpB9sxds/Iq8SEuzS0Q4YFOlG7EPFulbbxujpkrV2w== + dependencies: + postcss "^7.0.2" + +postcss-font-variant@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-font-variant/-/postcss-font-variant-4.0.1.tgz#42d4c0ab30894f60f98b17561eb5c0321f502641" + integrity sha512-I3ADQSTNtLTTd8uxZhtSOrTCQ9G4qUVKPjHiDk0bV75QSxXjVWiJVJ2VLdspGUi9fbW9BcjKJoRvxAH1pckqmA== + dependencies: + postcss "^7.0.2" + +postcss-gap-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/postcss-gap-properties/-/postcss-gap-properties-2.0.0.tgz#431c192ab3ed96a3c3d09f2ff615960f902c1715" + integrity sha512-QZSqDaMgXCHuHTEzMsS2KfVDOq7ZFiknSpkrPJY6jmxbugUPTuSzs/vuE5I3zv0WAS+3vhrlqhijiprnuQfzmg== + dependencies: + postcss "^7.0.2" + +postcss-image-set-function@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/postcss-image-set-function/-/postcss-image-set-function-3.0.1.tgz#28920a2f29945bed4c3198d7df6496d410d3f288" + integrity sha512-oPTcFFip5LZy8Y/whto91L9xdRHCWEMs3e1MdJxhgt4jy2WYXfhkng59fH5qLXSCPN8k4n94p1Czrfe5IOkKUw== + dependencies: + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-initial@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/postcss-initial/-/postcss-initial-3.0.2.tgz#f018563694b3c16ae8eaabe3c585ac6319637b2d" + integrity sha512-ugA2wKonC0xeNHgirR4D3VWHs2JcU08WAi1KFLVcnb7IN89phID6Qtg2RIctWbnvp1TM2BOmDtX8GGLCKdR8YA== + dependencies: + lodash.template "^4.5.0" + postcss "^7.0.2" + +postcss-lab-function@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/postcss-lab-function/-/postcss-lab-function-2.0.1.tgz#bb51a6856cd12289ab4ae20db1e3821ef13d7d2e" + integrity sha512-whLy1IeZKY+3fYdqQFuDBf8Auw+qFuVnChWjmxm/UhHWqNHZx+B99EwxTvGYmUBqe3Fjxs4L1BoZTJmPu6usVg== + dependencies: + "@csstools/convert-colors" "^1.4.0" + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-load-config@^2.0.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/postcss-load-config/-/postcss-load-config-2.1.2.tgz#c5ea504f2c4aef33c7359a34de3573772ad7502a" + integrity sha512-/rDeGV6vMUo3mwJZmeHfEDvwnTKKqQ0S7OHUi/kJvvtx3aWtyWG2/0ZWnzCt2keEclwN6Tf0DST2v9kITdOKYw== + dependencies: + cosmiconfig "^5.0.0" + import-cwd "^2.0.0" + +postcss-loader@3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-loader/-/postcss-loader-3.0.0.tgz#6b97943e47c72d845fa9e03f273773d4e8dd6c2d" + integrity sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA== + dependencies: + loader-utils "^1.1.0" + postcss "^7.0.0" + postcss-load-config "^2.0.0" + schema-utils "^1.0.0" + +postcss-logical@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-logical/-/postcss-logical-3.0.0.tgz#2495d0f8b82e9f262725f75f9401b34e7b45d5b5" + integrity sha512-1SUKdJc2vuMOmeItqGuNaC+N8MzBWFWEkAnRnLpFYj1tGGa7NqyVBujfRtgNa2gXR+6RkGUiB2O5Vmh7E2RmiA== + dependencies: + postcss "^7.0.2" + +postcss-media-minmax@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/postcss-media-minmax/-/postcss-media-minmax-4.0.0.tgz#b75bb6cbc217c8ac49433e12f22048814a4f5ed5" + integrity sha512-fo9moya6qyxsjbFAYl97qKO9gyre3qvbMnkOZeZwlsW6XYFsvs2DMGDlchVLfAd8LHPZDxivu/+qW2SMQeTHBw== + dependencies: + postcss "^7.0.2" + +postcss-merge-longhand@^4.0.11: + version "4.0.11" + resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-4.0.11.tgz#62f49a13e4a0ee04e7b98f42bb16062ca2549e24" + integrity sha512-alx/zmoeXvJjp7L4mxEMjh8lxVlDFX1gqWHzaaQewwMZiVhLo42TEClKaeHbRf6J7j82ZOdTJ808RtN0ZOZwvw== + dependencies: + css-color-names "0.0.4" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + stylehacks "^4.0.0" + +postcss-merge-rules@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/postcss-merge-rules/-/postcss-merge-rules-4.0.3.tgz#362bea4ff5a1f98e4075a713c6cb25aefef9a650" + integrity sha512-U7e3r1SbvYzO0Jr3UT/zKBVgYYyhAz0aitvGIYOYK5CPmkNih+WDSsS5tvPrJ8YMQYlEMvsZIiqmn7HdFUaeEQ== + dependencies: + browserslist "^4.0.0" + caniuse-api "^3.0.0" + cssnano-util-same-parent "^4.0.0" + postcss "^7.0.0" + postcss-selector-parser "^3.0.0" + vendors "^1.0.0" + +postcss-minify-font-values@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-minify-font-values/-/postcss-minify-font-values-4.0.2.tgz#cd4c344cce474343fac5d82206ab2cbcb8afd5a6" + integrity sha512-j85oO6OnRU9zPf04+PZv1LYIYOprWm6IA6zkXkrJXyRveDEuQggG6tvoy8ir8ZwjLxLuGfNkCZEQG7zan+Hbtg== + dependencies: + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-minify-gradients@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-minify-gradients/-/postcss-minify-gradients-4.0.2.tgz#93b29c2ff5099c535eecda56c4aa6e665a663471" + integrity sha512-qKPfwlONdcf/AndP1U8SJ/uzIJtowHlMaSioKzebAXSG4iJthlWC9iSWznQcX4f66gIWX44RSA841HTHj3wK+Q== + dependencies: + cssnano-util-get-arguments "^4.0.0" + is-color-stop "^1.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-minify-params@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-minify-params/-/postcss-minify-params-4.0.2.tgz#6b9cef030c11e35261f95f618c90036d680db874" + integrity sha512-G7eWyzEx0xL4/wiBBJxJOz48zAKV2WG3iZOqVhPet/9geefm/Px5uo1fzlHu+DOjT+m0Mmiz3jkQzVHe6wxAWg== + dependencies: + alphanum-sort "^1.0.0" + browserslist "^4.0.0" + cssnano-util-get-arguments "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + uniqs "^2.0.0" + +postcss-minify-selectors@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-minify-selectors/-/postcss-minify-selectors-4.0.2.tgz#e2e5eb40bfee500d0cd9243500f5f8ea4262fbd8" + integrity sha512-D5S1iViljXBj9kflQo4YutWnJmwm8VvIsU1GeXJGiG9j8CIg9zs4voPMdQDUmIxetUOh60VilsNzCiAFTOqu3g== + dependencies: + alphanum-sort "^1.0.0" + has "^1.0.0" + postcss "^7.0.0" + postcss-selector-parser "^3.0.0" + +postcss-modules-extract-imports@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz#818719a1ae1da325f9832446b01136eeb493cd7e" + integrity sha512-LaYLDNS4SG8Q5WAWqIJgdHPJrDDr/Lv775rMBFUbgjTz6j34lUznACHcdRWroPvXANP2Vj7yNK57vp9eFqzLWQ== + dependencies: + postcss "^7.0.5" + +postcss-modules-local-by-default@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-3.0.3.tgz#bb14e0cc78279d504dbdcbfd7e0ca28993ffbbb0" + integrity sha512-e3xDq+LotiGesympRlKNgaJ0PCzoUIdpH0dj47iWAui/kyTgh3CiAr1qP54uodmJhl6p9rN6BoNcdEDVJx9RDw== + dependencies: + icss-utils "^4.1.1" + postcss "^7.0.32" + postcss-selector-parser "^6.0.2" + postcss-value-parser "^4.1.0" + +postcss-modules-scope@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-2.2.0.tgz#385cae013cc7743f5a7d7602d1073a89eaae62ee" + integrity sha512-YyEgsTMRpNd+HmyC7H/mh3y+MeFWevy7V1evVhJWewmMbjDHIbZbOXICC2y+m1xI1UVfIT1HMW/O04Hxyu9oXQ== + dependencies: + postcss "^7.0.6" + postcss-selector-parser "^6.0.0" + +postcss-modules-values@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-modules-values/-/postcss-modules-values-3.0.0.tgz#5b5000d6ebae29b4255301b4a3a54574423e7f10" + integrity sha512-1//E5jCBrZ9DmRX+zCtmQtRSV6PV42Ix7Bzj9GbwJceduuf7IqP8MgeTXuRDHOWj2m0VzZD5+roFWDuU8RQjcg== + dependencies: + icss-utils "^4.0.0" + postcss "^7.0.6" + +postcss-nesting@^7.0.0: + version "7.0.1" + resolved "https://registry.yarnpkg.com/postcss-nesting/-/postcss-nesting-7.0.1.tgz#b50ad7b7f0173e5b5e3880c3501344703e04c052" + integrity sha512-FrorPb0H3nuVq0Sff7W2rnc3SmIcruVC6YwpcS+k687VxyxO33iE1amna7wHuRVzM8vfiYofXSBHNAZ3QhLvYg== + dependencies: + postcss "^7.0.2" + +postcss-normalize-charset@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-charset/-/postcss-normalize-charset-4.0.1.tgz#8b35add3aee83a136b0471e0d59be58a50285dd4" + integrity sha512-gMXCrrlWh6G27U0hF3vNvR3w8I1s2wOBILvA87iNXaPvSNo5uZAMYsZG7XjCUf1eVxuPfyL4TJ7++SGZLc9A3g== + dependencies: + postcss "^7.0.0" + +postcss-normalize-display-values@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-display-values/-/postcss-normalize-display-values-4.0.2.tgz#0dbe04a4ce9063d4667ed2be476bb830c825935a" + integrity sha512-3F2jcsaMW7+VtRMAqf/3m4cPFhPD3EFRgNs18u+k3lTJJlVe7d0YPO+bnwqo2xg8YiRpDXJI2u8A0wqJxMsQuQ== + dependencies: + cssnano-util-get-match "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-positions@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-positions/-/postcss-normalize-positions-4.0.2.tgz#05f757f84f260437378368a91f8932d4b102917f" + integrity sha512-Dlf3/9AxpxE+NF1fJxYDeggi5WwV35MXGFnnoccP/9qDtFrTArZ0D0R+iKcg5WsUd8nUYMIl8yXDCtcrT8JrdA== + dependencies: + cssnano-util-get-arguments "^4.0.0" + has "^1.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-repeat-style@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-4.0.2.tgz#c4ebbc289f3991a028d44751cbdd11918b17910c" + integrity sha512-qvigdYYMpSuoFs3Is/f5nHdRLJN/ITA7huIoCyqqENJe9PvPmLhNLMu7QTjPdtnVf6OcYYO5SHonx4+fbJE1+Q== + dependencies: + cssnano-util-get-arguments "^4.0.0" + cssnano-util-get-match "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-string@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-string/-/postcss-normalize-string-4.0.2.tgz#cd44c40ab07a0c7a36dc5e99aace1eca4ec2690c" + integrity sha512-RrERod97Dnwqq49WNz8qo66ps0swYZDSb6rM57kN2J+aoyEAJfZ6bMx0sx/F9TIEX0xthPGCmeyiam/jXif0eA== + dependencies: + has "^1.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-timing-functions@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-4.0.2.tgz#8e009ca2a3949cdaf8ad23e6b6ab99cb5e7d28d9" + integrity sha512-acwJY95edP762e++00Ehq9L4sZCEcOPyaHwoaFOhIwWCDfik6YvqsYNxckee65JHLKzuNSSmAdxwD2Cud1Z54A== + dependencies: + cssnano-util-get-match "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-unicode@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-unicode/-/postcss-normalize-unicode-4.0.1.tgz#841bd48fdcf3019ad4baa7493a3d363b52ae1cfb" + integrity sha512-od18Uq2wCYn+vZ/qCOeutvHjB5jm57ToxRaMeNuf0nWVHaP9Hua56QyMF6fs/4FSUnVIw0CBPsU0K4LnBPwYwg== + dependencies: + browserslist "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-url@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-url/-/postcss-normalize-url-4.0.1.tgz#10e437f86bc7c7e58f7b9652ed878daaa95faae1" + integrity sha512-p5oVaF4+IHwu7VpMan/SSpmpYxcJMtkGppYf0VbdH5B6hN8YNmVyJLuY9FmLQTzY3fag5ESUUHDqM+heid0UVA== + dependencies: + is-absolute-url "^2.0.0" + normalize-url "^3.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize-whitespace@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-normalize-whitespace/-/postcss-normalize-whitespace-4.0.2.tgz#bf1d4070fe4fcea87d1348e825d8cc0c5faa7d82" + integrity sha512-tO8QIgrsI3p95r8fyqKV+ufKlSHh9hMJqACqbv2XknufqEDhDvbguXGBBqxw9nsQoXWf0qOqppziKJKHMD4GtA== + dependencies: + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-normalize@8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/postcss-normalize/-/postcss-normalize-8.0.1.tgz#90e80a7763d7fdf2da6f2f0f82be832ce4f66776" + integrity sha512-rt9JMS/m9FHIRroDDBGSMsyW1c0fkvOJPy62ggxSHUldJO7B195TqFMqIf+lY5ezpDcYOV4j86aUp3/XbxzCCQ== + dependencies: + "@csstools/normalize.css" "^10.1.0" + browserslist "^4.6.2" + postcss "^7.0.17" + postcss-browser-comments "^3.0.0" + sanitize.css "^10.0.0" + +postcss-ordered-values@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/postcss-ordered-values/-/postcss-ordered-values-4.1.2.tgz#0cf75c820ec7d5c4d280189559e0b571ebac0eee" + integrity sha512-2fCObh5UanxvSxeXrtLtlwVThBvHn6MQcu4ksNT2tsaV2Fg76R2CV98W7wNSlX+5/pFwEyaDwKLLoEV7uRybAw== + dependencies: + cssnano-util-get-arguments "^4.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-overflow-shorthand@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/postcss-overflow-shorthand/-/postcss-overflow-shorthand-2.0.0.tgz#31ecf350e9c6f6ddc250a78f0c3e111f32dd4c30" + integrity sha512-aK0fHc9CBNx8jbzMYhshZcEv8LtYnBIRYQD5i7w/K/wS9c2+0NSR6B3OVMu5y0hBHYLcMGjfU+dmWYNKH0I85g== + dependencies: + postcss "^7.0.2" + +postcss-page-break@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/postcss-page-break/-/postcss-page-break-2.0.0.tgz#add52d0e0a528cabe6afee8b46e2abb277df46bf" + integrity sha512-tkpTSrLpfLfD9HvgOlJuigLuk39wVTbbd8RKcy8/ugV2bNBUW3xU+AIqyxhDrQr1VUj1RmyJrBn1YWrqUm9zAQ== + dependencies: + postcss "^7.0.2" + +postcss-place@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-place/-/postcss-place-4.0.1.tgz#e9f39d33d2dc584e46ee1db45adb77ca9d1dcc62" + integrity sha512-Zb6byCSLkgRKLODj/5mQugyuj9bvAAw9LqJJjgwz5cYryGeXfFZfSXoP1UfveccFmeq0b/2xxwcTEVScnqGxBg== + dependencies: + postcss "^7.0.2" + postcss-values-parser "^2.0.0" + +postcss-preset-env@6.7.0: + version "6.7.0" + resolved "https://registry.yarnpkg.com/postcss-preset-env/-/postcss-preset-env-6.7.0.tgz#c34ddacf8f902383b35ad1e030f178f4cdf118a5" + integrity sha512-eU4/K5xzSFwUFJ8hTdTQzo2RBLbDVt83QZrAvI07TULOkmyQlnYlpwep+2yIK+K+0KlZO4BvFcleOCCcUtwchg== + dependencies: + autoprefixer "^9.6.1" + browserslist "^4.6.4" + caniuse-lite "^1.0.30000981" + css-blank-pseudo "^0.1.4" + css-has-pseudo "^0.10.0" + css-prefers-color-scheme "^3.1.1" + cssdb "^4.4.0" + postcss "^7.0.17" + postcss-attribute-case-insensitive "^4.0.1" + postcss-color-functional-notation "^2.0.1" + postcss-color-gray "^5.0.0" + postcss-color-hex-alpha "^5.0.3" + postcss-color-mod-function "^3.0.3" + postcss-color-rebeccapurple "^4.0.1" + postcss-custom-media "^7.0.8" + postcss-custom-properties "^8.0.11" + postcss-custom-selectors "^5.1.2" + postcss-dir-pseudo-class "^5.0.0" + postcss-double-position-gradients "^1.0.0" + postcss-env-function "^2.0.2" + postcss-focus-visible "^4.0.0" + postcss-focus-within "^3.0.0" + postcss-font-variant "^4.0.0" + postcss-gap-properties "^2.0.0" + postcss-image-set-function "^3.0.1" + postcss-initial "^3.0.0" + postcss-lab-function "^2.0.1" + postcss-logical "^3.0.0" + postcss-media-minmax "^4.0.0" + postcss-nesting "^7.0.0" + postcss-overflow-shorthand "^2.0.0" + postcss-page-break "^2.0.0" + postcss-place "^4.0.1" + postcss-pseudo-class-any-link "^6.0.0" + postcss-replace-overflow-wrap "^3.0.0" + postcss-selector-matches "^4.0.0" + postcss-selector-not "^4.0.0" + +postcss-pseudo-class-any-link@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-6.0.0.tgz#2ed3eed393b3702879dec4a87032b210daeb04d1" + integrity sha512-lgXW9sYJdLqtmw23otOzrtbDXofUdfYzNm4PIpNE322/swES3VU9XlXHeJS46zT2onFO7V1QFdD4Q9LiZj8mew== + dependencies: + postcss "^7.0.2" + postcss-selector-parser "^5.0.0-rc.3" + +postcss-reduce-initial@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/postcss-reduce-initial/-/postcss-reduce-initial-4.0.3.tgz#7fd42ebea5e9c814609639e2c2e84ae270ba48df" + integrity sha512-gKWmR5aUulSjbzOfD9AlJiHCGH6AEVLaM0AV+aSioxUDd16qXP1PCh8d1/BGVvpdWn8k/HiK7n6TjeoXN1F7DA== + dependencies: + browserslist "^4.0.0" + caniuse-api "^3.0.0" + has "^1.0.0" + postcss "^7.0.0" + +postcss-reduce-transforms@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-reduce-transforms/-/postcss-reduce-transforms-4.0.2.tgz#17efa405eacc6e07be3414a5ca2d1074681d4e29" + integrity sha512-EEVig1Q2QJ4ELpJXMZR8Vt5DQx8/mo+dGWSR7vWXqcob2gQLyQGsionYcGKATXvQzMPn6DSN1vTN7yFximdIAg== + dependencies: + cssnano-util-get-match "^4.0.0" + has "^1.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + +postcss-replace-overflow-wrap@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-3.0.0.tgz#61b360ffdaedca84c7c918d2b0f0d0ea559ab01c" + integrity sha512-2T5hcEHArDT6X9+9dVSPQdo7QHzG4XKclFT8rU5TzJPDN7RIRTbO9c4drUISOVemLj03aezStHCR2AIcr8XLpw== + dependencies: + postcss "^7.0.2" + +postcss-safe-parser@5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/postcss-safe-parser/-/postcss-safe-parser-5.0.2.tgz#459dd27df6bc2ba64608824ba39e45dacf5e852d" + integrity sha512-jDUfCPJbKOABhwpUKcqCVbbXiloe/QXMcbJ6Iipf3sDIihEzTqRCeMBfRaOHxhBuTYqtASrI1KJWxzztZU4qUQ== + dependencies: + postcss "^8.1.0" + +postcss-selector-matches@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/postcss-selector-matches/-/postcss-selector-matches-4.0.0.tgz#71c8248f917ba2cc93037c9637ee09c64436fcff" + integrity sha512-LgsHwQR/EsRYSqlwdGzeaPKVT0Ml7LAT6E75T8W8xLJY62CE4S/l03BWIt3jT8Taq22kXP08s2SfTSzaraoPww== + dependencies: + balanced-match "^1.0.0" + postcss "^7.0.2" + +postcss-selector-not@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-selector-not/-/postcss-selector-not-4.0.1.tgz#263016eef1cf219e0ade9a913780fc1f48204cbf" + integrity sha512-YolvBgInEK5/79C+bdFMyzqTg6pkYqDbzZIST/PDMqa/o3qtXenD05apBG2jLgT0/BQ77d4U2UK12jWpilqMAQ== + dependencies: + balanced-match "^1.0.0" + postcss "^7.0.2" + +postcss-selector-parser@^3.0.0: + version "3.1.2" + resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz#b310f5c4c0fdaf76f94902bbaa30db6aa84f5270" + integrity sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA== + dependencies: + dot-prop "^5.2.0" + indexes-of "^1.0.1" + uniq "^1.0.1" + +postcss-selector-parser@^5.0.0-rc.3, postcss-selector-parser@^5.0.0-rc.4: + version "5.0.0" + resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz#249044356697b33b64f1a8f7c80922dddee7195c" + integrity sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ== + dependencies: + cssesc "^2.0.0" + indexes-of "^1.0.1" + uniq "^1.0.1" + +postcss-selector-parser@^6.0.0, postcss-selector-parser@^6.0.2: + version "6.0.4" + resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.4.tgz#56075a1380a04604c38b063ea7767a129af5c2b3" + integrity sha512-gjMeXBempyInaBqpp8gODmwZ52WaYsVOsfr4L4lDQ7n3ncD6mEyySiDtgzCT+NYC0mmeOLvtsF8iaEf0YT6dBw== + dependencies: + cssesc "^3.0.0" + indexes-of "^1.0.1" + uniq "^1.0.1" + util-deprecate "^1.0.2" + +postcss-svgo@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/postcss-svgo/-/postcss-svgo-4.0.2.tgz#17b997bc711b333bab143aaed3b8d3d6e3d38258" + integrity sha512-C6wyjo3VwFm0QgBy+Fu7gCYOkCmgmClghO+pjcxvrcBKtiKt0uCF+hvbMO1fyv5BMImRK90SMb+dwUnfbGd+jw== + dependencies: + is-svg "^3.0.0" + postcss "^7.0.0" + postcss-value-parser "^3.0.0" + svgo "^1.0.0" + +postcss-unique-selectors@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/postcss-unique-selectors/-/postcss-unique-selectors-4.0.1.tgz#9446911f3289bfd64c6d680f073c03b1f9ee4bac" + integrity sha512-+JanVaryLo9QwZjKrmJgkI4Fn8SBgRO6WXQBJi7KiAVPlmxikB5Jzc4EvXMT2H0/m0RjrVVm9rGNhZddm/8Spg== + dependencies: + alphanum-sort "^1.0.0" + postcss "^7.0.0" + uniqs "^2.0.0" + +postcss-value-parser@^3.0.0: + version "3.3.1" + resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz#9ff822547e2893213cf1c30efa51ac5fd1ba8281" + integrity sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ== + +postcss-value-parser@^4.0.2, postcss-value-parser@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.1.0.tgz#443f6a20ced6481a2bda4fa8532a6e55d789a2cb" + integrity sha512-97DXOFbQJhk71ne5/Mt6cOu6yxsSfM0QGQyl0L25Gca4yGWEGJaig7l7gbCX623VqTBNGLRLaVUCnNkcedlRSQ== + +postcss-values-parser@^2.0.0, postcss-values-parser@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/postcss-values-parser/-/postcss-values-parser-2.0.1.tgz#da8b472d901da1e205b47bdc98637b9e9e550e5f" + integrity sha512-2tLuBsA6P4rYTNKCXYG/71C7j1pU6pK503suYOmn4xYrQIzW+opD+7FAFNuGSdZC/3Qfy334QbeMu7MEb8gOxg== + dependencies: + flatten "^1.0.2" + indexes-of "^1.0.1" + uniq "^1.0.1" + +postcss@7.0.21: + version "7.0.21" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-7.0.21.tgz#06bb07824c19c2021c5d056d5b10c35b989f7e17" + integrity sha512-uIFtJElxJo29QC753JzhidoAhvp/e/Exezkdhfmt8AymWT6/5B7W1WmponYWkHk2eg6sONyTch0A3nkMPun3SQ== + dependencies: + chalk "^2.4.2" + source-map "^0.6.1" + supports-color "^6.1.0" + +postcss@^7, postcss@^7.0.0, postcss@^7.0.1, postcss@^7.0.14, postcss@^7.0.17, postcss@^7.0.2, postcss@^7.0.26, postcss@^7.0.27, postcss@^7.0.32, postcss@^7.0.5, postcss@^7.0.6: + version "7.0.35" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-7.0.35.tgz#d2be00b998f7f211d8a276974079f2e92b970e24" + integrity sha512-3QT8bBJeX/S5zKTTjTCIjRF3If4avAT6kqxcASlTWEtAFCb9NH0OUxNDfgZSWdP5fJnBYCMEWkIFfWeugjzYMg== + dependencies: + chalk "^2.4.2" + source-map "^0.6.1" + supports-color "^6.1.0" + +postcss@^8.1.0: + version "8.2.8" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.2.8.tgz#0b90f9382efda424c4f0f69a2ead6f6830d08ece" + integrity sha512-1F0Xb2T21xET7oQV9eKuctbM9S7BC0fetoHCc4H13z0PT6haiRLP4T0ZY4XWh7iLP0usgqykT6p9B2RtOf4FPw== + dependencies: + colorette "^1.2.2" + nanoid "^3.1.20" + source-map "^0.6.1" + +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prelude-ls@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" + integrity sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ= + +prepend-http@^1.0.0: + version "1.0.4" + resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-1.0.4.tgz#d4f4562b0ce3696e41ac52d0e002e57a635dc6dc" + integrity sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw= + +pretty-bytes@^5.3.0: + version "5.6.0" + resolved "https://registry.yarnpkg.com/pretty-bytes/-/pretty-bytes-5.6.0.tgz#356256f643804773c82f64723fe78c92c62beaeb" + integrity sha512-FFw039TmrBqFK8ma/7OL3sDz/VytdtJr044/QUJtH0wK9lb9jLq9tJyIxUwtQJHwar2BqtiA4iCWSwo9JLkzFg== + +pretty-error@^2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-2.1.2.tgz#be89f82d81b1c86ec8fdfbc385045882727f93b6" + integrity sha512-EY5oDzmsX5wvuynAByrmY0P0hcp+QpnAKbJng2A2MPjVKXCxrDSUkzghVJ4ZGPIv+JC4gX8fPUWscC0RtjsWGw== + dependencies: + lodash "^4.17.20" + renderkid "^2.0.4" + +pretty-format@^26.0.0, pretty-format@^26.6.0, pretty-format@^26.6.2: + version "26.6.2" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-26.6.2.tgz#e35c2705f14cb7fe2fe94fa078345b444120fc93" + integrity sha512-7AeGuCYNGmycyQbCqd/3PWH4eOoX/OiCa0uphp57NVTeAGdJGaAliecxwBDHYQCIvrW7aDBZCYeNTP/WX69mkg== + dependencies: + "@jest/types" "^26.6.2" + ansi-regex "^5.0.0" + ansi-styles "^4.0.0" + react-is "^17.0.1" + +process-nextick-args@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" + integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== + +process@^0.11.10: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + integrity sha1-czIwDoQBYb2j5podHZGn1LwW8YI= + +progress@^2.0.0: + version "2.0.3" + resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" + integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== + +promise-inflight@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" + integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM= + +promise@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/promise/-/promise-8.1.0.tgz#697c25c3dfe7435dd79fcd58c38a135888eaf05e" + integrity sha512-W04AqnILOL/sPRXziNicCjSNRruLAuIHEOVBazepu0545DDNGYHz7ar9ZgZ1fMU8/MA4mVxp5rkBWRi6OXIy3Q== + dependencies: + asap "~2.0.6" + +prompts@2.4.0, prompts@^2.0.1: + version "2.4.0" + resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.4.0.tgz#4aa5de0723a231d1ee9121c40fdf663df73f61d7" + integrity sha512-awZAKrk3vN6CroQukBL+R9051a4R3zCZBlJm/HBfrSZ8iTpYix3VX1vU4mveiLpiwmOJT4wokTF9m6HUk4KqWQ== + dependencies: + kleur "^3.0.3" + sisteransi "^1.0.5" + +prop-types@^15.5.4, prop-types@^15.6.2, prop-types@^15.7.2: + version "15.7.2" + resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz#52c41e75b8c87e72b9d9360e0206b99dcbffa6c5" + integrity sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ== + dependencies: + loose-envify "^1.4.0" + object-assign "^4.1.1" + react-is "^16.8.1" + +proxy-addr@~2.0.5: + version "2.0.6" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.6.tgz#fdc2336505447d3f2f2c638ed272caf614bbb2bf" + integrity sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw== + dependencies: + forwarded "~0.1.2" + ipaddr.js "1.9.1" + +prr@~1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/prr/-/prr-1.0.1.tgz#d3fc114ba06995a45ec6893f484ceb1d78f5f476" + integrity sha1-0/wRS6BplaRexok/SEzrHXj19HY= + +psl@^1.1.28, psl@^1.1.33: + version "1.8.0" + resolved "https://registry.yarnpkg.com/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24" + integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ== + +public-encrypt@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" + integrity sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q== + dependencies: + bn.js "^4.1.0" + browserify-rsa "^4.0.0" + create-hash "^1.1.0" + parse-asn1 "^5.0.0" + randombytes "^2.0.1" + safe-buffer "^5.1.2" + +pump@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/pump/-/pump-2.0.1.tgz#12399add6e4cf7526d973cbc8b5ce2e2908b3909" + integrity sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA== + dependencies: + end-of-stream "^1.1.0" + once "^1.3.1" + +pump@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" + integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== + dependencies: + end-of-stream "^1.1.0" + once "^1.3.1" + +pumpify@^1.3.3: + version "1.5.1" + resolved "https://registry.yarnpkg.com/pumpify/-/pumpify-1.5.1.tgz#36513be246ab27570b1a374a5ce278bfd74370ce" + integrity sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ== + dependencies: + duplexify "^3.6.0" + inherits "^2.0.3" + pump "^2.0.0" + +punycode@1.3.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" + integrity sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0= + +punycode@^1.2.4: + version "1.4.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" + integrity sha1-wNWmOycYgArY4esPpSachN1BhF4= + +punycode@^2.1.0, punycode@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" + integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + +q@^1.1.2: + version "1.5.1" + resolved "https://registry.yarnpkg.com/q/-/q-1.5.1.tgz#7e32f75b41381291d04611f1bf14109ac00651d7" + integrity sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc= + +qs@6.7.0: + version "6.7.0" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.7.0.tgz#41dc1a015e3d581f1621776be31afb2876a9b1bc" + integrity sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ== + +qs@~6.5.2: + version "6.5.2" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.2.tgz#cb3ae806e8740444584ef154ce8ee98d403f3e36" + integrity sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA== + +query-string@^4.1.0: + version "4.3.4" + resolved "https://registry.yarnpkg.com/query-string/-/query-string-4.3.4.tgz#bbb693b9ca915c232515b228b1a02b609043dbeb" + integrity sha1-u7aTucqRXCMlFbIosaArYJBD2+s= + dependencies: + object-assign "^4.1.0" + strict-uri-encode "^1.0.0" + +querystring-es3@^0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" + integrity sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM= + +querystring@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620" + integrity sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA= + +querystring@^0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.1.tgz#40d77615bb09d16902a85c3e38aa8b5ed761c2dd" + integrity sha512-wkvS7mL/JMugcup3/rMitHmd9ecIGd2lhFhK9N3UUQ450h66d1r3Y9nvXzQAW1Lq+wyx61k/1pfKS5KuKiyEbg== + +querystringify@^2.1.1: + version "2.2.0" + resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" + integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== + +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + +raf@^3.4.1: + version "3.4.1" + resolved "https://registry.yarnpkg.com/raf/-/raf-3.4.1.tgz#0742e99a4a6552f445d73e3ee0328af0ff1ede39" + integrity sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA== + dependencies: + performance-now "^2.1.0" + +randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5, randombytes@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" + integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== + dependencies: + safe-buffer "^5.1.0" + +randomfill@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" + integrity sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw== + dependencies: + randombytes "^2.0.5" + safe-buffer "^5.1.0" + +range-parser@^1.2.1, range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +raw-body@2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.0.tgz#a1ce6fb9c9bc356ca52e89256ab59059e13d0332" + integrity sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q== + dependencies: + bytes "3.1.0" + http-errors "1.7.2" + iconv-lite "0.4.24" + unpipe "1.0.0" + +raw-loader@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/raw-loader/-/raw-loader-4.0.2.tgz#1aac6b7d1ad1501e66efdac1522c73e59a584eb6" + integrity sha512-ZnScIV3ag9A4wPX/ZayxL/jZH+euYb6FcUinPcgiQW0+UBtEv0O6Q3lGd3cqJ+GHH+rksEv3Pj99oxJ3u3VIKA== + dependencies: + loader-utils "^2.0.0" + schema-utils "^3.0.0" + +react-app-polyfill@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/react-app-polyfill/-/react-app-polyfill-2.0.0.tgz#a0bea50f078b8a082970a9d853dc34b6dcc6a3cf" + integrity sha512-0sF4ny9v/B7s6aoehwze9vJNWcmCemAUYBVasscVr92+UYiEqDXOxfKjXN685mDaMRNF3WdhHQs76oTODMocFA== + dependencies: + core-js "^3.6.5" + object-assign "^4.1.1" + promise "^8.1.0" + raf "^3.4.1" + regenerator-runtime "^0.13.7" + whatwg-fetch "^3.4.1" + +react-deep-force-update@^2.1.1: + version "2.1.3" + resolved "https://registry.yarnpkg.com/react-deep-force-update/-/react-deep-force-update-2.1.3.tgz#740612322e617bcced38f61794a4af75dc3d98e7" + integrity sha512-lqD4eHKVuB65RyO/hGbEST53E2/GPbcIPcFYyeW/p4vNngtH4G7jnKGlU6u1OqrFo0uNfIvwuBOg98IbLHlNEA== + +react-dev-utils@^11.0.3: + version "11.0.4" + resolved "https://registry.yarnpkg.com/react-dev-utils/-/react-dev-utils-11.0.4.tgz#a7ccb60257a1ca2e0efe7a83e38e6700d17aa37a" + integrity sha512-dx0LvIGHcOPtKbeiSUM4jqpBl3TcY7CDjZdfOIcKeznE7BWr9dg0iPG90G5yfVQ+p/rGNMXdbfStvzQZEVEi4A== + dependencies: + "@babel/code-frame" "7.10.4" + address "1.1.2" + browserslist "4.14.2" + chalk "2.4.2" + cross-spawn "7.0.3" + detect-port-alt "1.1.6" + escape-string-regexp "2.0.0" + filesize "6.1.0" + find-up "4.1.0" + fork-ts-checker-webpack-plugin "4.1.6" + global-modules "2.0.0" + globby "11.0.1" + gzip-size "5.1.1" + immer "8.0.1" + is-root "2.1.0" + loader-utils "2.0.0" + open "^7.0.2" + pkg-up "3.1.0" + prompts "2.4.0" + react-error-overlay "^6.0.9" + recursive-readdir "2.2.2" + shell-quote "1.7.2" + strip-ansi "6.0.0" + text-table "0.2.0" + +react-dom@^17.0.1: + version "17.0.2" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-17.0.2.tgz#ecffb6845e3ad8dbfcdc498f0d0a939736502c23" + integrity sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + scheduler "^0.20.2" + +react-error-overlay@^6.0.9: + version "6.0.9" + resolved "https://registry.yarnpkg.com/react-error-overlay/-/react-error-overlay-6.0.9.tgz#3c743010c9359608c375ecd6bc76f35d93995b0a" + integrity sha512-nQTTcUu+ATDbrSD1BZHr5kgSD4oF8OFjxun8uAaL8RwPBacGBNPf/yAuVVdx17N8XNzRDMrZ9XcKZHCjPW+9ew== + +react-fast-compare@^3.1.1: + version "3.2.0" + resolved "https://registry.yarnpkg.com/react-fast-compare/-/react-fast-compare-3.2.0.tgz#641a9da81b6a6320f270e89724fb45a0b39e43bb" + integrity sha512-rtGImPZ0YyLrscKI9xTpV8psd6I8VAtjKCzQDlzyDvqJA8XOW78TXYQwNRNd8g8JZnDu8q9Fu/1v4HPAVwVdHA== + +react-helmet@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/react-helmet/-/react-helmet-6.1.0.tgz#a750d5165cb13cf213e44747502652e794468726" + integrity sha512-4uMzEY9nlDlgxr61NL3XbKRy1hEkXmKNXhjbAIOVw5vcFrsdYbH2FEwcNyWvWinl103nXgzYNlns9ca+8kFiWw== + dependencies: + object-assign "^4.1.1" + prop-types "^15.7.2" + react-fast-compare "^3.1.1" + react-side-effect "^2.1.0" + +react-hot-loader@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/react-hot-loader/-/react-hot-loader-3.1.3.tgz#6f92877326958c7cb0134b512474517869126082" + integrity sha512-d7nZf78irxoGN5PY4zd6CSgZiroOhvIWzRast3qwTn4sSnBwlt08kV8WMQ9mitmxEdlCTwZt+5ClrRSjxWguMQ== + dependencies: + global "^4.3.0" + react-deep-force-update "^2.1.1" + react-proxy "^3.0.0-alpha.0" + redbox-react "^1.3.6" + source-map "^0.6.1" + +react-is@^16.6.0, react-is@^16.7.0, react-is@^16.8.1: + version "16.13.1" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" + integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== + +react-is@^17.0.1: + version "17.0.2" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0" + integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w== + +react-keyhooks@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/react-keyhooks/-/react-keyhooks-0.1.2.tgz#528a6da8d31b060cd8560b4f7429b42b542677bf" + integrity sha512-4DpTyZQy9Q1cKtVBhllNJjdazaX0DWYuWRmTa2O/nww643q/mcpFhmsUu6dCGx73yO5fmNlVLd3uUhNtUYsWSA== + dependencies: + "@types/react" "^17.0.2" + react "^17.0.1" + +react-proxy@^3.0.0-alpha.0: + version "3.0.0-alpha.1" + resolved "https://registry.yarnpkg.com/react-proxy/-/react-proxy-3.0.0-alpha.1.tgz#4400426bcfa80caa6724c7755695315209fa4b07" + integrity sha1-RABCa8+oDKpnJMd1VpUxUgn6Swc= + dependencies: + lodash "^4.6.1" + +react-refresh@^0.8.3: + version "0.8.3" + resolved "https://registry.yarnpkg.com/react-refresh/-/react-refresh-0.8.3.tgz#721d4657672d400c5e3c75d063c4a85fb2d5d68f" + integrity sha512-X8jZHc7nCMjaCqoU+V2I0cOhNW+QMBwSUkeXnTi8IPe6zaRWfn60ZzvFDZqWPfmSJfjub7dDW1SP0jaHWLu/hg== + +react-router-dom@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/react-router-dom/-/react-router-dom-5.2.0.tgz#9e65a4d0c45e13289e66c7b17c7e175d0ea15662" + integrity sha512-gxAmfylo2QUjcwxI63RhQ5G85Qqt4voZpUXSEqCwykV0baaOTQDR1f0PmY8AELqIyVc0NEZUj0Gov5lNGcXgsA== + dependencies: + "@babel/runtime" "^7.1.2" + history "^4.9.0" + loose-envify "^1.3.1" + prop-types "^15.6.2" + react-router "5.2.0" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + +react-router@5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/react-router/-/react-router-5.2.0.tgz#424e75641ca8747fbf76e5ecca69781aa37ea293" + integrity sha512-smz1DUuFHRKdcJC0jobGo8cVbhO3x50tCL4icacOlcwDOEQPq4TMqwx3sY1TP+DvtTgz4nm3thuo7A+BK2U0Dw== + dependencies: + "@babel/runtime" "^7.1.2" + history "^4.9.0" + hoist-non-react-statics "^3.1.0" + loose-envify "^1.3.1" + mini-create-react-context "^0.4.0" + path-to-regexp "^1.7.0" + prop-types "^15.6.2" + react-is "^16.6.0" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + +react-scripts@4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/react-scripts/-/react-scripts-4.0.3.tgz#b1cafed7c3fa603e7628ba0f187787964cb5d345" + integrity sha512-S5eO4vjUzUisvkIPB7jVsKtuH2HhWcASREYWHAQ1FP5HyCv3xgn+wpILAEWkmy+A+tTNbSZClhxjT3qz6g4L1A== + dependencies: + "@babel/core" "7.12.3" + "@pmmmwh/react-refresh-webpack-plugin" "0.4.3" + "@svgr/webpack" "5.5.0" + "@typescript-eslint/eslint-plugin" "^4.5.0" + "@typescript-eslint/parser" "^4.5.0" + babel-eslint "^10.1.0" + babel-jest "^26.6.0" + babel-loader "8.1.0" + babel-plugin-named-asset-import "^0.3.7" + babel-preset-react-app "^10.0.0" + bfj "^7.0.2" + camelcase "^6.1.0" + case-sensitive-paths-webpack-plugin "2.3.0" + css-loader "4.3.0" + dotenv "8.2.0" + dotenv-expand "5.1.0" + eslint "^7.11.0" + eslint-config-react-app "^6.0.0" + eslint-plugin-flowtype "^5.2.0" + eslint-plugin-import "^2.22.1" + eslint-plugin-jest "^24.1.0" + eslint-plugin-jsx-a11y "^6.3.1" + eslint-plugin-react "^7.21.5" + eslint-plugin-react-hooks "^4.2.0" + eslint-plugin-testing-library "^3.9.2" + eslint-webpack-plugin "^2.5.2" + file-loader "6.1.1" + fs-extra "^9.0.1" + html-webpack-plugin "4.5.0" + identity-obj-proxy "3.0.0" + jest "26.6.0" + jest-circus "26.6.0" + jest-resolve "26.6.0" + jest-watch-typeahead "0.6.1" + mini-css-extract-plugin "0.11.3" + optimize-css-assets-webpack-plugin "5.0.4" + pnp-webpack-plugin "1.6.4" + postcss-flexbugs-fixes "4.2.1" + postcss-loader "3.0.0" + postcss-normalize "8.0.1" + postcss-preset-env "6.7.0" + postcss-safe-parser "5.0.2" + prompts "2.4.0" + react-app-polyfill "^2.0.0" + react-dev-utils "^11.0.3" + react-refresh "^0.8.3" + resolve "1.18.1" + resolve-url-loader "^3.1.2" + sass-loader "^10.0.5" + semver "7.3.2" + style-loader "1.3.0" + terser-webpack-plugin "4.2.3" + ts-pnp "1.2.0" + url-loader "4.1.1" + webpack "4.44.2" + webpack-dev-server "3.11.1" + webpack-manifest-plugin "2.2.0" + workbox-webpack-plugin "5.1.4" + optionalDependencies: + fsevents "^2.1.3" + +react-side-effect@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/react-side-effect/-/react-side-effect-2.1.1.tgz#66c5701c3e7560ab4822a4ee2742dee215d72eb3" + integrity sha512-2FoTQzRNTncBVtnzxFOk2mCpcfxQpenBMbk5kSVBg5UcPqV9fRbgY2zhb7GTWWOlpFmAxhClBDlIq8Rsubz1yQ== + +react@^17.0.1: + version "17.0.2" + resolved "https://registry.yarnpkg.com/react/-/react-17.0.2.tgz#d0b5cc516d29eb3eee383f75b62864cfb6800037" + integrity sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + +read-pkg-up@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz#6b72a8048984e0c41e79510fd5e9fa99b3b549be" + integrity sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4= + dependencies: + find-up "^2.0.0" + read-pkg "^2.0.0" + +read-pkg-up@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-7.0.1.tgz#f3a6135758459733ae2b95638056e1854e7ef507" + integrity sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg== + dependencies: + find-up "^4.1.0" + read-pkg "^5.2.0" + type-fest "^0.8.1" + +read-pkg@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-2.0.0.tgz#8ef1c0623c6a6db0dc6713c4bfac46332b2368f8" + integrity sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg= + dependencies: + load-json-file "^2.0.0" + normalize-package-data "^2.3.2" + path-type "^2.0.0" + +read-pkg@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-5.2.0.tgz#7bf295438ca5a33e56cd30e053b34ee7250c93cc" + integrity sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg== + dependencies: + "@types/normalize-package-data" "^2.4.0" + normalize-package-data "^2.5.0" + parse-json "^5.0.0" + type-fest "^0.6.0" + +"readable-stream@1 || 2", readable-stream@^2.0.0, readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.1.5, readable-stream@^2.2.2, readable-stream@^2.3.3, readable-stream@^2.3.6, readable-stream@~2.3.6: + version "2.3.7" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" + integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.3" + isarray "~1.0.0" + process-nextick-args "~2.0.0" + safe-buffer "~5.1.1" + string_decoder "~1.1.1" + util-deprecate "~1.0.1" + +readable-stream@^3.0.6, readable-stream@^3.1.1, readable-stream@^3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" + integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== + dependencies: + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" + +readdirp@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.2.1.tgz#0e87622a3325aa33e892285caf8b4e846529a525" + integrity sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ== + dependencies: + graceful-fs "^4.1.11" + micromatch "^3.1.10" + readable-stream "^2.0.2" + +readdirp@~3.5.0: + version "3.5.0" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.5.0.tgz#9ba74c019b15d365278d2e91bb8c48d7b4d42c9e" + integrity sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ== + dependencies: + picomatch "^2.2.1" + +rechoir@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/rechoir/-/rechoir-0.7.0.tgz#32650fd52c21ab252aa5d65b19310441c7e03aca" + integrity sha512-ADsDEH2bvbjltXEP+hTIAmeFekTFK0V2BTxMkok6qILyAJEXV0AFfoWcAq4yfll5VdIMd/RVXq0lR+wQi5ZU3Q== + dependencies: + resolve "^1.9.0" + +recursive-readdir@2.2.2: + version "2.2.2" + resolved "https://registry.yarnpkg.com/recursive-readdir/-/recursive-readdir-2.2.2.tgz#9946fb3274e1628de6e36b2f6714953b4845094f" + integrity sha512-nRCcW9Sj7NuZwa2XvH9co8NPeXUBhZP7CRKJtU+cS6PW9FpCIFoI5ib0NT1ZrbNuPoRy0ylyCaUL8Gih4LSyFg== + dependencies: + minimatch "3.0.4" + +redbox-react@^1.3.6: + version "1.6.0" + resolved "https://registry.yarnpkg.com/redbox-react/-/redbox-react-1.6.0.tgz#e753ac02595bc1bf695b3935889a4f5b1b5a21a1" + integrity sha512-mLjM5eYR41yOp5YKHpd3syFeGq6B4Wj5vZr64nbLvTZW5ZLff4LYk7VE4ITpVxkZpCY6OZuqh0HiP3A3uEaCpg== + dependencies: + error-stack-parser "^1.3.6" + object-assign "^4.0.1" + prop-types "^15.5.4" + sourcemapped-stacktrace "^1.1.6" + +redent@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/redent/-/redent-3.0.0.tgz#e557b7998316bb53c9f1f56fa626352c6963059f" + integrity sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg== + dependencies: + indent-string "^4.0.0" + strip-indent "^3.0.0" + +regenerate-unicode-properties@^8.2.0: + version "8.2.0" + resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-8.2.0.tgz#e5de7111d655e7ba60c057dbe9ff37c87e65cdec" + integrity sha512-F9DjY1vKLo/tPePDycuH3dn9H1OTPIkVD9Kz4LODu+F2C75mgjAJ7x/gwy6ZcSNRAAkhNlJSOHRe8k3p+K9WhA== + dependencies: + regenerate "^1.4.0" + +regenerate@^1.4.0: + version "1.4.2" + resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" + integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== + +regenerator-runtime@^0.11.0: + version "0.11.1" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz#be05ad7f9bf7d22e056f9726cee5017fbf19e2e9" + integrity sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg== + +regenerator-runtime@^0.13.4, regenerator-runtime@^0.13.7: + version "0.13.7" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz#cac2dacc8a1ea675feaabaeb8ae833898ae46f55" + integrity sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew== + +regenerator-transform@^0.14.2: + version "0.14.5" + resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.14.5.tgz#c98da154683671c9c4dcb16ece736517e1b7feb4" + integrity sha512-eOf6vka5IO151Jfsw2NO9WpGX58W6wWmefK3I1zEGr0lOD0u8rwPaNqQL1aRxUaxLeKO3ArNh3VYg1KbaD+FFw== + dependencies: + "@babel/runtime" "^7.8.4" + +regex-not@^1.0.0, regex-not@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c" + integrity sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A== + dependencies: + extend-shallow "^3.0.2" + safe-regex "^1.1.0" + +regex-parser@^2.2.11: + version "2.2.11" + resolved "https://registry.yarnpkg.com/regex-parser/-/regex-parser-2.2.11.tgz#3b37ec9049e19479806e878cabe7c1ca83ccfe58" + integrity sha512-jbD/FT0+9MBU2XAZluI7w2OBs1RBi6p9M83nkoZayQXXU9e8Robt69FcZc7wU4eJD/YFTjn1JdCk3rbMJajz8Q== + +regexp.prototype.flags@^1.2.0, regexp.prototype.flags@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.3.1.tgz#7ef352ae8d159e758c0eadca6f8fcb4eef07be26" + integrity sha512-JiBdRBq91WlY7uRJ0ds7R+dU02i6LKi8r3BuQhNXn+kmeLN+EfHhfjqMRis1zJxnlu88hq/4dx0P2OP3APRTOA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + +regexpp@^3.0.0, regexpp@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.1.0.tgz#206d0ad0a5648cffbdb8ae46438f3dc51c9f78e2" + integrity sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q== + +regexpu-core@^4.7.1: + version "4.7.1" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-4.7.1.tgz#2dea5a9a07233298fbf0db91fa9abc4c6e0f8ad6" + integrity sha512-ywH2VUraA44DZQuRKzARmw6S66mr48pQVva4LBeRhcOltJ6hExvWly5ZjFLYo67xbIxb6W1q4bAGtgfEl20zfQ== + dependencies: + regenerate "^1.4.0" + regenerate-unicode-properties "^8.2.0" + regjsgen "^0.5.1" + regjsparser "^0.6.4" + unicode-match-property-ecmascript "^1.0.4" + unicode-match-property-value-ecmascript "^1.2.0" + +regjsgen@^0.5.1: + version "0.5.2" + resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.5.2.tgz#92ff295fb1deecbf6ecdab2543d207e91aa33733" + integrity sha512-OFFT3MfrH90xIW8OOSyUrk6QHD5E9JOTeGodiJeBS3J6IwlgzJMNE/1bZklWz5oTg+9dCMyEetclvCVXOPoN3A== + +regjsparser@^0.6.4: + version "0.6.9" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.6.9.tgz#b489eef7c9a2ce43727627011429cf833a7183e6" + integrity sha512-ZqbNRz1SNjLAiYuwY0zoXW8Ne675IX5q+YHioAGbCw4X96Mjl2+dcX9B2ciaeyYjViDAfvIjFpQjJgLttTEERQ== + dependencies: + jsesc "~0.5.0" + +relateurl@^0.2.7: + version "0.2.7" + resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9" + integrity sha1-VNvzd+UUQKypCkzSdGANP/LYiKk= + +remove-trailing-separator@^1.0.1: + version "1.1.0" + resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" + integrity sha1-wkvOKig62tW8P1jg1IJJuSN52O8= + +renderkid@^2.0.4: + version "2.0.5" + resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-2.0.5.tgz#483b1ac59c6601ab30a7a596a5965cabccfdd0a5" + integrity sha512-ccqoLg+HLOHq1vdfYNm4TBeaCDIi1FLt3wGojTDSvdewUv65oTmI3cnT2E4hRjl1gzKZIPK+KZrXzlUYKnR+vQ== + dependencies: + css-select "^2.0.2" + dom-converter "^0.2" + htmlparser2 "^3.10.1" + lodash "^4.17.20" + strip-ansi "^3.0.0" + +repeat-element@^1.1.2: + version "1.1.3" + resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz#782e0d825c0c5a3bb39731f84efee6b742e6b1ce" + integrity sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g== + +repeat-string@^1.6.1: + version "1.6.1" + resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" + integrity sha1-jcrkcOHIirwtYA//Sndihtp15jc= + +request-promise-core@1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/request-promise-core/-/request-promise-core-1.1.4.tgz#3eedd4223208d419867b78ce815167d10593a22f" + integrity sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw== + dependencies: + lodash "^4.17.19" + +request-promise-native@^1.0.9: + version "1.0.9" + resolved "https://registry.yarnpkg.com/request-promise-native/-/request-promise-native-1.0.9.tgz#e407120526a5efdc9a39b28a5679bf47b9d9dc28" + integrity sha512-wcW+sIUiWnKgNY0dqCpOZkUbF/I+YPi+f09JZIDa39Ec+q82CpSYniDp+ISgTTbKmnpJWASeJBPZmoxH84wt3g== + dependencies: + request-promise-core "1.1.4" + stealthy-require "^1.1.1" + tough-cookie "^2.3.3" + +request@^2.88.2: + version "2.88.2" + resolved "https://registry.yarnpkg.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3" + integrity sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw== + dependencies: + aws-sign2 "~0.7.0" + aws4 "^1.8.0" + caseless "~0.12.0" + combined-stream "~1.0.6" + extend "~3.0.2" + forever-agent "~0.6.1" + form-data "~2.3.2" + har-validator "~5.1.3" + http-signature "~1.2.0" + is-typedarray "~1.0.0" + isstream "~0.1.2" + json-stringify-safe "~5.0.1" + mime-types "~2.1.19" + oauth-sign "~0.9.0" + performance-now "^2.1.0" + qs "~6.5.2" + safe-buffer "^5.1.2" + tough-cookie "~2.5.0" + tunnel-agent "^0.6.0" + uuid "^3.3.2" + +require-directory@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" + integrity sha1-jGStX9MNqxyXbiNE/+f3kqam30I= + +require-from-string@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" + integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== + +require-main-filename@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b" + integrity sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg== + +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" + integrity sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8= + +resolve-cwd@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/resolve-cwd/-/resolve-cwd-2.0.0.tgz#00a9f7387556e27038eae232caa372a6a59b665a" + integrity sha1-AKn3OHVW4nA46uIyyqNypqWbZlo= + dependencies: + resolve-from "^3.0.0" + +resolve-cwd@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-cwd/-/resolve-cwd-3.0.0.tgz#0f0075f1bb2544766cf73ba6a6e2adfebcb13f2d" + integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== + dependencies: + resolve-from "^5.0.0" + +resolve-from@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748" + integrity sha1-six699nWiBvItuZTM17rywoYh0g= + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve-from@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69" + integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== + +resolve-pathname@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-pathname/-/resolve-pathname-3.0.0.tgz#99d02224d3cf263689becbb393bc560313025dcd" + integrity sha512-C7rARubxI8bXFNB/hqcp/4iUeIXJhJZvFPFPiSPRnhU5UPxzMFIl+2E6yY6c4k9giDJAhtV+enfA+G89N6Csng== + +resolve-url-loader@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/resolve-url-loader/-/resolve-url-loader-3.1.2.tgz#235e2c28e22e3e432ba7a5d4e305c59a58edfc08" + integrity sha512-QEb4A76c8Mi7I3xNKXlRKQSlLBwjUV/ULFMP+G7n3/7tJZ8MG5wsZ3ucxP1Jz8Vevn6fnJsxDx9cIls+utGzPQ== + dependencies: + adjust-sourcemap-loader "3.0.0" + camelcase "5.3.1" + compose-function "3.0.3" + convert-source-map "1.7.0" + es6-iterator "2.0.3" + loader-utils "1.2.3" + postcss "7.0.21" + rework "1.0.1" + rework-visit "1.0.0" + source-map "0.6.1" + +resolve-url@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" + integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo= + +resolve@1.18.1: + version "1.18.1" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.18.1.tgz#018fcb2c5b207d2a6424aee361c5a266da8f4130" + integrity sha512-lDfCPaMKfOJXjy0dPayzPdF1phampNWr3qFCjAu+rw/qbQmr5jWH5xN2hwh9QKfw9E5v4hwV7A+jrCmL8yjjqA== + dependencies: + is-core-module "^2.0.0" + path-parse "^1.0.6" + +resolve@^1.10.0, resolve@^1.12.0, resolve@^1.13.1, resolve@^1.14.2, resolve@^1.17.0, resolve@^1.18.1, resolve@^1.3.2, resolve@^1.8.1, resolve@^1.9.0: + version "1.20.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975" + integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A== + dependencies: + is-core-module "^2.2.0" + path-parse "^1.0.6" + +resolve@^2.0.0-next.3: + version "2.0.0-next.3" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-2.0.0-next.3.tgz#d41016293d4a8586a39ca5d9b5f15cbea1f55e46" + integrity sha512-W8LucSynKUIDu9ylraa7ueVZ7hc0uAgJBxVsQSKOXOyle8a93qXhcz+XAXZ8bIq2d6i4Ehddn6Evt+0/UwKk6Q== + dependencies: + is-core-module "^2.2.0" + path-parse "^1.0.6" + +ret@~0.1.10: + version "0.1.15" + resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc" + integrity sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg== + +retry@^0.12.0: + version "0.12.0" + resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" + integrity sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs= + +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +rework-visit@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/rework-visit/-/rework-visit-1.0.0.tgz#9945b2803f219e2f7aca00adb8bc9f640f842c9a" + integrity sha1-mUWygD8hni96ygCtuLyfZA+ELJo= + +rework@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/rework/-/rework-1.0.1.tgz#30806a841342b54510aa4110850cd48534144aa7" + integrity sha1-MIBqhBNCtUUQqkEQhQzUhTQUSqc= + dependencies: + convert-source-map "^0.3.3" + css "^2.0.0" + +rgb-regex@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/rgb-regex/-/rgb-regex-1.0.1.tgz#c0e0d6882df0e23be254a475e8edd41915feaeb1" + integrity sha1-wODWiC3w4jviVKR16O3UGRX+rrE= + +rgba-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/rgba-regex/-/rgba-regex-1.0.0.tgz#43374e2e2ca0968b0ef1523460b7d730ff22eeb3" + integrity sha1-QzdOLiyglosO8VI0YLfXMP8i7rM= + +rimraf@^2.5.4, rimraf@^2.6.3: + version "2.7.1" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" + integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== + dependencies: + glob "^7.1.3" + +rimraf@^3.0.0, rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +ripemd160@^2.0.0, ripemd160@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c" + integrity sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + +rollup-plugin-babel@^4.3.3: + version "4.4.0" + resolved "https://registry.yarnpkg.com/rollup-plugin-babel/-/rollup-plugin-babel-4.4.0.tgz#d15bd259466a9d1accbdb2fe2fff17c52d030acb" + integrity sha512-Lek/TYp1+7g7I+uMfJnnSJ7YWoD58ajo6Oarhlex7lvUce+RCKRuGRSgztDO3/MF/PuGKmUL5iTHKf208UNszw== + dependencies: + "@babel/helper-module-imports" "^7.0.0" + rollup-pluginutils "^2.8.1" + +rollup-plugin-terser@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/rollup-plugin-terser/-/rollup-plugin-terser-5.3.1.tgz#8c650062c22a8426c64268548957463bf981b413" + integrity sha512-1pkwkervMJQGFYvM9nscrUoncPwiKR/K+bHdjv6PFgRo3cgPHoRT83y2Aa3GvINj4539S15t/tpFPb775TDs6w== + dependencies: + "@babel/code-frame" "^7.5.5" + jest-worker "^24.9.0" + rollup-pluginutils "^2.8.2" + serialize-javascript "^4.0.0" + terser "^4.6.2" + +rollup-pluginutils@^2.8.1, rollup-pluginutils@^2.8.2: + version "2.8.2" + resolved "https://registry.yarnpkg.com/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz#72f2af0748b592364dbd3389e600e5a9444a351e" + integrity sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ== + dependencies: + estree-walker "^0.6.1" + +rollup@^1.31.1: + version "1.32.1" + resolved "https://registry.yarnpkg.com/rollup/-/rollup-1.32.1.tgz#4480e52d9d9e2ae4b46ba0d9ddeaf3163940f9c4" + integrity sha512-/2HA0Ec70TvQnXdzynFffkjA6XN+1e2pEv/uKS5Ulca40g2L7KuOE3riasHoNVHOsFD5KKZgDsMk1CP3Tw9s+A== + dependencies: + "@types/estree" "*" + "@types/node" "*" + acorn "^7.1.0" + +rsvp@^4.8.4: + version "4.8.5" + resolved "https://registry.yarnpkg.com/rsvp/-/rsvp-4.8.5.tgz#c8f155311d167f68f21e168df71ec5b083113734" + integrity sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA== + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + +run-queue@^1.0.0, run-queue@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/run-queue/-/run-queue-1.0.3.tgz#e848396f057d223f24386924618e25694161ec47" + integrity sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec= + dependencies: + aproba "^1.1.1" + +rxjs@^6.6.6: + version "6.6.7" + resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-6.6.7.tgz#90ac018acabf491bf65044235d5863c4dab804c9" + integrity sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ== + dependencies: + tslib "^1.9.0" + +safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: + version "5.1.2" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + +safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@~5.2.0: + version "5.2.1" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== + +safe-regex@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" + integrity sha1-QKNmnzsHfR6UPURinhV91IAjvy4= + dependencies: + ret "~0.1.10" + +"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +sane@^4.0.3: + version "4.1.0" + resolved "https://registry.yarnpkg.com/sane/-/sane-4.1.0.tgz#ed881fd922733a6c461bc189dc2b6c006f3ffded" + integrity sha512-hhbzAgTIX8O7SHfp2c8/kREfEn4qO/9q8C9beyY6+tvZ87EpoZ3i1RIEvp27YBswnNbY9mWd6paKVmKbAgLfZA== + dependencies: + "@cnakazawa/watch" "^1.0.3" + anymatch "^2.0.0" + capture-exit "^2.0.0" + exec-sh "^0.3.2" + execa "^1.0.0" + fb-watchman "^2.0.0" + micromatch "^3.1.4" + minimist "^1.1.1" + walker "~1.0.5" + +sanitize.css@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/sanitize.css/-/sanitize.css-10.0.0.tgz#b5cb2547e96d8629a60947544665243b1dc3657a" + integrity sha512-vTxrZz4dX5W86M6oVWVdOVe72ZiPs41Oi7Z6Km4W5Turyz28mrXSJhhEBZoRtzJWIv3833WKVwLSDWWkEfupMg== + +sass-loader@^10.0.5: + version "10.1.1" + resolved "https://registry.yarnpkg.com/sass-loader/-/sass-loader-10.1.1.tgz#4ddd5a3d7638e7949065dd6e9c7c04037f7e663d" + integrity sha512-W6gVDXAd5hR/WHsPicvZdjAWHBcEJ44UahgxcIE196fW2ong0ZHMPO1kZuI5q0VlvMQZh32gpv69PLWQm70qrw== + dependencies: + klona "^2.0.4" + loader-utils "^2.0.0" + neo-async "^2.6.2" + schema-utils "^3.0.0" + semver "^7.3.2" + +sass@^1.32.8: + version "1.32.8" + resolved "https://registry.yarnpkg.com/sass/-/sass-1.32.8.tgz#f16a9abd8dc530add8834e506878a2808c037bdc" + integrity sha512-Sl6mIeGpzjIUZqvKnKETfMf0iDAswD9TNlv13A7aAF3XZlRPMq4VvJWBC2N2DXbp94MQVdNSFG6LfF/iOXrPHQ== + dependencies: + chokidar ">=2.0.0 <4.0.0" + +sax@~1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" + integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== + +saxes@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d" + integrity sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw== + dependencies: + xmlchars "^2.2.0" + +scheduler@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.20.2.tgz#4baee39436e34aa93b4874bddcbf0fe8b8b50e91" + integrity sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + +schema-utils@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-1.0.0.tgz#0b79a93204d7b600d4b2850d1f66c2a34951c770" + integrity sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g== + dependencies: + ajv "^6.1.0" + ajv-errors "^1.0.0" + ajv-keywords "^3.1.0" + +schema-utils@^2.6.5, schema-utils@^2.7.0, schema-utils@^2.7.1: + version "2.7.1" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-2.7.1.tgz#1ca4f32d1b24c590c203b8e7a50bf0ea4cd394d7" + integrity sha512-SHiNtMOUGWBQJwzISiVYKu82GiV4QYGePp3odlY1tuKO7gPtphAT5R/py0fA6xtbgLL/RvtJZnU9b8s0F1q0Xg== + dependencies: + "@types/json-schema" "^7.0.5" + ajv "^6.12.4" + ajv-keywords "^3.5.2" + +schema-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.0.0.tgz#67502f6aa2b66a2d4032b4279a2944978a0913ef" + integrity sha512-6D82/xSzO094ajanoOSbe4YvXWMfn2A//8Y1+MUqFAJul5Bs+yn36xbK9OtNDcRVSBJ9jjeoXftM6CfztsjOAA== + dependencies: + "@types/json-schema" "^7.0.6" + ajv "^6.12.5" + ajv-keywords "^3.5.2" + +select-hose@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca" + integrity sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo= + +selfsigned@^1.10.8: + version "1.10.8" + resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-1.10.8.tgz#0d17208b7d12c33f8eac85c41835f27fc3d81a30" + integrity sha512-2P4PtieJeEwVgTU9QEcwIRDQ/mXJLX8/+I3ur+Pg16nS8oNbrGxEso9NyYWy8NAmXiNl4dlAp5MwoNeCWzON4w== + dependencies: + node-forge "^0.10.0" + +"semver@2 || 3 || 4 || 5", semver@^5.4.1, semver@^5.5.0, semver@^5.5.1, semver@^5.6.0: + version "5.7.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" + integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== + +semver@7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.0.0.tgz#5f3ca35761e47e05b206c6daff2cf814f0316b8e" + integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== + +semver@7.3.2: + version "7.3.2" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.2.tgz#604962b052b81ed0786aae84389ffba70ffd3938" + integrity sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ== + +semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" + integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== + +semver@^7.2.1, semver@^7.3.2, semver@^7.3.4: + version "7.3.5" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7" + integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ== + dependencies: + lru-cache "^6.0.0" + +send@0.17.1: + version "0.17.1" + resolved "https://registry.yarnpkg.com/send/-/send-0.17.1.tgz#c1d8b059f7900f7466dd4938bdc44e11ddb376c8" + integrity sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg== + dependencies: + debug "2.6.9" + depd "~1.1.2" + destroy "~1.0.4" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "~1.7.2" + mime "1.6.0" + ms "2.1.1" + on-finished "~2.3.0" + range-parser "~1.2.1" + statuses "~1.5.0" + +serialize-javascript@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-4.0.0.tgz#b525e1238489a5ecfc42afacc3fe99e666f4b1aa" + integrity sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw== + dependencies: + randombytes "^2.1.0" + +serialize-javascript@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-5.0.1.tgz#7886ec848049a462467a97d3d918ebb2aaf934f4" + integrity sha512-SaaNal9imEO737H2c05Og0/8LUXG7EnsZyMa8MzkmuHoELfT6txuj0cMqRj6zfPKnmQ1yasR4PCJc8x+M4JSPA== + dependencies: + randombytes "^2.1.0" + +serve-index@^1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/serve-index/-/serve-index-1.9.1.tgz#d3768d69b1e7d82e5ce050fff5b453bea12a9239" + integrity sha1-03aNabHn2C5c4FD/9bRTvqEqkjk= + dependencies: + accepts "~1.3.4" + batch "0.6.1" + debug "2.6.9" + escape-html "~1.0.3" + http-errors "~1.6.2" + mime-types "~2.1.17" + parseurl "~1.3.2" + +serve-static@1.14.1: + version "1.14.1" + resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.1.tgz#666e636dc4f010f7ef29970a88a674320898b2f9" + integrity sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg== + dependencies: + encodeurl "~1.0.2" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.17.1" + +set-blocking@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" + integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= + +set-value@^2.0.0, set-value@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b" + integrity sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw== + dependencies: + extend-shallow "^2.0.1" + is-extendable "^0.1.1" + is-plain-object "^2.0.3" + split-string "^3.0.1" + +setimmediate@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" + integrity sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU= + +setprototypeof@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" + integrity sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ== + +setprototypeof@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" + integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== + +sha.js@^2.4.0, sha.js@^2.4.8: + version "2.4.11" + resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.11.tgz#37a5cf0b81ecbc6943de109ba2960d1b26584ae7" + integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +shallow-clone@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/shallow-clone/-/shallow-clone-3.0.1.tgz#8f2981ad92531f55035b01fb230769a40e02efa3" + integrity sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA== + dependencies: + kind-of "^6.0.2" + +shebang-command@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea" + integrity sha1-RKrGW2lbAzmJaMOfNj/uXer98eo= + dependencies: + shebang-regex "^1.0.0" + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" + integrity sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM= + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +shell-quote@1.7.2: + version "1.7.2" + resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.7.2.tgz#67a7d02c76c9da24f99d20808fcaded0e0e04be2" + integrity sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg== + +shellwords@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/shellwords/-/shellwords-0.1.1.tgz#d6b9181c1a48d397324c84871efbcfc73fc0654b" + integrity sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww== + +side-channel@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" + integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== + dependencies: + call-bind "^1.0.0" + get-intrinsic "^1.0.2" + object-inspect "^1.9.0" + +signal-exit@^3.0.0, signal-exit@^3.0.2, signal-exit@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c" + integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA== + +simple-swizzle@^0.2.2: + version "0.2.2" + resolved "https://registry.yarnpkg.com/simple-swizzle/-/simple-swizzle-0.2.2.tgz#a4da6b635ffcccca33f70d17cb92592de95e557a" + integrity sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo= + dependencies: + is-arrayish "^0.3.1" + +sirv@^1.0.7: + version "1.0.11" + resolved "https://registry.yarnpkg.com/sirv/-/sirv-1.0.11.tgz#81c19a29202048507d6ec0d8ba8910fda52eb5a4" + integrity sha512-SR36i3/LSWja7AJNRBz4fF/Xjpn7lQFI30tZ434dIy+bitLYSP+ZEenHg36i23V2SGEz+kqjksg0uOGZ5LPiqg== + dependencies: + "@polka/url" "^1.0.0-next.9" + mime "^2.3.1" + totalist "^1.0.0" + +sisteransi@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" + integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +slice-ansi@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b" + integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ== + dependencies: + ansi-styles "^4.0.0" + astral-regex "^2.0.0" + is-fullwidth-code-point "^3.0.0" + +snapdragon-node@^2.0.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" + integrity sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw== + dependencies: + define-property "^1.0.0" + isobject "^3.0.0" + snapdragon-util "^3.0.1" + +snapdragon-util@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz#f956479486f2acd79700693f6f7b805e45ab56e2" + integrity sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ== + dependencies: + kind-of "^3.2.0" + +snapdragon@^0.8.1: + version "0.8.2" + resolved "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz#64922e7c565b0e14204ba1aa7d6964278d25182d" + integrity sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg== + dependencies: + base "^0.11.1" + debug "^2.2.0" + define-property "^0.2.5" + extend-shallow "^2.0.1" + map-cache "^0.2.2" + source-map "^0.5.6" + source-map-resolve "^0.5.0" + use "^3.1.0" + +sockjs-client@^1.5.0: + version "1.5.1" + resolved "https://registry.yarnpkg.com/sockjs-client/-/sockjs-client-1.5.1.tgz#256908f6d5adfb94dabbdbd02c66362cca0f9ea6" + integrity sha512-VnVAb663fosipI/m6pqRXakEOw7nvd7TUgdr3PlR/8V2I95QIdwT8L4nMxhyU8SmDBHYXU1TOElaKOmKLfYzeQ== + dependencies: + debug "^3.2.6" + eventsource "^1.0.7" + faye-websocket "^0.11.3" + inherits "^2.0.4" + json3 "^3.3.3" + url-parse "^1.5.1" + +sockjs@^0.3.21: + version "0.3.21" + resolved "https://registry.yarnpkg.com/sockjs/-/sockjs-0.3.21.tgz#b34ffb98e796930b60a0cfa11904d6a339a7d417" + integrity sha512-DhbPFGpxjc6Z3I+uX07Id5ZO2XwYsWOrYjaSeieES78cq+JaJvVe5q/m1uvjIQhXinhIeCFRH6JgXe+mvVMyXw== + dependencies: + faye-websocket "^0.11.3" + uuid "^3.4.0" + websocket-driver "^0.7.4" + +sort-keys@^1.0.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/sort-keys/-/sort-keys-1.1.2.tgz#441b6d4d346798f1b4e49e8920adfba0e543f9ad" + integrity sha1-RBttTTRnmPG05J6JIK37oOVD+a0= + dependencies: + is-plain-obj "^1.0.0" + +source-list-map@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-2.0.1.tgz#3993bd873bfc48479cca9ea3a547835c7c154b34" + integrity sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw== + +source-map-resolve@^0.5.0, source-map-resolve@^0.5.2: + version "0.5.3" + resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a" + integrity sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw== + dependencies: + atob "^2.1.2" + decode-uri-component "^0.2.0" + resolve-url "^0.2.1" + source-map-url "^0.4.0" + urix "^0.1.0" + +source-map-resolve@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.6.0.tgz#3d9df87e236b53f16d01e58150fc7711138e5ed2" + integrity sha512-KXBr9d/fO/bWo97NXsPIAW1bFSBOuCnjbNTBMO7N59hsv5i9yzRDfcYwwt0l04+VqnKC+EwzvJZIP/qkuMgR/w== + dependencies: + atob "^2.1.2" + decode-uri-component "^0.2.0" + +source-map-support@^0.5.6, source-map-support@~0.5.12, source-map-support@~0.5.19: + version "0.5.19" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" + integrity sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map-url@^0.4.0: + version "0.4.1" + resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56" + integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw== + +source-map@0.5.6: + version "0.5.6" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.6.tgz#75ce38f52bf0733c5a7f0c118d81334a2bb5f412" + integrity sha1-dc449SvwczxafwwRjYEzSiu19BI= + +source-map@0.6.1, source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0, source-map@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +source-map@^0.5.0, source-map@^0.5.6: + version "0.5.7" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" + integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= + +source-map@^0.7.3, source-map@~0.7.2: + version "0.7.3" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.3.tgz#5302f8169031735226544092e64981f751750383" + integrity sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ== + +sourcemap-codec@^1.4.4: + version "1.4.8" + resolved "https://registry.yarnpkg.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz#ea804bd94857402e6992d05a38ef1ae35a9ab4c4" + integrity sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA== + +sourcemapped-stacktrace@^1.1.6: + version "1.1.11" + resolved "https://registry.yarnpkg.com/sourcemapped-stacktrace/-/sourcemapped-stacktrace-1.1.11.tgz#e2dede7fc148599c52a4f883276e527f8452657d" + integrity sha512-O0pcWjJqzQFVsisPlPXuNawJHHg9N9UgpJ/aDmvi9+vnS3x1C0NhwkVFzzZ1VN0Xo+bekyweoqYvBw5ZBKiNnQ== + dependencies: + source-map "0.5.6" + +spdx-correct@^3.0.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.1.1.tgz#dece81ac9c1e6713e5f7d1b6f17d468fa53d89a9" + integrity sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w== + dependencies: + spdx-expression-parse "^3.0.0" + spdx-license-ids "^3.0.0" + +spdx-exceptions@^2.1.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz#3f28ce1a77a00372683eade4a433183527a2163d" + integrity sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A== + +spdx-expression-parse@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz#cf70f50482eefdc98e3ce0a6833e4a53ceeba679" + integrity sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q== + dependencies: + spdx-exceptions "^2.1.0" + spdx-license-ids "^3.0.0" + +spdx-license-ids@^3.0.0: + version "3.0.7" + resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz#e9c18a410e5ed7e12442a549fbd8afa767038d65" + integrity sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ== + +spdy-transport@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/spdy-transport/-/spdy-transport-3.0.0.tgz#00d4863a6400ad75df93361a1608605e5dcdcf31" + integrity sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw== + dependencies: + debug "^4.1.0" + detect-node "^2.0.4" + hpack.js "^2.1.6" + obuf "^1.1.2" + readable-stream "^3.0.6" + wbuf "^1.7.3" + +spdy@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/spdy/-/spdy-4.0.2.tgz#b74f466203a3eda452c02492b91fb9e84a27677b" + integrity sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA== + dependencies: + debug "^4.1.0" + handle-thing "^2.0.0" + http-deceiver "^1.2.7" + select-hose "^2.0.0" + spdy-transport "^3.0.0" + +split-string@^3.0.1, split-string@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2" + integrity sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw== + dependencies: + extend-shallow "^3.0.0" + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" + integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= + +sshpk@^1.7.0: + version "1.16.1" + resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.16.1.tgz#fb661c0bef29b39db40769ee39fa70093d6f6877" + integrity sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg== + dependencies: + asn1 "~0.2.3" + assert-plus "^1.0.0" + bcrypt-pbkdf "^1.0.0" + dashdash "^1.12.0" + ecc-jsbn "~0.1.1" + getpass "^0.1.1" + jsbn "~0.1.0" + safer-buffer "^2.0.2" + tweetnacl "~0.14.0" + +ssri@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/ssri/-/ssri-6.0.1.tgz#2a3c41b28dd45b62b63676ecb74001265ae9edd8" + integrity sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA== + dependencies: + figgy-pudding "^3.5.1" + +ssri@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.1.tgz#638e4e439e2ffbd2cd289776d5ca457c4f51a2af" + integrity sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ== + dependencies: + minipass "^3.1.1" + +stable@^0.1.8: + version "0.1.8" + resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.8.tgz#836eb3c8382fe2936feaf544631017ce7d47a3cf" + integrity sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w== + +stack-utils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.3.tgz#cd5f030126ff116b78ccb3c027fe302713b61277" + integrity sha512-gL//fkxfWUsIlFL2Tl42Cl6+HFALEaB1FU76I/Fy+oZjRreP7OPMXFlGbxM7NQsI0ZpUfw76sHnv0WNYuTb7Iw== + dependencies: + escape-string-regexp "^2.0.0" + +stackframe@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/stackframe/-/stackframe-0.3.1.tgz#33aa84f1177a5548c8935533cbfeb3420975f5a4" + integrity sha1-M6qE8Rd6VUjIk1Uzy/6zQgl19aQ= + +stackframe@^1.1.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/stackframe/-/stackframe-1.2.0.tgz#52429492d63c62eb989804c11552e3d22e779303" + integrity sha512-GrdeshiRmS1YLMYgzF16olf2jJ/IzxXY9lhKOskuVziubpTYcYqyOwYeJKzQkwy7uN0fYSsbsC4RQaXf9LCrYA== + +static-extend@^0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz#60809c39cbff55337226fd5e0b520f341f1fb5c6" + integrity sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY= + dependencies: + define-property "^0.2.5" + object-copy "^0.1.0" + +"statuses@>= 1.4.0 < 2", "statuses@>= 1.5.0 < 2", statuses@~1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" + integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= + +stealthy-require@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/stealthy-require/-/stealthy-require-1.1.1.tgz#35b09875b4ff49f26a777e509b3090a3226bf24b" + integrity sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks= + +stream-browserify@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.2.tgz#87521d38a44aa7ee91ce1cd2a47df0cb49dd660b" + integrity sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg== + dependencies: + inherits "~2.0.1" + readable-stream "^2.0.2" + +stream-each@^1.1.0: + version "1.2.3" + resolved "https://registry.yarnpkg.com/stream-each/-/stream-each-1.2.3.tgz#ebe27a0c389b04fbcc233642952e10731afa9bae" + integrity sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw== + dependencies: + end-of-stream "^1.1.0" + stream-shift "^1.0.0" + +stream-http@^2.7.2: + version "2.8.3" + resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-2.8.3.tgz#b2d242469288a5a27ec4fe8933acf623de6514fc" + integrity sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw== + dependencies: + builtin-status-codes "^3.0.0" + inherits "^2.0.1" + readable-stream "^2.3.6" + to-arraybuffer "^1.0.0" + xtend "^4.0.0" + +stream-shift@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/stream-shift/-/stream-shift-1.0.1.tgz#d7088281559ab2778424279b0877da3c392d5a3d" + integrity sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ== + +strict-uri-encode@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz#279b225df1d582b1f54e65addd4352e18faa0713" + integrity sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM= + +string-length@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.2.tgz#a8a8dc7bd5c1a82b9b3c8b87e125f66871b6e57a" + integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ== + dependencies: + char-regex "^1.0.2" + strip-ansi "^6.0.0" + +string-natural-compare@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/string-natural-compare/-/string-natural-compare-3.0.1.tgz#7a42d58474454963759e8e8b7ae63d71c1e7fdf4" + integrity sha512-n3sPwynL1nwKi3WJ6AIsClwBMa0zTi54fn2oLU6ndfTSIO05xaznjSf15PcBZU6FNWbmN5Q6cxT4V5hGvB4taw== + +string-width@^3.0.0, string-width@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" + integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== + dependencies: + emoji-regex "^7.0.1" + is-fullwidth-code-point "^2.0.0" + strip-ansi "^5.1.0" + +string-width@^4.1.0, string-width@^4.2.0: + version "4.2.2" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.2.tgz#dafd4f9559a7585cfba529c6a0a4f73488ebd4c5" + integrity sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.0" + +string.prototype.matchall@^4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.4.tgz#608f255e93e072107f5de066f81a2dfb78cf6b29" + integrity sha512-pknFIWVachNcyqRfaQSeu/FUfpvJTe4uskUSZ9Wc1RijsPuzbZ8TyYT8WCNnntCjUEqQ3vUHMAfVj2+wLAisPQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.18.0-next.2" + has-symbols "^1.0.1" + internal-slot "^1.0.3" + regexp.prototype.flags "^1.3.1" + side-channel "^1.0.4" + +string.prototype.trimend@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz#e75ae90c2942c63504686c18b287b4a0b1a45f80" + integrity sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + +string.prototype.trimstart@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz#b36399af4ab2999b4c9c648bd7a3fb2bb26feeed" + integrity sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + +string_decoder@^1.0.0, string_decoder@^1.1.1: + version "1.3.0" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" + integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== + dependencies: + safe-buffer "~5.2.0" + +string_decoder@~1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" + integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== + dependencies: + safe-buffer "~5.1.0" + +stringify-object@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" + integrity sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw== + dependencies: + get-own-enumerable-property-symbols "^3.0.0" + is-obj "^1.0.1" + is-regexp "^1.0.0" + +strip-ansi@6.0.0, strip-ansi@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" + integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== + dependencies: + ansi-regex "^5.0.0" + +strip-ansi@^3.0.0, strip-ansi@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" + integrity sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8= + dependencies: + ansi-regex "^2.0.0" + +strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" + integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== + dependencies: + ansi-regex "^4.1.0" + +strip-bom@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" + integrity sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM= + +strip-bom@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" + integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== + +strip-comments@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/strip-comments/-/strip-comments-1.0.2.tgz#82b9c45e7f05873bee53f37168af930aa368679d" + integrity sha512-kL97alc47hoyIQSV165tTt9rG5dn4w1dNnBhOQ3bOU1Nc1hel09jnXANaHJ7vzHLd4Ju8kseDGzlev96pghLFw== + dependencies: + babel-extract-comments "^1.0.0" + babel-plugin-transform-object-rest-spread "^6.26.0" + +strip-eof@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" + integrity sha1-u0P/VZim6wXYm1n80SnJgzE2Br8= + +strip-final-newline@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" + integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + +strip-indent@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-indent/-/strip-indent-3.0.0.tgz#c32e1cee940b6b3432c771bc2c54bcce73cd3001" + integrity sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ== + dependencies: + min-indent "^1.0.0" + +strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +style-loader@1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/style-loader/-/style-loader-1.3.0.tgz#828b4a3b3b7e7aa5847ce7bae9e874512114249e" + integrity sha512-V7TCORko8rs9rIqkSrlMfkqA63DfoGBBJmK1kKGCcSi+BWb4cqz0SRsnp4l6rU5iwOEd0/2ePv68SV22VXon4Q== + dependencies: + loader-utils "^2.0.0" + schema-utils "^2.7.0" + +stylehacks@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/stylehacks/-/stylehacks-4.0.3.tgz#6718fcaf4d1e07d8a1318690881e8d96726a71d5" + integrity sha512-7GlLk9JwlElY4Y6a/rmbH2MhVlTyVmiJd1PfTCqFaIBEGMYNsrO/v3SeGTdhBThLg4Z+NbOk/qFMwCa+J+3p/g== + dependencies: + browserslist "^4.0.0" + postcss "^7.0.0" + postcss-selector-parser "^3.0.0" + +supports-color@^5.3.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-6.1.0.tgz#0764abc69c63d5ac842dd4867e8d025e880df8f3" + integrity sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.0.0, supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-hyperlinks@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.1.0.tgz#f663df252af5f37c5d49bbd7eeefa9e0b9e59e47" + integrity sha512-zoE5/e+dnEijk6ASB6/qrK+oYdm2do1hjoLWrqUC/8WEIW1gbxFcKuBof7sW8ArN6e+AYvsE8HBGiVRWL/F5CA== + dependencies: + has-flag "^4.0.0" + supports-color "^7.0.0" + +svg-parser@^2.0.2: + version "2.0.4" + resolved "https://registry.yarnpkg.com/svg-parser/-/svg-parser-2.0.4.tgz#fdc2e29e13951736140b76cb122c8ee6630eb6b5" + integrity sha512-e4hG1hRwoOdRb37cIMSgzNsxyzKfayW6VOflrwvR+/bzrkyxY/31WkbgnQpgtrNp1SdpJvpUAGTa/ZoiPNDuRQ== + +svgo@^1.0.0, svgo@^1.2.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/svgo/-/svgo-1.3.2.tgz#b6dc511c063346c9e415b81e43401145b96d4167" + integrity sha512-yhy/sQYxR5BkC98CY7o31VGsg014AKLEPxdfhora76l36hD9Rdy5NZA/Ocn6yayNPgSamYdtX2rFJdcv07AYVw== + dependencies: + chalk "^2.4.1" + coa "^2.0.2" + css-select "^2.0.0" + css-select-base-adapter "^0.1.1" + css-tree "1.0.0-alpha.37" + csso "^4.0.2" + js-yaml "^3.13.1" + mkdirp "~0.5.1" + object.values "^1.1.0" + sax "~1.2.4" + stable "^0.1.8" + unquote "~1.1.1" + util.promisify "~1.0.0" + +symbol-tree@^3.2.4: + version "3.2.4" + resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" + integrity sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw== + +table@^6.0.4: + version "6.0.9" + resolved "https://registry.yarnpkg.com/table/-/table-6.0.9.tgz#790a12bf1e09b87b30e60419bafd6a1fd85536fb" + integrity sha512-F3cLs9a3hL1Z7N4+EkSscsel3z55XT950AvB05bwayrNg5T1/gykXtigioTAjbltvbMSJvvhFCbnf6mX+ntnJQ== + dependencies: + ajv "^8.0.1" + is-boolean-object "^1.1.0" + is-number-object "^1.0.4" + is-string "^1.0.5" + lodash.clonedeep "^4.5.0" + lodash.flatten "^4.4.0" + lodash.truncate "^4.4.2" + slice-ansi "^4.0.0" + string-width "^4.2.0" + +tapable@^1.0.0, tapable@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/tapable/-/tapable-1.1.3.tgz#a1fccc06b58db61fd7a45da2da44f5f3a3e67ba2" + integrity sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA== + +tar@^6.0.2: + version "6.1.0" + resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.0.tgz#d1724e9bcc04b977b18d5c573b333a2207229a83" + integrity sha512-DUCttfhsnLCjwoDoFcI+B2iJgYa93vBnDUATYEeRx6sntCTdN01VnqsIuTlALXla/LWooNg0yEGeB+Y8WdFxGA== + dependencies: + chownr "^2.0.0" + fs-minipass "^2.0.0" + minipass "^3.0.0" + minizlib "^2.1.1" + mkdirp "^1.0.3" + yallist "^4.0.0" + +temp-dir@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/temp-dir/-/temp-dir-1.0.0.tgz#0a7c0ea26d3a39afa7e0ebea9c1fc0bc4daa011d" + integrity sha1-CnwOom06Oa+n4OvqnB/AvE2qAR0= + +tempy@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/tempy/-/tempy-0.3.0.tgz#6f6c5b295695a16130996ad5ab01a8bd726e8bf8" + integrity sha512-WrH/pui8YCwmeiAoxV+lpRH9HpRtgBhSR2ViBPgpGb/wnYDzp21R4MN45fsCGvLROvY67o3byhJRYRONJyImVQ== + dependencies: + temp-dir "^1.0.0" + type-fest "^0.3.1" + unique-string "^1.0.0" + +terminal-link@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" + integrity sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ== + dependencies: + ansi-escapes "^4.2.1" + supports-hyperlinks "^2.0.0" + +terser-webpack-plugin@4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-4.2.3.tgz#28daef4a83bd17c1db0297070adc07fc8cfc6a9a" + integrity sha512-jTgXh40RnvOrLQNgIkwEKnQ8rmHjHK4u+6UBEi+W+FPmvb+uo+chJXntKe7/3lW5mNysgSWD60KyesnhW8D6MQ== + dependencies: + cacache "^15.0.5" + find-cache-dir "^3.3.1" + jest-worker "^26.5.0" + p-limit "^3.0.2" + schema-utils "^3.0.0" + serialize-javascript "^5.0.1" + source-map "^0.6.1" + terser "^5.3.4" + webpack-sources "^1.4.3" + +terser-webpack-plugin@^1.4.3: + version "1.4.5" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz#a217aefaea330e734ffacb6120ec1fa312d6040b" + integrity sha512-04Rfe496lN8EYruwi6oPQkG0vo8C+HT49X687FZnpPF0qMAIHONI6HEXYPKDOE8e5HjXTyKfqRd/agHtH0kOtw== + dependencies: + cacache "^12.0.2" + find-cache-dir "^2.1.0" + is-wsl "^1.1.0" + schema-utils "^1.0.0" + serialize-javascript "^4.0.0" + source-map "^0.6.1" + terser "^4.1.2" + webpack-sources "^1.4.0" + worker-farm "^1.7.0" + +terser@^4.1.2, terser@^4.6.2, terser@^4.6.3: + version "4.8.0" + resolved "https://registry.yarnpkg.com/terser/-/terser-4.8.0.tgz#63056343d7c70bb29f3af665865a46fe03a0df17" + integrity sha512-EAPipTNeWsb/3wLPeup1tVPaXfIaU68xMnVdPafIL1TV05OhASArYyIfFvnvJCNrR2NIOvDVNNTFRa+Re2MWyw== + dependencies: + commander "^2.20.0" + source-map "~0.6.1" + source-map-support "~0.5.12" + +terser@^5.3.4: + version "5.6.1" + resolved "https://registry.yarnpkg.com/terser/-/terser-5.6.1.tgz#a48eeac5300c0a09b36854bf90d9c26fb201973c" + integrity sha512-yv9YLFQQ+3ZqgWCUk+pvNJwgUTdlIxUk1WTN+RnaFJe2L7ipG2csPT0ra2XRm7Cs8cxN7QXmK1rFzEwYEQkzXw== + dependencies: + commander "^2.20.0" + source-map "~0.7.2" + source-map-support "~0.5.19" + +test-exclude@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-6.0.0.tgz#04a8698661d805ea6fa293b6cb9e63ac044ef15e" + integrity sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w== + dependencies: + "@istanbuljs/schema" "^0.1.2" + glob "^7.1.4" + minimatch "^3.0.4" + +text-table@0.2.0, text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha1-f17oI66AUgfACvLfSoTsP8+lcLQ= + +throat@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/throat/-/throat-5.0.0.tgz#c5199235803aad18754a667d659b5e72ce16764b" + integrity sha512-fcwX4mndzpLQKBS1DVYhGAcYaYt7vsHNIvQV+WXMvnow5cgjPphq5CaayLaGsjRdSCKZFNGt7/GYAuXaNOiYCA== + +through2@^2.0.0: + version "2.0.5" + resolved "https://registry.yarnpkg.com/through2/-/through2-2.0.5.tgz#01c1e39eb31d07cb7d03a96a70823260b23132cd" + integrity sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ== + dependencies: + readable-stream "~2.3.6" + xtend "~4.0.1" + +thunky@^1.0.2: + version "1.1.0" + resolved "https://registry.yarnpkg.com/thunky/-/thunky-1.1.0.tgz#5abaf714a9405db0504732bbccd2cedd9ef9537d" + integrity sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA== + +timers-browserify@^2.0.4: + version "2.0.12" + resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.12.tgz#44a45c11fbf407f34f97bccd1577c652361b00ee" + integrity sha512-9phl76Cqm6FhSX9Xe1ZUAMLtm1BLkKj2Qd5ApyWkXzsMRaA7dgr81kf4wJmQf/hAvg8EEyJxDo3du/0KlhPiKQ== + dependencies: + setimmediate "^1.0.4" + +timsort@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/timsort/-/timsort-0.3.0.tgz#405411a8e7e6339fe64db9a234de11dc31e02bd4" + integrity sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q= + +tiny-invariant@^1.0.2: + version "1.1.0" + resolved "https://registry.yarnpkg.com/tiny-invariant/-/tiny-invariant-1.1.0.tgz#634c5f8efdc27714b7f386c35e6760991d230875" + integrity sha512-ytxQvrb1cPc9WBEI/HSeYYoGD0kWnGEOR8RY6KomWLBVhqz0RgTwVO9dLrGz7dC+nN9llyI7OKAgRq8Vq4ZBSw== + +tiny-warning@^1.0.0, tiny-warning@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/tiny-warning/-/tiny-warning-1.0.3.tgz#94a30db453df4c643d0fd566060d60a875d84754" + integrity sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA== + +tmpl@1.0.x: + version "1.0.4" + resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.4.tgz#23640dd7b42d00433911140820e5cf440e521dd1" + integrity sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE= + +to-arraybuffer@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43" + integrity sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M= + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + integrity sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4= + +to-object-path@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz#297588b7b0e7e0ac08e04e672f85c1f4999e17af" + integrity sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68= + dependencies: + kind-of "^3.0.2" + +to-regex-range@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38" + integrity sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg= + dependencies: + is-number "^3.0.0" + repeat-string "^1.6.1" + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +to-regex@^3.0.1, to-regex@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz#13cfdd9b336552f30b51f33a8ae1b42a7a7599ce" + integrity sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw== + dependencies: + define-property "^2.0.2" + extend-shallow "^3.0.2" + regex-not "^1.0.2" + safe-regex "^1.1.0" + +toidentifier@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" + integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== + +totalist@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/totalist/-/totalist-1.1.0.tgz#a4d65a3e546517701e3e5c37a47a70ac97fe56df" + integrity sha512-gduQwd1rOdDMGxFG1gEvhV88Oirdo2p+KjoYFU7k2g+i7n6AFFbDQ5kMPUsW0pNbfQsB/cwXvT1i4Bue0s9g5g== + +tough-cookie@^2.3.3, tough-cookie@~2.5.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" + integrity sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g== + dependencies: + psl "^1.1.28" + punycode "^2.1.1" + +tough-cookie@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" + integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg== + dependencies: + psl "^1.1.33" + punycode "^2.1.1" + universalify "^0.1.2" + +tr46@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.0.2.tgz#03273586def1595ae08fedb38d7733cee91d2479" + integrity sha512-3n1qG+/5kg+jrbTzwAykB5yRYtQCTqOGKq5U5PE3b0a1/mzo6snDhjGS0zJVJunO0NrT3Dg1MLy5TjWP/UJppg== + dependencies: + punycode "^2.1.1" + +tryer@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/tryer/-/tryer-1.0.1.tgz#f2c85406800b9b0f74c9f7465b81eaad241252f8" + integrity sha512-c3zayb8/kWWpycWYg87P71E1S1ZL6b6IJxfb5fvsUgsf0S2MVGaDhDXXjDMpdCpfWXqptc+4mXwmiy1ypXqRAA== + +ts-loader@^8.0.17: + version "8.1.0" + resolved "https://registry.yarnpkg.com/ts-loader/-/ts-loader-8.1.0.tgz#d6292487df279c7cc79b6d3b70bb9d31682b693e" + integrity sha512-YiQipGGAFj2zBfqLhp28yUvPP9jUGqHxRzrGYuc82Z2wM27YIHbElXiaZDc93c3x0mz4zvBmS6q/DgExpdj37A== + dependencies: + chalk "^4.1.0" + enhanced-resolve "^4.0.0" + loader-utils "^2.0.0" + micromatch "^4.0.0" + semver "^7.3.4" + +ts-pnp@1.2.0, ts-pnp@^1.1.6: + version "1.2.0" + resolved "https://registry.yarnpkg.com/ts-pnp/-/ts-pnp-1.2.0.tgz#a500ad084b0798f1c3071af391e65912c86bca92" + integrity sha512-csd+vJOb/gkzvcCHgTGSChYpy5f1/XKNsmvBGO4JXS+z1v2HobugDz4s1IeFXM3wZB44uczs+eazB5Q/ccdhQw== + +tsconfig-paths@^3.9.0: + version "3.9.0" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz#098547a6c4448807e8fcb8eae081064ee9a3c90b" + integrity sha512-dRcuzokWhajtZWkQsDVKbWyY+jgcLC5sqJhg2PSgf4ZkH2aHPvaOY8YWGhmjb68b5qqTfasSsDO9k7RUiEmZAw== + dependencies: + "@types/json5" "^0.0.29" + json5 "^1.0.1" + minimist "^1.2.0" + strip-bom "^3.0.0" + +tslib@^1.8.1, tslib@^1.9.0: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.0.3: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.1.0.tgz#da60860f1c2ecaa5703ab7d39bc05b6bf988b97a" + integrity sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A== + +tsutils@^3.17.1: + version "3.21.0" + resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" + integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== + dependencies: + tslib "^1.8.1" + +tty-browserify@0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6" + integrity sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY= + +tunnel-agent@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" + integrity sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0= + dependencies: + safe-buffer "^5.0.1" + +tweetnacl@^0.14.3, tweetnacl@~0.14.0: + version "0.14.5" + resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" + integrity sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q= + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + +type-check@~0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" + integrity sha1-WITKtRLPHTVeP7eE8wgEsrUg23I= + dependencies: + prelude-ls "~1.1.2" + +type-detect@4.0.8: + version "4.0.8" + resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" + integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== + +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + +type-fest@^0.21.3: + version "0.21.3" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" + integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== + +type-fest@^0.3.1: + version "0.3.1" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.3.1.tgz#63d00d204e059474fe5e1b7c011112bbd1dc29e1" + integrity sha512-cUGJnCdr4STbePCgqNFbpVNCepa+kAVohJs1sLhxzdH+gnEoOd8VhbYa7pD3zZYGiURWM2xzEII3fQcRizDkYQ== + +type-fest@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.6.0.tgz#8d2a2370d3df886eb5c90ada1c5bf6188acf838b" + integrity sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg== + +type-fest@^0.8.1: + version "0.8.1" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" + integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== + +type-is@~1.6.17, type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +type@^1.0.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/type/-/type-1.2.0.tgz#848dd7698dafa3e54a6c479e759c4bc3f18847a0" + integrity sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg== + +type@^2.0.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/type/-/type-2.5.0.tgz#0a2e78c2e77907b252abe5f298c1b01c63f0db3d" + integrity sha512-180WMDQaIMm3+7hGXWf12GtdniDEy7nYcyFMKJn/eZz/6tSLXrUN9V0wKSbMjej0I1WHWbpREDEKHtqPQa9NNw== + +typedarray-to-buffer@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" + integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== + dependencies: + is-typedarray "^1.0.0" + +typedarray@^0.0.6: + version "0.0.6" + resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" + integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c= + +typescript@^4.1.2: + version "4.2.3" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.2.3.tgz#39062d8019912d43726298f09493d598048c1ce3" + integrity sha512-qOcYwxaByStAWrBf4x0fibwZvMRG+r4cQoTjbPtUlrWjBHbmCAww1i448U0GJ+3cNNEtebDteo/cHOR3xJ4wEw== + +unbox-primitive@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.1.tgz#085e215625ec3162574dc8859abee78a59b14471" + integrity sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw== + dependencies: + function-bind "^1.1.1" + has-bigints "^1.0.1" + has-symbols "^1.0.2" + which-boxed-primitive "^1.0.2" + +unicode-canonical-property-names-ecmascript@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz#2619800c4c825800efdd8343af7dd9933cbe2818" + integrity sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ== + +unicode-match-property-ecmascript@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz#8ed2a32569961bce9227d09cd3ffbb8fed5f020c" + integrity sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg== + dependencies: + unicode-canonical-property-names-ecmascript "^1.0.4" + unicode-property-aliases-ecmascript "^1.0.4" + +unicode-match-property-value-ecmascript@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.2.0.tgz#0d91f600eeeb3096aa962b1d6fc88876e64ea531" + integrity sha512-wjuQHGQVofmSJv1uVISKLE5zO2rNGzM/KCYZch/QQvez7C1hUhBIuZ701fYXExuufJFMPhv2SyL8CyoIfMLbIQ== + +unicode-property-aliases-ecmascript@^1.0.4: + version "1.1.0" + resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.1.0.tgz#dd57a99f6207bedff4628abefb94c50db941c8f4" + integrity sha512-PqSoPh/pWetQ2phoj5RLiaqIk4kCNwoV3CI+LfGmWLKI3rE3kl1h59XpX2BjgDrmbxD9ARtQobPGU1SguCYuQg== + +union-value@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz#0b6fe7b835aecda61c6ea4d4f02c14221e109847" + integrity sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg== + dependencies: + arr-union "^3.1.0" + get-value "^2.0.6" + is-extendable "^0.1.1" + set-value "^2.0.1" + +uniq@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/uniq/-/uniq-1.0.1.tgz#b31c5ae8254844a3a8281541ce2b04b865a734ff" + integrity sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8= + +uniqs@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/uniqs/-/uniqs-2.0.0.tgz#ffede4b36b25290696e6e165d4a59edb998e6b02" + integrity sha1-/+3ks2slKQaW5uFl1KWe25mOawI= + +unique-filename@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-1.1.1.tgz#1d69769369ada0583103a1e6ae87681b56573230" + integrity sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ== + dependencies: + unique-slug "^2.0.0" + +unique-slug@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-2.0.2.tgz#baabce91083fc64e945b0f3ad613e264f7cd4e6c" + integrity sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w== + dependencies: + imurmurhash "^0.1.4" + +unique-string@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-1.0.0.tgz#9e1057cca851abb93398f8b33ae187b99caec11a" + integrity sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo= + dependencies: + crypto-random-string "^1.0.0" + +universalify@^0.1.0, universalify@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" + integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== + +universalify@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" + integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== + +unpipe@1.0.0, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" + integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= + +unquote@~1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/unquote/-/unquote-1.1.1.tgz#8fded7324ec6e88a0ff8b905e7c098cdc086d544" + integrity sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ= + +unset-value@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559" + integrity sha1-g3aHP30jNRef+x5vw6jtDfyKtVk= + dependencies: + has-value "^0.3.1" + isobject "^3.0.0" + +upath@^1.1.1, upath@^1.1.2, upath@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/upath/-/upath-1.2.0.tgz#8f66dbcd55a883acdae4408af8b035a5044c1894" + integrity sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg== + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +urix@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72" + integrity sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI= + +url-loader@4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/url-loader/-/url-loader-4.1.1.tgz#28505e905cae158cf07c92ca622d7f237e70a4e2" + integrity sha512-3BTV812+AVHHOJQO8O5MkWgZ5aosP7GnROJwvzLS9hWDj00lZ6Z0wNak423Lp9PBZN05N+Jk/N5Si8jRAlGyWA== + dependencies: + loader-utils "^2.0.0" + mime-types "^2.1.27" + schema-utils "^3.0.0" + +url-parse@^1.4.3, url-parse@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/url-parse/-/url-parse-1.5.1.tgz#d5fa9890af8a5e1f274a2c98376510f6425f6e3b" + integrity sha512-HOfCOUJt7iSYzEx/UqgtwKRMC6EU91NFhsCHMv9oM03VJcVo2Qrp8T8kI9D7amFf1cu+/3CEhgb3rF9zL7k85Q== + dependencies: + querystringify "^2.1.1" + requires-port "^1.0.0" + +url@^0.11.0: + version "0.11.0" + resolved "https://registry.yarnpkg.com/url/-/url-0.11.0.tgz#3838e97cfc60521eb73c525a8e55bfdd9e2e28f1" + integrity sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE= + dependencies: + punycode "1.3.2" + querystring "0.2.0" + +use@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" + integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== + +util-deprecate@^1.0.1, util-deprecate@^1.0.2, util-deprecate@~1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= + +util.promisify@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/util.promisify/-/util.promisify-1.0.0.tgz#440f7165a459c9a16dc145eb8e72f35687097030" + integrity sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA== + dependencies: + define-properties "^1.1.2" + object.getownpropertydescriptors "^2.0.3" + +util.promisify@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/util.promisify/-/util.promisify-1.0.1.tgz#6baf7774b80eeb0f7520d8b81d07982a59abbaee" + integrity sha512-g9JpC/3He3bm38zsLupWryXHoEcS22YHthuPQSJdMy6KNrzIRzWqcsHzD/WUnqe45whVou4VIsPew37DoXWNrA== + dependencies: + define-properties "^1.1.3" + es-abstract "^1.17.2" + has-symbols "^1.0.1" + object.getownpropertydescriptors "^2.1.0" + +util@0.10.3: + version "0.10.3" + resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" + integrity sha1-evsa/lCAUkZInj23/g7TeTNqwPk= + dependencies: + inherits "2.0.1" + +util@^0.11.0: + version "0.11.1" + resolved "https://registry.yarnpkg.com/util/-/util-0.11.1.tgz#3236733720ec64bb27f6e26f421aaa2e1b588d61" + integrity sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ== + dependencies: + inherits "2.0.3" + +utila@~0.4: + version "0.4.0" + resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c" + integrity sha1-ihagXURWV6Oupe7MWxKk+lN5dyw= + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" + integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= + +uuid@^3.3.2, uuid@^3.4.0: + version "3.4.0" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" + integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A== + +uuid@^8.3.0: + version "8.3.2" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + +v8-compile-cache@^2.0.3, v8-compile-cache@^2.2.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" + integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== + +v8-to-istanbul@^7.0.0: + version "7.1.1" + resolved "https://registry.yarnpkg.com/v8-to-istanbul/-/v8-to-istanbul-7.1.1.tgz#04bfd1026ba4577de5472df4f5e89af49de5edda" + integrity sha512-p0BB09E5FRjx0ELN6RgusIPsSPhtgexSRcKETybEs6IGOTXJSZqfwxp7r//55nnu0f1AxltY5VvdVqy2vZf9AA== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.1" + convert-source-map "^1.6.0" + source-map "^0.7.3" + +validate-npm-package-license@^3.0.1: + version "3.0.4" + resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz#fc91f6b9c7ba15c857f4cb2c5defeec39d4f410a" + integrity sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew== + dependencies: + spdx-correct "^3.0.0" + spdx-expression-parse "^3.0.0" + +value-equal@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/value-equal/-/value-equal-1.0.1.tgz#1e0b794c734c5c0cade179c437d356d931a34d6c" + integrity sha512-NOJ6JZCAWr0zlxZt+xqCHNTEKOsrks2HQd4MqhP1qy4z1SkbEP467eNx6TgDKXMvUOb+OENfJCZwM+16n7fRfw== + +vary@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" + integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= + +vendors@^1.0.0: + version "1.0.4" + resolved "https://registry.yarnpkg.com/vendors/-/vendors-1.0.4.tgz#e2b800a53e7a29b93506c3cf41100d16c4c4ad8e" + integrity sha512-/juG65kTL4Cy2su4P8HjtkTxk6VmJDiOPBufWniqQ6wknac6jNiXS9vU+hO3wgusiyqWlzTbVHi0dyJqRONg3w== + +verror@1.10.0: + version "1.10.0" + resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" + integrity sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA= + dependencies: + assert-plus "^1.0.0" + core-util-is "1.0.2" + extsprintf "^1.2.0" + +vm-browserify@^1.0.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-1.1.2.tgz#78641c488b8e6ca91a75f511e7a3b32a86e5dda0" + integrity sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ== + +w3c-hr-time@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz#0a89cdf5cc15822df9c360543676963e0cc308cd" + integrity sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ== + dependencies: + browser-process-hrtime "^1.0.0" + +w3c-xmlserializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz#3e7104a05b75146cc60f564380b7f683acf1020a" + integrity sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA== + dependencies: + xml-name-validator "^3.0.0" + +walker@^1.0.7, walker@~1.0.5: + version "1.0.7" + resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.7.tgz#2f7f9b8fd10d677262b18a884e28d19618e028fb" + integrity sha1-L3+bj9ENZ3JisYqITijRlhjgKPs= + dependencies: + makeerror "1.0.x" + +watchpack-chokidar2@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz#38500072ee6ece66f3769936950ea1771be1c957" + integrity sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww== + dependencies: + chokidar "^2.1.8" + +watchpack@^1.7.4: + version "1.7.5" + resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-1.7.5.tgz#1267e6c55e0b9b5be44c2023aed5437a2c26c453" + integrity sha512-9P3MWk6SrKjHsGkLT2KHXdQ/9SNkyoJbabxnKOoJepsvJjJG8uYTR3yTPxPQvNDI3w4Nz1xnE0TLHK4RIVe/MQ== + dependencies: + graceful-fs "^4.1.2" + neo-async "^2.5.0" + optionalDependencies: + chokidar "^3.4.1" + watchpack-chokidar2 "^2.0.1" + +wbuf@^1.1.0, wbuf@^1.7.3: + version "1.7.3" + resolved "https://registry.yarnpkg.com/wbuf/-/wbuf-1.7.3.tgz#c1d8d149316d3ea852848895cb6a0bfe887b87df" + integrity sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA== + dependencies: + minimalistic-assert "^1.0.0" + +web-vitals@^1.0.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/web-vitals/-/web-vitals-1.1.1.tgz#2df535e3355fb7fbe34787b44b736e270e539377" + integrity sha512-jYOaqu01Ny1NvMwJ3dBJDUOJ2PGWknZWH4AUnvFOscvbdHMERIKT2TlgiAey5rVyfOePG7so2JcXXZdSnBvioQ== + +webidl-conversions@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" + integrity sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA== + +webidl-conversions@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-6.1.0.tgz#9111b4d7ea80acd40f5270d666621afa78b69514" + integrity sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w== + +webpack-bundle-analyzer@^4.4.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.4.0.tgz#74013106e7e2b07cbd64f3a5ae847f7e814802c7" + integrity sha512-9DhNa+aXpqdHk8LkLPTBU/dMfl84Y+WE2+KnfI6rSpNRNVKa0VGLjPd2pjFubDeqnWmulFggxmWBxhfJXZnR0g== + dependencies: + acorn "^8.0.4" + acorn-walk "^8.0.0" + chalk "^4.1.0" + commander "^6.2.0" + gzip-size "^6.0.0" + lodash "^4.17.20" + opener "^1.5.2" + sirv "^1.0.7" + ws "^7.3.1" + +webpack-cli@^4.5.0: + version "4.6.0" + resolved "https://registry.yarnpkg.com/webpack-cli/-/webpack-cli-4.6.0.tgz#27ae86bfaec0cf393fcfd58abdc5a229ad32fd16" + integrity sha512-9YV+qTcGMjQFiY7Nb1kmnupvb1x40lfpj8pwdO/bom+sQiP4OBMKjHq29YQrlDWDPZO9r/qWaRRywKaRDKqBTA== + dependencies: + "@discoveryjs/json-ext" "^0.5.0" + "@webpack-cli/configtest" "^1.0.2" + "@webpack-cli/info" "^1.2.3" + "@webpack-cli/serve" "^1.3.1" + colorette "^1.2.1" + commander "^7.0.0" + enquirer "^2.3.6" + execa "^5.0.0" + fastest-levenshtein "^1.0.12" + import-local "^3.0.2" + interpret "^2.2.0" + rechoir "^0.7.0" + v8-compile-cache "^2.2.0" + webpack-merge "^5.7.3" + +webpack-dev-middleware@^3.7.2: + version "3.7.3" + resolved "https://registry.yarnpkg.com/webpack-dev-middleware/-/webpack-dev-middleware-3.7.3.tgz#0639372b143262e2b84ab95d3b91a7597061c2c5" + integrity sha512-djelc/zGiz9nZj/U7PTBi2ViorGJXEWo/3ltkPbDyxCXhhEXkW0ce99falaok4TPj+AsxLiXJR0EBOb0zh9fKQ== + dependencies: + memory-fs "^0.4.1" + mime "^2.4.4" + mkdirp "^0.5.1" + range-parser "^1.2.1" + webpack-log "^2.0.0" + +webpack-dev-server@3.11.1: + version "3.11.1" + resolved "https://registry.yarnpkg.com/webpack-dev-server/-/webpack-dev-server-3.11.1.tgz#c74028bf5ba8885aaf230e48a20e8936ab8511f0" + integrity sha512-u4R3mRzZkbxQVa+MBWi2uVpB5W59H3ekZAJsQlKUTdl7Elcah2EhygTPLmeFXybQkf9i2+L0kn7ik9SnXa6ihQ== + dependencies: + ansi-html "0.0.7" + bonjour "^3.5.0" + chokidar "^2.1.8" + compression "^1.7.4" + connect-history-api-fallback "^1.6.0" + debug "^4.1.1" + del "^4.1.1" + express "^4.17.1" + html-entities "^1.3.1" + http-proxy-middleware "0.19.1" + import-local "^2.0.0" + internal-ip "^4.3.0" + ip "^1.1.5" + is-absolute-url "^3.0.3" + killable "^1.0.1" + loglevel "^1.6.8" + opn "^5.5.0" + p-retry "^3.0.1" + portfinder "^1.0.26" + schema-utils "^1.0.0" + selfsigned "^1.10.8" + semver "^6.3.0" + serve-index "^1.9.1" + sockjs "^0.3.21" + sockjs-client "^1.5.0" + spdy "^4.0.2" + strip-ansi "^3.0.1" + supports-color "^6.1.0" + url "^0.11.0" + webpack-dev-middleware "^3.7.2" + webpack-log "^2.0.0" + ws "^6.2.1" + yargs "^13.3.2" + +webpack-dev-server@^3.11.2: + version "3.11.2" + resolved "https://registry.yarnpkg.com/webpack-dev-server/-/webpack-dev-server-3.11.2.tgz#695ebced76a4929f0d5de7fd73fafe185fe33708" + integrity sha512-A80BkuHRQfCiNtGBS1EMf2ChTUs0x+B3wGDFmOeT4rmJOHhHTCH2naNxIHhmkr0/UillP4U3yeIyv1pNp+QDLQ== + dependencies: + ansi-html "0.0.7" + bonjour "^3.5.0" + chokidar "^2.1.8" + compression "^1.7.4" + connect-history-api-fallback "^1.6.0" + debug "^4.1.1" + del "^4.1.1" + express "^4.17.1" + html-entities "^1.3.1" + http-proxy-middleware "0.19.1" + import-local "^2.0.0" + internal-ip "^4.3.0" + ip "^1.1.5" + is-absolute-url "^3.0.3" + killable "^1.0.1" + loglevel "^1.6.8" + opn "^5.5.0" + p-retry "^3.0.1" + portfinder "^1.0.26" + schema-utils "^1.0.0" + selfsigned "^1.10.8" + semver "^6.3.0" + serve-index "^1.9.1" + sockjs "^0.3.21" + sockjs-client "^1.5.0" + spdy "^4.0.2" + strip-ansi "^3.0.1" + supports-color "^6.1.0" + url "^0.11.0" + webpack-dev-middleware "^3.7.2" + webpack-log "^2.0.0" + ws "^6.2.1" + yargs "^13.3.2" + +webpack-log@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/webpack-log/-/webpack-log-2.0.0.tgz#5b7928e0637593f119d32f6227c1e0ac31e1b47f" + integrity sha512-cX8G2vR/85UYG59FgkoMamwHUIkSSlV3bBMRsbxVXVUk2j6NleCKjQ/WE9eYg9WY4w25O9w8wKP4rzNZFmUcUg== + dependencies: + ansi-colors "^3.0.0" + uuid "^3.3.2" + +webpack-manifest-plugin@2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/webpack-manifest-plugin/-/webpack-manifest-plugin-2.2.0.tgz#19ca69b435b0baec7e29fbe90fb4015de2de4f16" + integrity sha512-9S6YyKKKh/Oz/eryM1RyLVDVmy3NSPV0JXMRhZ18fJsq+AwGxUY34X54VNwkzYcEmEkDwNxuEOboCZEebJXBAQ== + dependencies: + fs-extra "^7.0.0" + lodash ">=3.5 <5" + object.entries "^1.1.0" + tapable "^1.0.0" + +webpack-merge@^5.7.3: + version "5.7.3" + resolved "https://registry.yarnpkg.com/webpack-merge/-/webpack-merge-5.7.3.tgz#2a0754e1877a25a8bbab3d2475ca70a052708213" + integrity sha512-6/JUQv0ELQ1igjGDzHkXbVDRxkfA57Zw7PfiupdLFJYrgFqY5ZP8xxbpp2lU3EPwYx89ht5Z/aDkD40hFCm5AA== + dependencies: + clone-deep "^4.0.1" + wildcard "^2.0.0" + +webpack-sources@^1.1.0, webpack-sources@^1.3.0, webpack-sources@^1.4.0, webpack-sources@^1.4.1, webpack-sources@^1.4.3: + version "1.4.3" + resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-1.4.3.tgz#eedd8ec0b928fbf1cbfe994e22d2d890f330a933" + integrity sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ== + dependencies: + source-list-map "^2.0.0" + source-map "~0.6.1" + +webpack@4.44.2: + version "4.44.2" + resolved "https://registry.yarnpkg.com/webpack/-/webpack-4.44.2.tgz#6bfe2b0af055c8b2d1e90ed2cd9363f841266b72" + integrity sha512-6KJVGlCxYdISyurpQ0IPTklv+DULv05rs2hseIXer6D7KrUicRDLFb4IUM1S6LUAKypPM/nSiVSuv8jHu1m3/Q== + dependencies: + "@webassemblyjs/ast" "1.9.0" + "@webassemblyjs/helper-module-context" "1.9.0" + "@webassemblyjs/wasm-edit" "1.9.0" + "@webassemblyjs/wasm-parser" "1.9.0" + acorn "^6.4.1" + ajv "^6.10.2" + ajv-keywords "^3.4.1" + chrome-trace-event "^1.0.2" + enhanced-resolve "^4.3.0" + eslint-scope "^4.0.3" + json-parse-better-errors "^1.0.2" + loader-runner "^2.4.0" + loader-utils "^1.2.3" + memory-fs "^0.4.1" + micromatch "^3.1.10" + mkdirp "^0.5.3" + neo-async "^2.6.1" + node-libs-browser "^2.2.1" + schema-utils "^1.0.0" + tapable "^1.1.3" + terser-webpack-plugin "^1.4.3" + watchpack "^1.7.4" + webpack-sources "^1.4.1" + +websocket-driver@>=0.5.1, websocket-driver@^0.7.4: + version "0.7.4" + resolved "https://registry.yarnpkg.com/websocket-driver/-/websocket-driver-0.7.4.tgz#89ad5295bbf64b480abcba31e4953aca706f5760" + integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== + dependencies: + http-parser-js ">=0.5.1" + safe-buffer ">=5.1.0" + websocket-extensions ">=0.1.1" + +websocket-extensions@>=0.1.1: + version "0.1.4" + resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42" + integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg== + +whatwg-encoding@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz#5abacf777c32166a51d085d6b4f3e7d27113ddb0" + integrity sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw== + dependencies: + iconv-lite "0.4.24" + +whatwg-fetch@>=0.10.0, whatwg-fetch@^3.4.1: + version "3.6.2" + resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.6.2.tgz#dced24f37f2624ed0281725d51d0e2e3fe677f8c" + integrity sha512-bJlen0FcuU/0EMLrdbJ7zOnW6ITZLrZMIarMUVmdKtsGvZna8vxKYaexICWPfZ8qwf9fzNq+UEIZrnSaApt6RA== + +whatwg-mimetype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf" + integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g== + +whatwg-url@^8.0.0, whatwg-url@^8.5.0: + version "8.5.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.5.0.tgz#7752b8464fc0903fec89aa9846fc9efe07351fd3" + integrity sha512-fy+R77xWv0AiqfLl4nuGUlQ3/6b5uNfQ4WAbGQVMYshCTCCPK9psC1nWh3XHuxGVCtlcDDQPQW1csmmIQo+fwg== + dependencies: + lodash "^4.7.0" + tr46 "^2.0.2" + webidl-conversions "^6.1.0" + +which-boxed-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6" + integrity sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg== + dependencies: + is-bigint "^1.0.1" + is-boolean-object "^1.1.0" + is-number-object "^1.0.4" + is-string "^1.0.5" + is-symbol "^1.0.3" + +which-module@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a" + integrity sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho= + +which@^1.2.9, which@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" + integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== + dependencies: + isexe "^2.0.0" + +which@^2.0.1, which@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +wildcard@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/wildcard/-/wildcard-2.0.0.tgz#a77d20e5200c6faaac979e4b3aadc7b3dd7f8fec" + integrity sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw== + +word-wrap@^1.2.3, word-wrap@~1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +workbox-background-sync@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-background-sync/-/workbox-background-sync-5.1.4.tgz#5ae0bbd455f4e9c319e8d827c055bb86c894fd12" + integrity sha512-AH6x5pYq4vwQvfRDWH+vfOePfPIYQ00nCEB7dJRU1e0n9+9HMRyvI63FlDvtFT2AvXVRsXvUt7DNMEToyJLpSA== + dependencies: + workbox-core "^5.1.4" + +workbox-broadcast-update@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-broadcast-update/-/workbox-broadcast-update-5.1.4.tgz#0eeb89170ddca7f6914fa3523fb14462891f2cfc" + integrity sha512-HTyTWkqXvHRuqY73XrwvXPud/FN6x3ROzkfFPsRjtw/kGZuZkPzfeH531qdUGfhtwjmtO/ZzXcWErqVzJNdXaA== + dependencies: + workbox-core "^5.1.4" + +workbox-build@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-build/-/workbox-build-5.1.4.tgz#23d17ed5c32060c363030c8823b39d0eabf4c8c7" + integrity sha512-xUcZn6SYU8usjOlfLb9Y2/f86Gdo+fy1fXgH8tJHjxgpo53VVsqRX0lUDw8/JuyzNmXuo8vXX14pXX2oIm9Bow== + dependencies: + "@babel/core" "^7.8.4" + "@babel/preset-env" "^7.8.4" + "@babel/runtime" "^7.8.4" + "@hapi/joi" "^15.1.0" + "@rollup/plugin-node-resolve" "^7.1.1" + "@rollup/plugin-replace" "^2.3.1" + "@surma/rollup-plugin-off-main-thread" "^1.1.1" + common-tags "^1.8.0" + fast-json-stable-stringify "^2.1.0" + fs-extra "^8.1.0" + glob "^7.1.6" + lodash.template "^4.5.0" + pretty-bytes "^5.3.0" + rollup "^1.31.1" + rollup-plugin-babel "^4.3.3" + rollup-plugin-terser "^5.3.1" + source-map "^0.7.3" + source-map-url "^0.4.0" + stringify-object "^3.3.0" + strip-comments "^1.0.2" + tempy "^0.3.0" + upath "^1.2.0" + workbox-background-sync "^5.1.4" + workbox-broadcast-update "^5.1.4" + workbox-cacheable-response "^5.1.4" + workbox-core "^5.1.4" + workbox-expiration "^5.1.4" + workbox-google-analytics "^5.1.4" + workbox-navigation-preload "^5.1.4" + workbox-precaching "^5.1.4" + workbox-range-requests "^5.1.4" + workbox-routing "^5.1.4" + workbox-strategies "^5.1.4" + workbox-streams "^5.1.4" + workbox-sw "^5.1.4" + workbox-window "^5.1.4" + +workbox-cacheable-response@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-cacheable-response/-/workbox-cacheable-response-5.1.4.tgz#9ff26e1366214bdd05cf5a43da9305b274078a54" + integrity sha512-0bfvMZs0Of1S5cdswfQK0BXt6ulU5kVD4lwer2CeI+03czHprXR3V4Y8lPTooamn7eHP8Iywi5QjyAMjw0qauA== + dependencies: + workbox-core "^5.1.4" + +workbox-core@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-core/-/workbox-core-5.1.4.tgz#8bbfb2362ecdff30e25d123c82c79ac65d9264f4" + integrity sha512-+4iRQan/1D8I81nR2L5vcbaaFskZC2CL17TLbvWVzQ4qiF/ytOGF6XeV54pVxAvKUtkLANhk8TyIUMtiMw2oDg== + +workbox-expiration@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-expiration/-/workbox-expiration-5.1.4.tgz#92b5df461e8126114943a3b15c55e4ecb920b163" + integrity sha512-oDO/5iC65h2Eq7jctAv858W2+CeRW5e0jZBMNRXpzp0ZPvuT6GblUiHnAsC5W5lANs1QS9atVOm4ifrBiYY7AQ== + dependencies: + workbox-core "^5.1.4" + +workbox-google-analytics@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-google-analytics/-/workbox-google-analytics-5.1.4.tgz#b3376806b1ac7d7df8418304d379707195fa8517" + integrity sha512-0IFhKoEVrreHpKgcOoddV+oIaVXBFKXUzJVBI+nb0bxmcwYuZMdteBTp8AEDJacENtc9xbR0wa9RDCnYsCDLjA== + dependencies: + workbox-background-sync "^5.1.4" + workbox-core "^5.1.4" + workbox-routing "^5.1.4" + workbox-strategies "^5.1.4" + +workbox-navigation-preload@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-navigation-preload/-/workbox-navigation-preload-5.1.4.tgz#30d1b720d26a05efc5fa11503e5cc1ed5a78902a" + integrity sha512-Wf03osvK0wTflAfKXba//QmWC5BIaIZARU03JIhAEO2wSB2BDROWI8Q/zmianf54kdV7e1eLaIEZhth4K4MyfQ== + dependencies: + workbox-core "^5.1.4" + +workbox-precaching@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-precaching/-/workbox-precaching-5.1.4.tgz#874f7ebdd750dd3e04249efae9a1b3f48285fe6b" + integrity sha512-gCIFrBXmVQLFwvAzuGLCmkUYGVhBb7D1k/IL7pUJUO5xacjLcFUaLnnsoVepBGAiKw34HU1y/YuqvTKim9qAZA== + dependencies: + workbox-core "^5.1.4" + +workbox-range-requests@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-range-requests/-/workbox-range-requests-5.1.4.tgz#7066a12c121df65bf76fdf2b0868016aa2bab859" + integrity sha512-1HSujLjgTeoxHrMR2muDW2dKdxqCGMc1KbeyGcmjZZAizJTFwu7CWLDmLv6O1ceWYrhfuLFJO+umYMddk2XMhw== + dependencies: + workbox-core "^5.1.4" + +workbox-routing@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-routing/-/workbox-routing-5.1.4.tgz#3e8cd86bd3b6573488d1a2ce7385e547b547e970" + integrity sha512-8ljknRfqE1vEQtnMtzfksL+UXO822jJlHTIR7+BtJuxQ17+WPZfsHqvk1ynR/v0EHik4x2+826Hkwpgh4GKDCw== + dependencies: + workbox-core "^5.1.4" + +workbox-strategies@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-strategies/-/workbox-strategies-5.1.4.tgz#96b1418ccdfde5354612914964074d466c52d08c" + integrity sha512-VVS57LpaJTdjW3RgZvPwX0NlhNmscR7OQ9bP+N/34cYMDzXLyA6kqWffP6QKXSkca1OFo/v6v7hW7zrrguo6EA== + dependencies: + workbox-core "^5.1.4" + workbox-routing "^5.1.4" + +workbox-streams@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-streams/-/workbox-streams-5.1.4.tgz#05754e5e3667bdc078df2c9315b3f41210d8cac0" + integrity sha512-xU8yuF1hI/XcVhJUAfbQLa1guQUhdLMPQJkdT0kn6HP5CwiPOGiXnSFq80rAG4b1kJUChQQIGPrq439FQUNVrw== + dependencies: + workbox-core "^5.1.4" + workbox-routing "^5.1.4" + +workbox-sw@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-sw/-/workbox-sw-5.1.4.tgz#2bb34c9f7381f90d84cef644816d45150011d3db" + integrity sha512-9xKnKw95aXwSNc8kk8gki4HU0g0W6KXu+xks7wFuC7h0sembFnTrKtckqZxbSod41TDaGh+gWUA5IRXrL0ECRA== + +workbox-webpack-plugin@5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-webpack-plugin/-/workbox-webpack-plugin-5.1.4.tgz#7bfe8c16e40fe9ed8937080ac7ae9c8bde01e79c" + integrity sha512-PZafF4HpugZndqISi3rZ4ZK4A4DxO8rAqt2FwRptgsDx7NF8TVKP86/huHquUsRjMGQllsNdn4FNl8CD/UvKmQ== + dependencies: + "@babel/runtime" "^7.5.5" + fast-json-stable-stringify "^2.0.0" + source-map-url "^0.4.0" + upath "^1.1.2" + webpack-sources "^1.3.0" + workbox-build "^5.1.4" + +workbox-window@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/workbox-window/-/workbox-window-5.1.4.tgz#2740f7dea7f93b99326179a62f1cc0ca2c93c863" + integrity sha512-vXQtgTeMCUq/4pBWMfQX8Ee7N2wVC4Q7XYFqLnfbXJ2hqew/cU1uMTD2KqGEgEpE4/30luxIxgE+LkIa8glBYw== + dependencies: + workbox-core "^5.1.4" + +worker-farm@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/worker-farm/-/worker-farm-1.7.0.tgz#26a94c5391bbca926152002f69b84a4bf772e5a8" + integrity sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw== + dependencies: + errno "~0.1.7" + +worker-rpc@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/worker-rpc/-/worker-rpc-0.1.1.tgz#cb565bd6d7071a8f16660686051e969ad32f54d5" + integrity sha512-P1WjMrUB3qgJNI9jfmpZ/htmBEjFh//6l/5y8SD9hg1Ef5zTTVVoRjTrTEzPrNBQvmhMxkoTsjOXN10GWU7aCg== + dependencies: + microevent.ts "~0.1.1" + +wrap-ansi@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-5.1.0.tgz#1fd1f67235d5b6d0fee781056001bfb694c03b09" + integrity sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q== + dependencies: + ansi-styles "^3.2.0" + string-width "^3.0.0" + strip-ansi "^5.0.0" + +wrap-ansi@^6.2.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz#e9393ba07102e6c91a3b221478f0257cd2856e53" + integrity sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA== + dependencies: + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= + +write-file-atomic@^3.0.0: + version "3.0.3" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" + integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== + dependencies: + imurmurhash "^0.1.4" + is-typedarray "^1.0.0" + signal-exit "^3.0.2" + typedarray-to-buffer "^3.1.5" + +ws@^6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/ws/-/ws-6.2.1.tgz#442fdf0a47ed64f59b6a5d8ff130f4748ed524fb" + integrity sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA== + dependencies: + async-limiter "~1.0.0" + +ws@^7.3.1, ws@^7.4.4: + version "7.4.4" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.4.4.tgz#383bc9742cb202292c9077ceab6f6047b17f2d59" + integrity sha512-Qm8k8ojNQIMx7S+Zp8u/uHOx7Qazv3Yv4q68MiWWWOJhiwG5W3x7iqmRtJo8xxrciZUY4vRxUTJCKuRnF28ZZw== + +xml-name-validator@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-3.0.0.tgz#6ae73e06de4d8c6e47f9fb181f78d648ad457c6a" + integrity sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw== + +xmlchars@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" + integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== + +xtend@^4.0.0, xtend@~4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" + integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== + +y18n@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.1.tgz#8db2b83c31c5d75099bb890b23f3094891e247d4" + integrity sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ== + +yallist@^3.0.2: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" + integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yaml@^1.10.0, yaml@^1.7.2: + version "1.10.2" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.2.tgz#2301c5ffbf12b467de8da2333a459e29e7920e4b" + integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== + +yargs-parser@^13.1.2: + version "13.1.2" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-13.1.2.tgz#130f09702ebaeef2650d54ce6e3e5706f7a4fb38" + integrity sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg== + dependencies: + camelcase "^5.0.0" + decamelize "^1.2.0" + +yargs-parser@^18.1.2: + version "18.1.3" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0" + integrity sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ== + dependencies: + camelcase "^5.0.0" + decamelize "^1.2.0" + +yargs@^13.3.2: + version "13.3.2" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-13.3.2.tgz#ad7ffefec1aa59565ac915f82dccb38a9c31a2dd" + integrity sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw== + dependencies: + cliui "^5.0.0" + find-up "^3.0.0" + get-caller-file "^2.0.1" + require-directory "^2.1.1" + require-main-filename "^2.0.0" + set-blocking "^2.0.0" + string-width "^3.0.0" + which-module "^2.0.0" + y18n "^4.0.0" + yargs-parser "^13.1.2" + +yargs@^15.4.1: + version "15.4.1" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.4.1.tgz#0d87a16de01aee9d8bec2bfbf74f67851730f4f8" + integrity sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A== + dependencies: + cliui "^6.0.0" + decamelize "^1.2.0" + find-up "^4.1.0" + get-caller-file "^2.0.1" + require-directory "^2.1.1" + require-main-filename "^2.0.0" + set-blocking "^2.0.0" + string-width "^4.2.0" + which-module "^2.0.0" + y18n "^4.0.0" + yargs-parser "^18.1.2" + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== diff --git a/utils/json/json.go b/utils/json/json.go index 5e61555b6a..d946ff4621 100644 --- a/utils/json/json.go +++ b/utils/json/json.go @@ -1,6 +1,11 @@ package json -import "encoding/json" +import ( + "encoding/json" + "io" + + gwruntime "github.com/grpc-ecosystem/grpc-gateway/runtime" +) // MustMarshal marshals an object and panics if it failures. This function should only be used // when the object being passed in does not have any chance of failing (i.e. you constructed @@ -12,3 +17,31 @@ func MustMarshal(i interface{}) []byte { } return bytes } + +// JSONMarshaler is a type which satisfies the grpc-gateway Marshaler interface +type JSONMarshaler struct{} + +// ContentType implements gwruntime.Marshaler. +func (j *JSONMarshaler) ContentType() string { + return "application/json" +} + +// Marshal implements gwruntime.Marshaler. +func (j *JSONMarshaler) Marshal(v interface{}) ([]byte, error) { + return json.Marshal(v) +} + +// NewDecoder implements gwruntime.Marshaler. +func (j *JSONMarshaler) NewDecoder(r io.Reader) gwruntime.Decoder { + return json.NewDecoder(r) +} + +// NewEncoder implements gwruntime.Marshaler. +func (j *JSONMarshaler) NewEncoder(w io.Writer) gwruntime.Encoder { + return json.NewEncoder(w) +} + +// Unmarshal implements gwruntime.Marshaler. +func (j *JSONMarshaler) Unmarshal(data []byte, v interface{}) error { + return json.Unmarshal(data, v) +}