149 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| # Copyright 2014 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.
 | |
| 
 | |
| function kube::util::sourced_variable {
 | |
|   # Call this function to tell shellcheck that a variable is supposed to
 | |
|   # be used from other calling context. This helps quiet an "unused
 | |
|   # variable" warning from shellcheck and also document your code.
 | |
|   true
 | |
| }
 | |
| 
 | |
| kube::util::sortable_date() {
 | |
|   date "+%Y%m%d-%H%M%S"
 | |
| }
 | |
| 
 | |
| # arguments: target, item1, item2, item3, ...
 | |
| # returns 0 if target is in the given items, 1 otherwise.
 | |
| kube::util::array_contains() {
 | |
|   local search="$1"
 | |
|   local element
 | |
|   shift
 | |
|   for element; do
 | |
|     if [[ "${element}" == "${search}" ]]; then
 | |
|       return 0
 | |
|      fi
 | |
|   done
 | |
|   return 1
 | |
| }
 | |
| 
 | |
| # Example:  kube::util::trap_add 'echo "in trap DEBUG"' DEBUG
 | |
| # See: http://stackoverflow.com/questions/3338030/multiple-bash-traps-for-the-same-signal
 | |
| kube::util::trap_add() {
 | |
|   local trap_add_cmd
 | |
|   trap_add_cmd=$1
 | |
|   shift
 | |
| 
 | |
|   for trap_add_name in "$@"; do
 | |
|     local existing_cmd
 | |
|     local new_cmd
 | |
| 
 | |
|     # Grab the currently defined trap commands for this trap
 | |
|     existing_cmd=$(trap -p "${trap_add_name}" |  awk -F"'" '{print $2}')
 | |
| 
 | |
|     if [[ -z "${existing_cmd}" ]]; then
 | |
|       new_cmd="${trap_add_cmd}"
 | |
|     else
 | |
|       new_cmd="${trap_add_cmd};${existing_cmd}"
 | |
|     fi
 | |
| 
 | |
|     # Assign the test. Disable the shellcheck warning telling that trap
 | |
|     # commands should be single quoted to avoid evaluating them at this
 | |
|     # point instead evaluating them at run time. The logic of adding new
 | |
|     # commands to a single trap requires them to be evaluated right away.
 | |
|     # shellcheck disable=SC2064
 | |
|     trap "${new_cmd}" "${trap_add_name}"
 | |
|   done
 | |
| }
 | |
| 
 | |
| kube::util::download_file() {
 | |
|   local -r url=$1
 | |
|   local -r destination_file=$2
 | |
| 
 | |
|   rm "${destination_file}" 2&> /dev/null || true
 | |
| 
 | |
|   for i in $(seq 5)
 | |
|   do
 | |
|     if ! curl -fsSL --retry 3 --keepalive-time 2 "${url}" -o "${destination_file}"; then
 | |
|       echo "Downloading ${url} failed. $((5-i)) retries left."
 | |
|       sleep 1
 | |
|     else
 | |
|       echo "Downloading ${url} succeed"
 | |
|       return 0
 | |
|     fi
 | |
|   done
 | |
|   return 1
 | |
| }
 | |
| 
 | |
| # Wait for background jobs to finish. Return with
 | |
| # an error status if any of the jobs failed.
 | |
| kube::util::wait-for-jobs() {
 | |
|   local fail=0
 | |
|   local job
 | |
|   for job in $(jobs -p); do
 | |
|     wait "${job}" || fail=$((fail + 1))
 | |
|   done
 | |
|   return ${fail}
 | |
| }
 | |
| 
 | |
| # kube::util::join <delim> <list...>
 | |
| # Concatenates the list elements with the delimiter passed as first parameter
 | |
| #
 | |
| # Ex: kube::util::join , a b c
 | |
| #  -> a,b,c
 | |
| function kube::util::join {
 | |
|   local IFS="$1"
 | |
|   shift
 | |
|   echo "$*"
 | |
| }
 | |
| 
 | |
| # kube::util::check-file-in-alphabetical-order <file>
 | |
| # Check that the file is in alphabetical order
 | |
| #
 | |
| function kube::util::check-file-in-alphabetical-order {
 | |
|   local failure_file="$1"
 | |
|   if ! diff -u "${failure_file}" <(LC_ALL=C sort "${failure_file}"); then
 | |
|     {
 | |
|       echo
 | |
|       echo "${failure_file} is not in alphabetical order. Please sort it:"
 | |
|       echo
 | |
|       echo "  LC_ALL=C sort -o ${failure_file} ${failure_file}"
 | |
|       echo
 | |
|     } >&2
 | |
|     false
 | |
|   fi
 | |
| }
 | |
| 
 | |
| # Some useful colors.
 | |
| if [[ -z "${color_start-}" ]]; then
 | |
|   declare -r color_start="\033["
 | |
|   declare -r color_red="${color_start}0;31m"
 | |
|   declare -r color_yellow="${color_start}0;33m"
 | |
|   declare -r color_green="${color_start}0;32m"
 | |
|   declare -r color_blue="${color_start}1;34m"
 | |
|   declare -r color_cyan="${color_start}1;36m"
 | |
|   declare -r color_norm="${color_start}0m"
 | |
| 
 | |
|   kube::util::sourced_variable "${color_start}"
 | |
|   kube::util::sourced_variable "${color_red}"
 | |
|   kube::util::sourced_variable "${color_yellow}"
 | |
|   kube::util::sourced_variable "${color_green}"
 | |
|   kube::util::sourced_variable "${color_blue}"
 | |
|   kube::util::sourced_variable "${color_cyan}"
 | |
|   kube::util::sourced_variable "${color_norm}"
 | |
| fi
 | |
| 
 | |
| # ex: ts=2 sw=2 et filetype=sh
 |