mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-01-23 13:19:29 +00:00
87 lines
2.7 KiB
Bash
87 lines
2.7 KiB
Bash
|
#!/bin/bash
|
||
|
|
||
|
# Copyright 2015 The Kubernetes 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.
|
||
|
|
||
|
# Script to fetch latest swagger spec.
|
||
|
# Puts the updated spec at api/swagger-spec/
|
||
|
|
||
|
set -o errexit
|
||
|
set -o nounset
|
||
|
set -o pipefail
|
||
|
|
||
|
cat << __EOF__
|
||
|
Note: This assumes that the 'types_swagger_doc_generated.go' file has been
|
||
|
updated for all API group versions. If you are unsure, please run
|
||
|
hack/update-generated-swagger-docs.sh first.
|
||
|
__EOF__
|
||
|
|
||
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
||
|
SWAGGER_ROOT_DIR="${KUBE_ROOT}/api/swagger-spec"
|
||
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
||
|
|
||
|
kube::golang::setup_env
|
||
|
|
||
|
make -C "${KUBE_ROOT}" WHAT=cmd/kube-apiserver
|
||
|
|
||
|
function cleanup()
|
||
|
{
|
||
|
[[ -n ${APISERVER_PID-} ]] && kill ${APISERVER_PID} 1>&2 2>/dev/null
|
||
|
|
||
|
kube::etcd::cleanup
|
||
|
|
||
|
kube::log::status "Clean up complete"
|
||
|
}
|
||
|
|
||
|
trap cleanup EXIT SIGINT
|
||
|
|
||
|
kube::golang::setup_env
|
||
|
|
||
|
apiserver=$(kube::util::find-binary "kube-apiserver")
|
||
|
|
||
|
TMP_DIR=$(mktemp -d /tmp/update-swagger-spec.XXXX)
|
||
|
ETCD_HOST=${ETCD_HOST:-127.0.0.1}
|
||
|
ETCD_PORT=${ETCD_PORT:-2379}
|
||
|
API_PORT=${API_PORT:-8050}
|
||
|
API_HOST=${API_HOST:-127.0.0.1}
|
||
|
|
||
|
kube::etcd::start
|
||
|
|
||
|
|
||
|
# Start kube-apiserver, with alpha api versions on so we can harvest their swagger docs
|
||
|
# Set --runtime-config to all versions in KUBE_AVAILABLE_GROUP_VERSIONS to enable alpha features.
|
||
|
kube::log::status "Starting kube-apiserver"
|
||
|
"${KUBE_OUTPUT_HOSTBIN}/kube-apiserver" \
|
||
|
--insecure-bind-address="${API_HOST}" \
|
||
|
--bind-address="${API_HOST}" \
|
||
|
--insecure-port="${API_PORT}" \
|
||
|
--etcd-servers="http://${ETCD_HOST}:${ETCD_PORT}" \
|
||
|
--advertise-address="10.10.10.10" \
|
||
|
--cert-dir="${TMP_DIR}/certs" \
|
||
|
--runtime-config=$(echo "${KUBE_AVAILABLE_GROUP_VERSIONS}" | sed -E 's|[[:blank:]]+|,|g') \
|
||
|
--service-cluster-ip-range="10.0.0.0/24" >/tmp/swagger-api-server.log 2>&1 &
|
||
|
APISERVER_PID=$!
|
||
|
|
||
|
kube::util::wait_for_url "${API_HOST}:${API_PORT}/healthz" "apiserver: "
|
||
|
|
||
|
SWAGGER_API_PATH="${API_HOST}:${API_PORT}/swaggerapi/"
|
||
|
|
||
|
kube::log::status "Updating " ${SWAGGER_ROOT_DIR}
|
||
|
|
||
|
SWAGGER_API_PATH="${SWAGGER_API_PATH}" SWAGGER_ROOT_DIR="${SWAGGER_ROOT_DIR}" VERSIONS="${KUBE_AVAILABLE_GROUP_VERSIONS}" KUBE_NONSERVER_GROUP_VERSIONS="${KUBE_NONSERVER_GROUP_VERSIONS}" kube::util::fetch-swagger-spec
|
||
|
|
||
|
kube::log::status "SUCCESS"
|
||
|
|
||
|
# ex: ts=2 sw=2 et filetype=sh
|