Skip to content

Commit

Permalink
remove dupes from whitelist
Browse files Browse the repository at this point in the history
  • Loading branch information
sondresjolyst committed Sep 14, 2023
1 parent 5cba3e6 commit 18b4521
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 4 deletions.
19 changes: 16 additions & 3 deletions scripts/acr/update_acr_whitelist.sh
Original file line number Diff line number Diff line change
Expand Up @@ -120,13 +120,21 @@ source ${RADIX_PLATFORM_REPOSITORY_PATH}/scripts/utility/lib_ip_whitelist.sh
### Fetch ACR IP whitelist from key vault
###

MASTER_ACR_IP_WHITELIST=$(az keyvault secret show --vault-name "${AZ_RESOURCE_KEYVAULT}" --name "${SECRET_NAME}" --query="value" -otsv | base64 --decode | jq '{whitelist:.whitelist | sort_by(.location | ascii_downcase)}' 2>/dev/null)
MASTER_ACR_IP_WHITELIST=$(az keyvault secret show \
--vault-name "${AZ_RESOURCE_KEYVAULT}" \
--name "${SECRET_NAME}" \
--query="value" \
--output tsv | base64 --decode | jq '{whitelist:.whitelist | unique_by(.ip) |sort_by(.location | ascii_downcase)}' 2>/dev/null)

#######################################################################################
### Run interactive wizard to modify IP whitelist
###

MASTER_ACR_IP_WHITELIST=$(az keyvault secret show --vault-name "${AZ_RESOURCE_KEYVAULT}" --name "${SECRET_NAME}" --query="value" -otsv | base64 --decode | jq '{whitelist:.whitelist | sort_by(.location | ascii_downcase)}' 2>/dev/null)
MASTER_ACR_IP_WHITELIST=$(az keyvault secret show \
--vault-name "${AZ_RESOURCE_KEYVAULT}" \
--name "${SECRET_NAME}" \
--query="value" \
--output tsv | base64 --decode | jq '{whitelist:.whitelist | unique_by(.ip) | sort_by(.location | ascii_downcase)}' 2>/dev/null)
temp_file_path="/tmp/$(uuidgen)"

if [[ -n "${IP_MASK}" ]]; then
Expand All @@ -153,7 +161,9 @@ function update-keyvault() {
if [[ -z "$updateKeyvault" ]]; then
updateKeyvault=true
fi

if [[ $updateKeyvault == false ]]; then return; fi

printf "\nUpdating keyvault \"%s\"... " "${AZ_RESOURCE_KEYVAULT}"
if [[ "$(az keyvault secret set --name "${SECRET_NAME}" --vault-name "${AZ_RESOURCE_KEYVAULT}" --value "${new_master_acr_ip_whitelist_base64}" --expires "$EXPIRY_DATE" 2>&1)" == *"ERROR"* ]]; then
printf "\nERROR: Could not update secret in keyvault \"%s\". Exiting..." "${AZ_RESOURCE_KEYVAULT}" >&2
Expand Down Expand Up @@ -188,7 +198,10 @@ function update-acr-firewall() {
current_ips_file_no_mask="/tmp/$(uuidgen)"
current_ips_file_with_duplicates="/tmp/$(uuidgen)"
jq <<<"${acr_ip_whitelist}" | jq -r '[.whitelist[].ip] | join("\n")' | sort | uniq >${desired_ips_file}
az acr network-rule list --name "${acr}" --subscription "${AZ_SUBSCRIPTION_ID}" --resource-group "${AZ_RESOURCE_GROUP_COMMON}" | jq -r '[.ipRules[].ipAddressOrRange] | join("\n")' >${current_ips_file_no_mask}
az acr network-rule list \
--name "${acr}" \
--subscription "${AZ_SUBSCRIPTION_ID}" \
--resource-group "${AZ_RESOURCE_GROUP_COMMON}" | jq -r '[.ipRules[].ipAddressOrRange] | join("\n")' >${current_ips_file_no_mask}
cat ${current_ips_file_no_mask} | grep -v "/" | xargs -I {} echo "{}/32" >>${current_ips_file_with_duplicates}
cat ${current_ips_file_no_mask} | grep "/" >>${current_ips_file_with_duplicates}
cat ${current_ips_file_with_duplicates} | sort | uniq >${current_ips_file}
Expand Down
6 changes: 5 additions & 1 deletion scripts/aks/update_api_server_whitelist.sh
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,11 @@ source ${RADIX_PLATFORM_REPOSITORY_PATH}/scripts/utility/lib_ip_whitelist.sh
### Prepare K8S API IP WHITELIST
###

MASTER_K8S_API_IP_WHITELIST=$(az keyvault secret show --vault-name "${AZ_RESOURCE_KEYVAULT}" --name "${SECRET_NAME}" --query="value" -otsv | base64 --decode | jq '{whitelist:.whitelist | sort_by(.location | ascii_downcase)}' 2>/dev/null)
MASTER_K8S_API_IP_WHITELIST=$(az keyvault secret show \
--vault-name "${AZ_RESOURCE_KEYVAULT}" \
--name "${SECRET_NAME}" \
--query="value" \
--output tsv | base64 --decode | jq '{whitelist:.whitelist | sort_by(.location | ascii_downcase)}' 2>/dev/null)

temp_file_path="/tmp/$(uuidgen)"
run-interactive-ip-whitelist-wizard "${MASTER_K8S_API_IP_WHITELIST}" "${temp_file_path}" "${USER_PROMPT}"
Expand Down

0 comments on commit 18b4521

Please sign in to comment.