Dismiss Notice

Register now to be one of the first members of this SharePoint Community! Click here it just takes seconds!

Dismiss Notice
Welcome Guest from Country Flag

Azure Function to Authenticate Azure PowerShell into the ARM APIs

Discussion in 'Official Microsoft News' started by William Eastbury, Mar 30, 2017.

Thread Status:
Not open for further replies.
  1. William Eastbury

    William Eastbury Guest

    Blog Posts:
    0
    Whilst working through a problem with a colleague I thought this would be a useful snippet to pop out there for ISVs who are deploying small scale tenant services or want to poll services and run Azure management processes in response to events. (This can be useful if your application design prevents you from using Autoscaling or VM Scale Sets in Azure, but you need to have some kind of flexibility in operations).

    Literally copy and paste this into a powershell function, and define a service principal with the right permissions to connect to the subscription – then put SP_AppID and SP_Secret into your functionapp settings.


    # Define an AppService setting SP_AppID to be the Azure AD Service Principal applicationid
    # Define the AppService setting SP_Secret to be an Azure AD Service Principal Secret

    $secpasswd = ConvertTo-SecureString $ENV:SP_Secret -AsPlainText -Force
    $mycreds = New-Object System.Management.Automation.PSCredential ($ENV:SP_AppID, $secpasswd)
    $result = Login-AzureRmAccount -ServicePrincipal -Tenant $ENV:SP_Tenant -Credential $mycreds

    # Now do / deploy whatever you need to with the AzureRm Powershell cmdlets

    You can host this on an Azure Functions Consumption Plan so this will cost you a minimal amount for hosting administrative processes.

    The use case my colleague (Mike Ormond) was interested in was dynamic deployment of an entire application tenant in response to an authenticated web request.

    In this case we would have fired the New-AzureRmResourceGroupDeployment cmdlet.

    New-AzureRmResourceGroupDeployment -ResourceGroupName $rg -TemplateFile $templatefile -Force -TemplateParameterFile $tempparamfile
    And voila, a dynamically deployed application tenant, based on a template, you can now manage that subscription fully via ARM from your Azure Functions.
    Now imagine if this function was bound via a storage queue to fire upon signup of a new tenant via a mgmt portal (say someone signs up with a credit card for your app).


    That’s all for now [​IMG]

    Continue reading...
     
Thread Status:
Not open for further replies.

Share This Page

LiveZilla Live Chat Software