-
Notifications
You must be signed in to change notification settings - Fork 206
/
Copy pathGet-AzStorageBlobs.ps1
113 lines (95 loc) · 4.05 KB
/
Get-AzStorageBlobs.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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#Requires -Version 5.0
#Requires -Modules Az.Storage
<#
.SYNOPSIS
Lists blobs in a container
.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 Container
[sr-en] Specifies the name of the container
[sr-de] Name des Containers
.Parameter BlobName
[sr-en] Specifies a name or name pattern, which can be used for a wildcard search
[sr-de] Name oder Pattern des Blobs
.Parameter IncludeDeleted
[sr-en] Include Deleted Blob, by default get blob won't include deleted blob
[sr-de] Gelöschte Blobs anzeigen
.Parameter ConcurrentTaskCount
[sr-en] Specifies the maximum concurrent network calls
[sr-de] Maximale gleichzeitige Netzwerk calls
.Parameter Prefix
[sr-en] Specifies a prefix for the blob names that you want to get.
You can use this to find all containers that start with the same string, parameter BlobName is ignored
[sr-de] Präfix für die Blob-Namen.
Alle Container, die mit der gleichen Zeichenfolge beginnen, der Parameter BlobName 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,
[Parameter(Mandatory = $true)]
[string]$Container,
[string]$BlobName,
[switch]$IncludeDeleted,
[int]$ConcurrentTaskCount = 10,
[string]$Prefix,
[int]$MaxCount = 25,
[ValidateSet('*','Name','IsDeleted','Length','LastModified','SnapshotTime','BlobType')]
[string[]]$Properties = @('Name','IsDeleted','Length','LastModified','BlobType')
)
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
'Container' = $Container
'ConcurrentTaskCount' = $ConcurrentTaskCount
'IncludeDeleted' = $IncludeDeleted
'MaxCount' = $MaxCount
}
if([System.String]::IsNullOrWhiteSpace($Prefix) -eq $false){
$cmdArgs.Add('Prefix',$Prefix)
}
elseif([System.String]::IsNullOrWhiteSpace($BlobName) -eq $false){
$cmdArgs.Add('Blob',$BlobName)
}
$ret = Get-AzStorageBlob @cmdArgs | Select-Object $Properties
if($SRXEnv) {
$SRXEnv.ResultMessage = $ret
}
else{
Write-Output $ret
}
}
catch{
throw
}
finally{
}