fix/cicd #3

Merged
marcio.fernandes merged 62 commits from fix/cicd into master 2025-11-22 17:43:58 +00:00
Showing only changes of commit c2b97b4066 - Show all commits

View File

@@ -1,15 +1,15 @@
name: Setup kubectl name: Setup kubectl
description: "Reads kube config from inputs and sets KUBECONFIG" description: "Reads kube config from inputs and sets kube config"
inputs: inputs:
kube_server: kube_server:
description: "Kubernetes API server address" description: "Kubernetes server address and port. Example (https://serverip:6443)"
required: true required: true
kube_ca_base64: kube_ca_base64:
description: "Base64-encoded CA certificate" description: "Base64-encoded Kubernetes cluster CA certificate"
required: true required: true
kube_token: kube_token:
description: "ServiceAccount token" description: "Kubernetes ServiceAccount token"
required: true required: true
runs: runs:
@@ -18,9 +18,34 @@ runs:
- name: Create kubeconfig - name: Create kubeconfig
shell: bash shell: bash
run: | run: |
set -x set -euo pipefail
mkdir -p "${GITHUB_TEMP}/.kube"
# check arguments
ERROR=0
if [ -z "${{ inputs.kube_server }}" ]; then
echo "❌ ERROR: kube_server input is empty or not set"
$ERROR=1
fi
if [ -z "${{ inputs.kube_ca_base64 }}" ]; then
echo "❌ ERROR: kube_ca_base64 input is empty or not set"
$ERROR=1
fi
if [ -z "${{ inputs.kube_server }}" ]; then
echo "❌ ERROR: kube_token input is empty or not set"
$ERROR=1
fi
if [ "$ERROR" != 0 ]; then
echo "❌ ERROR code $ERROR"
exit "$ERROR"
fi
# end check arguments
# creates kube config
mkdir -p "${GITHUB_TEMP}/.kube"
cat <<EOF > "${GITHUB_TEMP}/.kube/config" cat <<EOF > "${GITHUB_TEMP}/.kube/config"
apiVersion: v1 apiVersion: v1
kind: Config kind: Config
@@ -41,11 +66,10 @@ runs:
user: user:
token: ${{ inputs.kube_token }} token: ${{ inputs.kube_token }}
EOF EOF
echo "config created - ${GITHUB_TEMP}/.kube/config"
ls -lah ${GITHUB_TEMP}/.kube/config # sets KUBECONFIG environment variable
echo "KUBECONFIG=${GITHUB_TEMP}/.kube/config" >> "${GITHUB_ENV}" echo "KUBECONFIG=${GITHUB_TEMP}/.kube/config" >> "${GITHUB_ENV}"
# curl -vk \ # tests communication to server
# --cacert ca.crt \ curl -k -cacert <(echo "${{ inputs.kube_ca_base64 }}" | base64 -d) -H "Authorization: Bearer ${{ inputs.kube_token }}" ${{ inputs.kube_server }}/version
# -H "Authorization: Bearer $KUBE_TOKEN" \
# https://<server>:6443/version