#!/usr/bin/env bash ####################################################################################### # Copyright ETSI Contributors and Others. # # 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. ####################################################################################### # Delete a VM and its resources (nic, disk, nsg, public IP) on Azure. # To do this it reads the following environment variables: # - K8S_NAME: name of the VM # - RESOURCE_GROUP: name of the resource-group where the VM is function delete_azure_vm { set -eux INTERFACE_ID=$(az vm show --resource-group ${RESOURCE_GROUP} --name ${K8S_NAME} --query networkProfile.networkInterfaces[0].id) INTERFACE_ID=${INTERFACE_ID:1:-1} OS_DISK_ID=$(az vm show --resource-group ${RESOURCE_GROUP} --name ${K8S_NAME} --query storageProfile.osDisk.managedDisk.id) OS_DISK_ID=${OS_DISK_ID:1:-1} SECURITY_GROUP_ID=$(az network nic show --id ${INTERFACE_ID} --query networkSecurityGroup.id) SECURITY_GROUP_ID=${SECURITY_GROUP_ID:1:-1} PUBLIC_IP_ID=$(az network nic show --id ${INTERFACE_ID} --query ipConfigurations[0].publicIpAddress.id) PUBLIC_IP_ID=${PUBLIC_IP_ID:1:-1} az vm delete --resource-group ${RESOURCE_GROUP} --name ${K8S_NAME} --yes az network nic delete --id ${INTERFACE_ID} az disk delete --id ${OS_DISK_ID} --yes az network nsg delete --id ${SECURITY_GROUP_ID} if [ -n "${PUBLIC_IP_ID}" ]; then az network public-ip delete --id ${PUBLIC_IP_ID} fi } # Delete an existing AKS cluster and its subnet. # Required the following environment variables: # - K8S_NAME: name of the AKS # - RESOURCE_GROUP: name of the resource-group where the AKS was created function delete_azure_aks { SUBNET_ID=$(az aks show --resource-group "${RESOURCE_GROUP}" --name ${K8S_NAME} --query agentPoolProfiles[].vnetSubnetId -o tsv) az aks delete -y --resource-group "${RESOURCE_GROUP}" --name "${K8S_NAME}" az network vnet subnet delete --ids "${SUBNET_ID}" } # Delete a VM on GCP. # To do this it reads the following environment variables: # - K8S_NAME: name of the VM # - GCP_PROJECT: name of project where the VM is # - GCP_ZONE: name of the zone function delete_gcp_vm { gcloud compute instances delete "${K8S_NAME}" --project="${GCP_PROJECT}" --zone="${GCP_ZONE}" --delete-disks all -q } # Delete an existing GKE cluster. # Required the following environment variables: # - K8S_NAME: name of the AKS # - GCP_PROJECT: name of project where the VM is # - GCP_ZONE: name of the zone function delete_gcp_gke { gcloud container clusters delete "${K8S_NAME}" --project="${GCP_PROJECT}" --zone="${GCP_ZONE}" -q } # If there is an argument, it must be the cluster name if [ -n "${1:-}" ]; then K8S_NAME=$1 else K8S_NAME="${K8S_IMAGE_NAME}" fi # Default USE_PAAS_K8S is "FALSE" if [ -z "${USE_PAAS_K8S}" ]; then USE_PAAS_K8S="FALSE" fi # Branch by USE_PAAS_K8S and CLOUD_TYPE values if [ "${USE_PAAS_K8S}" == "FALSE" ]; then # Deletes k8s cluster in a cloud's VM echo "Deleting IaaS k8s cluster in ${CLOUD_TYPE}" if [ "${CLOUD_TYPE}" == "azure" ]; then # Azure VIM delete_azure_vm elif [ "${CLOUD_TYPE}" == "gcp" ]; then # GCP VIM delete_gcp_vm else echo "Invalid cloud type: ${CLOUD_TYPE}" fi else # Deletes k8s cluster as PaaS in cloud if [ "${CLOUD_TYPE}" == "azure" ]; then echo "Deleting PaaS k8s cluster in Azure" delete_azure_aks elif [ "${CLOUD_TYPE}" == "gcp" ]; then echo "Deleting PaaS k8s cluster in GCP" delete_gcp_gke else echo "Invalid cloud type: ${CLOUD_TYPE}" fi fi