# Auto-generated argument completers for parameters of SDK ConstantClass-derived type used in cmdlets. # Do not modify this file; it may be overwritten during version upgrades. $psMajorVersion = $PSVersionTable.PSVersion.Major if ($psMajorVersion -eq 2) { Write-Verbose "Dynamic argument completion not supported in PowerShell version 2; skipping load." return } # PowerShell's native Register-ArgumentCompleter cmdlet is available on v5.0 or higher. For lower # version, we can use the version in the TabExpansion++ module if installed. $registrationCmdletAvailable = ($psMajorVersion -ge 5) -Or !((Get-Command Register-ArgumentCompleter -ea Ignore) -eq $null) # internal function to perform the registration using either cmdlet or manipulation # of the options table function _awsArgumentCompleterRegistration() { param ( [scriptblock]$scriptBlock, [hashtable]$param2CmdletsMap ) if ($registrationCmdletAvailable) { foreach ($paramName in $param2CmdletsMap.Keys) { $args = @{ "ScriptBlock" = $scriptBlock "Parameter" = $paramName } $cmdletNames = $param2CmdletsMap[$paramName] if ($cmdletNames -And $cmdletNames.Length -gt 0) { $args["Command"] = $cmdletNames } Register-ArgumentCompleter @args } } else { if (-not $global:options) { $global:options = @{ CustomArgumentCompleters = @{ }; NativeArgumentCompleters = @{ } } } foreach ($paramName in $param2CmdletsMap.Keys) { $cmdletNames = $param2CmdletsMap[$paramName] if ($cmdletNames -And $cmdletNames.Length -gt 0) { foreach ($cn in $cmdletNames) { $fqn = [string]::Concat($cn, ":", $paramName) $global:options['CustomArgumentCompleters'][$fqn] = $scriptBlock } } else { $global:options['CustomArgumentCompleters'][$paramName] = $scriptBlock } } $function:tabexpansion2 = $function:tabexpansion2 -replace 'End\r\n{', 'End { if ($null -ne $options) { $options += $global:options} else {$options = $global:options}' } } # To allow for same-name parameters of different ConstantClass-derived types # each completer function checks on command name concatenated with parameter name. # Additionally, the standard code pattern for completers is to pipe through # sort-object after filtering against $wordToComplete but we omit this as our members # are already sorted. # Argument completions for service Amazon Route 53 Resolver $R53R_Completers = { param($commandName, $parameterName, $wordToComplete, $commandAst, $fakeBoundParameter) switch ($("$commandName/$parameterName")) { # Amazon.Route53Resolver.Action { ($_ -eq "Edit-R53RFirewallRule/Action") -Or ($_ -eq "Get-R53RFirewallRuleList/Action") -Or ($_ -eq "New-R53RFirewallRule/Action") } { $v = "ALERT","ALLOW","BLOCK" break } # Amazon.Route53Resolver.AutodefinedReverseFlag "Update-R53RResolverConfig/AutodefinedReverseFlag" { $v = "DISABLE","ENABLE","USE_LOCAL_RESOURCE_SETTING" break } # Amazon.Route53Resolver.BlockOverrideDnsType { ($_ -eq "Edit-R53RFirewallRule/BlockOverrideDnsType") -Or ($_ -eq "New-R53RFirewallRule/BlockOverrideDnsType") } { $v = "CNAME" break } # Amazon.Route53Resolver.BlockResponse { ($_ -eq "Edit-R53RFirewallRule/BlockResponse") -Or ($_ -eq "New-R53RFirewallRule/BlockResponse") } { $v = "NODATA","NXDOMAIN","OVERRIDE" break } # Amazon.Route53Resolver.FirewallDomainImportOperation "Import-R53RFirewallDomainList/Operation" { $v = "REPLACE" break } # Amazon.Route53Resolver.FirewallDomainUpdateOperation "Edit-R53RFirewallDomain/Operation" { $v = "ADD","REMOVE","REPLACE" break } # Amazon.Route53Resolver.FirewallFailOpenStatus "Edit-R53RFirewallConfig/FirewallFailOpen" { $v = "DISABLED","ENABLED","USE_LOCAL_RESOURCE_SETTING" break } # Amazon.Route53Resolver.FirewallRuleGroupAssociationStatus "Get-R53RFirewallRuleGroupAssociationList/Status" { $v = "COMPLETE","DELETING","UPDATING" break } # Amazon.Route53Resolver.MutationProtectionStatus { ($_ -eq "Edit-R53RFirewallRuleGroupAssociation/MutationProtection") -Or ($_ -eq "New-R53RFirewallRuleGroupAssociation/MutationProtection") } { $v = "DISABLED","ENABLED" break } # Amazon.Route53Resolver.ResolverEndpointDirection "New-R53RResolverEndpoint/Direction" { $v = "INBOUND","OUTBOUND" break } # Amazon.Route53Resolver.ResolverEndpointType { ($_ -eq "New-R53RResolverEndpoint/ResolverEndpointType") -Or ($_ -eq "Update-R53RResolverEndpoint/ResolverEndpointType") } { $v = "DUALSTACK","IPV4","IPV6" break } # Amazon.Route53Resolver.RuleTypeOption "New-R53RResolverRule/RuleType" { $v = "FORWARD","RECURSIVE","SYSTEM" break } # Amazon.Route53Resolver.SortOrder { ($_ -eq "Get-R53RResolverQueryLogConfigAssociationList/SortOrder") -Or ($_ -eq "Get-R53RResolverQueryLogConfigList/SortOrder") } { $v = "ASCENDING","DESCENDING" break } # Amazon.Route53Resolver.Validation "Update-R53RResolverDnssecConfig/Validation" { $v = "DISABLE","ENABLE","USE_LOCAL_RESOURCE_SETTING" break } } $v | Where-Object { $_ -like "$wordToComplete*" } | ForEach-Object { New-Object System.Management.Automation.CompletionResult $_, $_, 'ParameterValue', $_ } } $R53R_map = @{ "Action"=@("Edit-R53RFirewallRule","Get-R53RFirewallRuleList","New-R53RFirewallRule") "AutodefinedReverseFlag"=@("Update-R53RResolverConfig") "BlockOverrideDnsType"=@("Edit-R53RFirewallRule","New-R53RFirewallRule") "BlockResponse"=@("Edit-R53RFirewallRule","New-R53RFirewallRule") "Direction"=@("New-R53RResolverEndpoint") "FirewallFailOpen"=@("Edit-R53RFirewallConfig") "MutationProtection"=@("Edit-R53RFirewallRuleGroupAssociation","New-R53RFirewallRuleGroupAssociation") "Operation"=@("Edit-R53RFirewallDomain","Import-R53RFirewallDomainList") "ResolverEndpointType"=@("New-R53RResolverEndpoint","Update-R53RResolverEndpoint") "RuleType"=@("New-R53RResolverRule") "SortOrder"=@("Get-R53RResolverQueryLogConfigAssociationList","Get-R53RResolverQueryLogConfigList") "Status"=@("Get-R53RFirewallRuleGroupAssociationList") "Validation"=@("Update-R53RResolverDnssecConfig") } _awsArgumentCompleterRegistration $R53R_Completers $R53R_map $R53R_SelectCompleters = { param($commandName, $parameterName, $wordToComplete, $commandAst, $fakeBoundParameter) $cmdletType = Invoke-Expression "[Amazon.PowerShell.Cmdlets.R53R.$($commandName.Replace('-', ''))Cmdlet]" if (-not $cmdletType) { return } $awsCmdletAttribute = $cmdletType.GetCustomAttributes([Amazon.PowerShell.Common.AWSCmdletAttribute], $false) if (-not $awsCmdletAttribute) { return } $type = $awsCmdletAttribute.SelectReturnType if (-not $type) { return } $splitSelect = $wordToComplete -Split '\.' $splitSelect | Select-Object -First ($splitSelect.Length - 1) | ForEach-Object { $propertyName = $_ $properties = $type.GetProperties(('Instance', 'Public', 'DeclaredOnly')) | Where-Object { $_.Name -ieq $propertyName } if ($properties.Length -ne 1) { break } $type = $properties.PropertyType $prefix += "$($properties.Name)." $asEnumerableType = $type.GetInterface('System.Collections.Generic.IEnumerable`1') if ($asEnumerableType -and $type -ne [System.String]) { $type = $asEnumerableType.GetGenericArguments()[0] } } $v = @( '*' ) $properties = $type.GetProperties(('Instance', 'Public', 'DeclaredOnly')).Name | Sort-Object if ($properties) { $v += ($properties | ForEach-Object { $prefix + $_ }) } $parameters = $cmdletType.GetProperties(('Instance', 'Public')) | Where-Object { $_.GetCustomAttributes([System.Management.Automation.ParameterAttribute], $true) } | Select-Object -ExpandProperty Name | Sort-Object if ($parameters) { $v += ($parameters | ForEach-Object { "^$_" }) } $v | Where-Object { $_ -match "^$([System.Text.RegularExpressions.Regex]::Escape($wordToComplete)).*" } | ForEach-Object { New-Object System.Management.Automation.CompletionResult $_, $_, 'ParameterValue', $_ } } $R53R_SelectMap = @{ "Select"=@("New-R53RFirewallRuleGroupAssociation", "Add-R53RResolverEndpointIpAddressAssociation", "Add-R53RResolverQueryLogConfigAssociation", "Add-R53RResolverRuleAssociation", "New-R53RFirewallDomainList", "New-R53RFirewallRule", "New-R53RFirewallRuleGroup", "New-R53ROutpostResolver", "New-R53RResolverEndpoint", "New-R53RResolverQueryLogConfig", "New-R53RResolverRule", "Remove-R53RFirewallDomainList", "Remove-R53RFirewallRule", "Remove-R53RFirewallRuleGroup", "Remove-R53ROutpostResolver", "Remove-R53RResolverEndpoint", "Remove-R53RResolverQueryLogConfig", "Remove-R53RResolverRule", "Remove-R53RFirewallRuleGroupAssociation", "Remove-R53RResolverEndpointIpAddressAssociation", "Remove-R53RResolverQueryLogConfigAssociation", "Remove-R53RResolverRuleAssociation", "Get-R53RFirewallConfig", "Get-R53RFirewallDomainList", "Get-R53RFirewallRuleGroup", "Get-R53RFirewallRuleGroupAssociation", "Get-R53RFirewallRuleGroupPolicy", "Get-R53ROutpostResolver", "Get-R53RResolverConfig", "Get-R53RResolverDnssecConfig", "Get-R53RResolverEndpoint", "Get-R53RResolverQueryLogConfig", "Get-R53RResolverQueryLogConfigAssociation", "Get-R53RResolverQueryLogConfigPolicy", "Get-R53RResolverRule", "Get-R53RResolverRuleAssociation", "Get-R53RResolverRulePolicy", "Import-R53RFirewallDomainList", "Get-R53RFirewallConfigList", "Get-R53RFirewallDomainListList", "Get-R53RFirewallDomain", "Get-R53RFirewallRuleGroupAssociationList", "Get-R53RFirewallRuleGroupList", "Get-R53RFirewallRuleList", "Get-R53ROutpostResolverList", "Get-R53RResolverConfigList", "Get-R53RResolverDnssecConfigList", "Get-R53RResolverEndpointIpAddressList", "Get-R53RResolverEndpointList", "Get-R53RResolverQueryLogConfigAssociationList", "Get-R53RResolverQueryLogConfigList", "Get-R53RResolverRuleAssociationList", "Get-R53RResolverRuleList", "Get-R53RResourceTagList", "Edit-R53RFirewallRuleGroupPolicy", "Write-R53RResolverQueryLogConfigPolicy", "Set-R53RResolverRulePolicy", "Add-R53RResourceTag", "Remove-R53RResourceTag", "Edit-R53RFirewallConfig", "Edit-R53RFirewallDomain", "Edit-R53RFirewallRule", "Edit-R53RFirewallRuleGroupAssociation", "Update-R53ROutpostResolver", "Update-R53RResolverConfig", "Update-R53RResolverDnssecConfig", "Update-R53RResolverEndpoint", "Update-R53RResolverRule") } _awsArgumentCompleterRegistration $R53R_SelectCompleters $R53R_SelectMap