forked from scriptrunner/ActionPacks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGet-AzStorageContainers.ps1
94 lines (79 loc) · 3.24 KB
/
Get-AzStorageContainers.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#Requires -Version 5.0
#Requires -Modules Az.Storage
<#
.SYNOPSIS
Gets the storage containers
.DESCRIPTION
.NOTES
This PowerShell script was developed and optimized for ScriptRunner. The use of the scripts requires ScriptRunner.
The customer or user is authorized to copy the script from the repository and use them in ScriptRunner.
The terms of use for ScriptRunner do not apply to this script. In particular, ScriptRunner Software GmbH assumes no liability for the function,
the use and the consequences of the use of this freely available script.
PowerShell is a product of Microsoft Corporation. ScriptRunner is a product of ScriptRunner Software GmbH.
© ScriptRunner Software GmbH
.COMPONENT
Requires Module Az.Storage
.LINK
https://github.com/scriptrunner/ActionPacks/blob/master/Azure/Storage
.Parameter StorageAccountName
[sr-en] Specifies the name of the Storage account to get containers
[sr-de] Name des Storage Accounts
.Parameter ResourceGroupName
[sr-en] Specifies the name of the resource group that contains the Storage containers to get
[sr-de] Name der resource group die die Storage Container enthält
.Parameter Name
[sr-en] Specifies the container name
[sr-de] Name des Containers
.Parameter Prefix
[sr-en] Specifies a prefix used in the name of the container or containers you want to get.
You can use this to find all containers that start with the same string, parameter Name is ignored
[sr-de] Präfix für den Container-Namen.
Alle Container, die mit der gleichen Zeichenfolge beginnen, der Parameter Name wird ignoriert
.Parameter MaxCount
[sr-en] Specifies the maximum number of objects that this cmdlet returns
[sr-de] Maximale Anzahl der Objekte
.Parameter Properties
[sr-en] List of properties to expand. Use * for all properties
[sr-de] Liste der zu anzuzeigenden Eigenschaften. Verwenden Sie * für alle Eigenschaften
#>
param(
[Parameter(Mandatory = $true)]
[string]$StorageAccountName,
[Parameter(Mandatory = $true)]
[string]$ResourceGroupName,
[string]$Name,
[string]$Prefix,
[int]$MaxCount = 25,
[ValidateSet('*','Name','LastModified','PublicAccess')]
[string[]]$Properties = @('Name','LastModified','PublicAccess')
)
Import-Module Az.Storage
try{
if($Properties -contains '*'){
$Properties = @('*')
}
$azAccount = $null
GetAzureStorageAccount -AccountName $StorageAccountName -ResourceGroupName $ResourceGroupName -StorageAccount ([ref]$azAccount)
[hashtable]$cmdArgs = @{'ErrorAction' = 'Stop'
'Context' = $azAccount.Context
'MaxCount' = $MaxCount
}
if([System.String]::IsNullOrWhiteSpace($Prefix) -eq $false){
$cmdArgs.Add('Prefix',$Prefix)
}
elseif([System.String]::IsNullOrWhiteSpace($Name) -eq $false){
$cmdArgs.Add('Name',$Name)
}
$ret = Get-AzStorageContainer @cmdArgs | Select-Object $Properties
if($SRXEnv) {
$SRXEnv.ResultMessage = $ret
}
else{
Write-Output $ret
}
}
catch{
throw
}
finally{
}