From 47da7ac9ad24c4b3b2d931577fee78d65c0b5e00 Mon Sep 17 00:00:00 2001 From: QuintusJoyal Date: Thu, 9 May 2024 14:36:29 +0530 Subject: [PATCH 1/3] feat(az): Added az-sb-delete-all-topics.md --- az-sb-delete-all-topics.md | 120 +++++++++++++++++++++++++++++++++++++ 1 file changed, 120 insertions(+) create mode 100644 az-sb-delete-all-topics.md diff --git a/az-sb-delete-all-topics.md b/az-sb-delete-all-topics.md new file mode 100644 index 0000000..1773fd0 --- /dev/null +++ b/az-sb-delete-all-topics.md @@ -0,0 +1,120 @@ +# Deletes all topics in An Azure service bus + +## Prerequisites: + +1. **Azure CLI Installed**: Ensure you have Azure CLI installed on your system. You can download and install it from [here](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli). + +2. **Azure Account**: You'll need an active Azure account. If you don't have one, you can sign up for a free trial [here](https://azure.microsoft.com/en-us/free/). + +3. **Access to Azure Service Bus**: You must have access to the Azure Service Bus namespace and the necessary permissions to delete topics. + +## Steps to Setup and Usage: + +1. **Authenticate with Azure**: Run `az login` command to authenticate with your Azure account. + +2. **Set Variables**: Set the `resource_group` and `namespace` variables in the script to match your Azure Service Bus namespace details. + +3. **Save the Script**: Save the script with a `.sh` extension, for example, `delete_servicebus_topics.sh`. +```bash +resource_group=your_rg +namespace=your_namespace + +topics=$(az servicebus topic list --resource-group $resource_group --namespace-name $namespace) + +ids="" + +for i in $(seq 0 $(echo "${topics}" | jq '. | length')) +do + ids="$ids $(echo "${topics}" | jq ".[$i].id")" +done + +az servicebus topic delete --resource-group $resource_group --namespace-name $namespace --ids $ids +``` +## Usage +1. **Make the Script Executable**: Run `chmod +x delete_servicebus_topics.sh` to make the script executable. + +2. **Run the Script**: Execute the script by running `./delete_servicebus_topics.sh`. + +--- +--- + +# Alternative + +**Using `--query` global parameter**\ +Uses JMESPath query string. See [Here](http://jmespath.org/) for more information and examples. + +```bash +#!/bin/bash + +usage() { + echo "Usage: $0 -g -n [-y]" + exit 1 +} + +confirm_deletion=true + +while getopts ":g:n:y" opt; do + case ${opt} in + g ) + resource_group=$OPTARG + ;; + n ) + namespace=$OPTARG + ;; + y ) + confirm_deletion=false + ;; + \? ) + echo "Invalid option: $OPTARG" 1>&2 + usage + ;; + : ) + echo "Invalid option: $OPTARG requires an argument" 1>&2 + usage + ;; + esac +done +shift $((OPTIND -1)) + +if [ -z "$resource_group" ] || [ -z "$namespace" ]; then + echo "Resource group and namespace are required." + usage +fi + +echo "Fetching list of topics..." + +topics=$(az servicebus topic list --resource-group $resource_group --namespace-name $namespace --query '[].{Name:name, ID:id}' -o json) + +if [ -z "$topics" ]; then + echo "No topics found in the specified resource group and namespace." + exit 1 +fi + +echo "Topics to be deleted:" +echo "$topics" | jq -r '.[] | "\(.Name) (\(.ID))"' + +if [ "$confirm_deletion" = true ]; then + read -p "Are you sure you want to delete these topics? (y/n): " confirm +else + confirm="y" +fi + +if [[ $confirm =~ ^[Yy]$ ]]; then + echo "Deleting topics..." + ids=$(echo "$topics" | jq -r '.[].ID') + az servicebus topic delete --resource-group $resource_group --namespace-name $namespace --ids $ids + echo "Topics deleted successfully." +else + echo "Deletion cancelled." +fi + +``` + +## Usage + +1. **Make the Script Executable**: Run `chmod +x delete_servicebus_topics.sh` to make the script executable. + +2. **Run the Script**: Execute the script by running `./delete_servicebus_topics.sh -g -n [-y]`. + - `-g`: Takes resource group. + - `-n`: Takes namespace. + - `-y`: Deletes without confirmation. \ No newline at end of file From 245660c543840e08e36c69d198d1d0b3b9b6a73f Mon Sep 17 00:00:00 2001 From: QuintusJoyal Date: Thu, 9 May 2024 14:44:11 +0530 Subject: [PATCH 2/3] docs(readme): Added index to "Deletes all topics in An Azure service bus" --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index ba63096..b2deb37 100644 --- a/README.md +++ b/README.md @@ -6,3 +6,4 @@ Welcome to the Gists repository of SLIIT FOSS. This repository is dedicated to h - [GitHub Account Switching Method with Two Accounts](multi-github.md) - [Running a MySQL Database Instance Using Docker](mysql-server-docker.md) +- [Deletes all topics in An Azure service bus](az-sb-delete-all-topics.md) \ No newline at end of file From 8e17a2b167cf58a81ad3cf93705fd6712460a07b Mon Sep 17 00:00:00 2001 From: QuintusJoyal Date: Thu, 9 May 2024 15:02:39 +0530 Subject: [PATCH 3/3] fix(az): fixes az-sb-delete-all-topics.md Fixed few formating Added Steps for alternative method --- az-sb-delete-all-topics.md | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/az-sb-delete-all-topics.md b/az-sb-delete-all-topics.md index 1773fd0..e5c3bde 100644 --- a/az-sb-delete-all-topics.md +++ b/az-sb-delete-all-topics.md @@ -1,6 +1,6 @@ # Deletes all topics in An Azure service bus -## Prerequisites: +## Prerequisites 1. **Azure CLI Installed**: Ensure you have Azure CLI installed on your system. You can download and install it from [here](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli). @@ -8,7 +8,7 @@ 3. **Access to Azure Service Bus**: You must have access to the Azure Service Bus namespace and the necessary permissions to delete topics. -## Steps to Setup and Usage: +## Steps to Setup 1. **Authenticate with Azure**: Run `az login` command to authenticate with your Azure account. @@ -38,11 +38,16 @@ az servicebus topic delete --resource-group $resource_group --namespace-name $na --- --- -# Alternative +# Alternative Method **Using `--query` global parameter**\ Uses JMESPath query string. See [Here](http://jmespath.org/) for more information and examples. +## Steps to Setup + +1. **Authenticate with Azure**: Run `az login` command to authenticate with your Azure account. + +2. **Save the Script**: Save the script with a `.sh` extension, for example, `delete_servicebus_topics.sh`. ```bash #!/bin/bash