Corvus.Deployment.psm1
# <copyright file="Corvus.Deployment.psm1" company="Endjin Limited"> # Copyright (c) Endjin Limited. All rights reserved. # </copyright> <# .SYNOPSIS Contains a collection of useful utilities, templates and conventions for Azure deployment automation. .DESCRIPTION Contains a collection of useful utilities, templates and conventions for Azure deployment automation. .PARAMETER SubscriptionId The Azure Subscription that is the default target for any Azure operations. .PARAMETER AadTenantId The Azure Tenant that the Subscription belongs to. #> [CmdletBinding()] param ( [Parameter(Position=0)] $SubscriptionId, [Parameter(Position=1)] $AadTenantId ) $ErrorActionPreference = 'Stop' # Dynamically populate the module # # NOTE: # 1) Ignore any Pester test fixtures # # find all the functions that make-up this module $functions = Get-ChildItem -Recurse $PSScriptRoot/functions -Include *.ps1 | ` Where-Object { $_ -notmatch ".Tests.ps1" } # initialise the array that will be populated with the configuration handlers # when we dotsource the files below [array]$script:configHandlers = @() # dot source the individual scripts that make-up this module foreach ($function in ($functions)) { . $function.FullName } # export the non-private functions (by convention, private function scripts must begin with an '_' character) Export-ModuleMember -function ( $functions | ForEach-Object { (Get-Item $_).BaseName } | Where-Object { -not $_.StartsWith("_") } ) # ensure PowerShell Az modules are available $azAvailable = Get-Module Az -ListAvailable if ($null -eq $azAvailable) { Write-Warning "Az PowerShell modules are not installed - they can be installed using 'Install-Module Az -AllowClobber -Force'" } # This will track whether the current session has explicitly connected to a tenant/subscription $script:moduleContext = @{ SubscriptionId = $null AadTenantId = $null AzPowerShell = @{ Connected = $false } AzureCli = @{ Connected = $false } } # Validate the Azure connection details only if the details have been specified if ($SubscriptionId -and $AadTenantId) { Connect-Azure -SubscriptionId $SubscriptionId -AadTenantId $AadTenantId } else { Write-Host "The current Azure connection details have not been validated - use 'Connect-CorvusAzure' to get connected." } # define some useful globals / constants $script:AadGraphApiResourceId = "https://graph.windows.net/" |