AzSK ― Secure DevOps Kit for Azure, is a group of settings and scripts to analyze and improve the security of your Azure environments. It looks at six areas: Subscription Security, Security Verification Tests and IntelliSense, CI/CD Build/Release Extensions, Continuous Assurance Runbooks, OMS Solutions, and Cloud Risk Governance. In this article, I will focus on how to use AzSk to improve the security of your subscriptions.
Installing AzSKTo use AzSK, you first need a machine provisioned with windows and PowerShell ISE, which you can download here if you do not already have it available. In the open PowerShell ISE window, verify the version of PowerShell. (It needs to be 5.0 or higher.) To perform a check, run this command:
> $PSVersionTabledata:image/s3,"s3://crabby-images/bf8df/bf8df2a92ee7d25ff9eb5b04176055a9770b362b" alt="Making Your Subscriptions Safer with AzSK"
Now, with the machine ready to install AzSK, run the command below to install it for your user:
> Install-Module AzSK -Scope CurrentUserIf you do not have NuGetProvider and PSGallery installed, the script will recommend it to you automatically. You will just need to Accept to move on. Once the installation is finished, a window will open with a sign-in form into Azure, complete with your credentials and confirmation of login. That’s it ― AzSK is correctly installed and ready to use.
Checking the status of the subscriptionGo to portal.azure.com, find “Subscriptions” and copy the subscription ID that will be used to analyze security levels. Then, in PowerShell ISE, type the command to start the check:
> Get-AzSKSubscriptionSecurityStatus -SubscriptionId ID_OF_SUBSCRIPTIONdata:image/s3,"s3://crabby-images/5b61f/5b61fac46b41aa6fbe33175cdd6b07ffde1d0a11" alt="Making Your Subscriptions Safer with AzSK"
Agree with the privacy terms to continue. The process could take a while depending on your subscription’s size. When it’s finished, a log file will be created in the directory: C:\Users\IEUser\AppData\Local\Microsoft\AzSKLogs\Sub_VisualStudioEnterpriseBizSpark\TIMESTAMP_GSS. The name of the file is SecurityReport-TIMESTAMP.csv. This log contains found issues’ statuses, severity, descriptions, and recommendations.
In the PowerShell log, we can see the verifications and the total Passed and Failed results.
data:image/s3,"s3://crabby-images/8c434/8c4340861b4d463449d50fc616f5bf2fb8ea1b0b" alt="Making Your Subscriptions Safer with AzSK"
data:image/s3,"s3://crabby-images/08b7f/08b7fec956522244397486b5fd7dd03d7d798942" alt="Making Your Subscriptions Safer with AzSK"
Fixing security issues Azure Security Center (ASC) must be correctly configured for the subscription
One of the recommendations listed in the CSV file suggests configuring the Azure Security Center (ASC). The Azure Security Center offers security management with the ability to create and apply security policies.
To set up the Azure Security Center, provide your contact data (email and phone number) by including it in the command below. In the email field, you can use a comma to separate email addresses.
> Set-AzSKAzureSecurityCenterPolicies -SubscriptionId ID_OF_SUBSCRIPTION -SecurityContactEmails 'email@domain.com' -SecurityPhoneNumber '+1234567890'In Azure Portal, access Subscriptions > ID_OF_SUBSCRIPTION > Policies and check that ASC Default policy is enabled.
data:image/s3,"s3://crabby-images/3c227/3c227090f7b837dc8a1aa4bd178e6f733aa4494e" alt="Making Your Subscriptions Safer with AzSK"
Alerts must be configured for critical actions on subscriptions and resources
Another suggested recommendation is to enable action alerts on the subscription’s security. To set up alerts, run the command below, and include the email address that will receive the notifications.
> Set-AzSKAlerts -SubscriptionId ID_OF_SUBSCRIPTION -SecurityContactEmails ‘email@domain.com’You will then receive an email confirming that the subscription was added to an Azure Monitor action group.
data:image/s3,"s3://crabby-images/bc561/bc561c688278b20afd1cad78ea9d1f836e9c2117" alt="Making Your Subscriptions Safer with AzSK"
Verify the list of public IP addresses on your subscription
The removal of unused IP public addresses is also strongly recommended. Run the command below to list all of your public IPs.
> Get-AzureRmPublicIPAddressThe IP addresses ready to be removed have a “Not Assigned” label in the IP number column. But this status does not reflect the association with the network interface. If the IP address was associated with the network interface, it will be shown as “Not Assigned,” but deletion of the IP address will not be allowed until you disassociate it.
> Remove-AzureRmPublicIpAddress -Name NAME_OF_IP -ResourceGroupName NAME_OF_RESOURCE_GROUPTo remove an IP address, run the command above, filling the name of the IP address and the resource group. It will show a confirmation prompt, asking if you are sure you want to delete the public IP. Be alert, because this operation cannot be undone.
ConclusionThe effort to apply these security recommendations is worth it to help ensure a secure and healthy environment. What you choose to do with the recommendations is up to you, but with the critical importance of good security, the maximum you can do is considered a good start ― so take advantage of the six areas offered by AzSK to help secure your subscriptions.
data:image/s3,"s3://crabby-images/4ba34/4ba34ac77eec03f5c265098b0266cbe222e9c8cc" alt="Making Your Subscriptions Safer with AzSK"
Do you think you can beat this Sweet post? If so, you may have what it takes to become a Sweetcode contributor...Learn More.