published on Tuesday, Mar 10, 2026 by Pulumi
published on Tuesday, Mar 10, 2026 by Pulumi
Provides information about AWS Regions. Can be used to filter regions i.e., by Opt-In status or only regions enabled for current account. To get details like endpoint and description of each region the data source can be combined with the aws.getRegion data source.
Example Usage
Enabled AWS Regions
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var current = Aws.GetRegions.Invoke();
});
package main
import (
"github.com/pulumi/pulumi-aws/sdk/v5/go/aws"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := aws.GetRegions(ctx, nil, nil)
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.AwsFunctions;
import com.pulumi.aws.inputs.GetRegionsArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var current = AwsFunctions.getRegions();
}
}
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const current = aws.getRegions({});
import pulumi
import pulumi_aws as aws
current = aws.get_regions()
variables:
current:
fn::invoke:
Function: aws:getRegions
Arguments: {}
All the regions regardless of the availability
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var current = Aws.GetRegions.Invoke(new()
{
AllRegions = true,
});
});
package main
import (
"github.com/pulumi/pulumi-aws/sdk/v5/go/aws"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := aws.GetRegions(ctx, &aws.GetRegionsArgs{
AllRegions: pulumi.BoolRef(true),
}, nil)
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.AwsFunctions;
import com.pulumi.aws.inputs.GetRegionsArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var current = AwsFunctions.getRegions(GetRegionsArgs.builder()
.allRegions(true)
.build());
}
}
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const current = aws.getRegions({
allRegions: true,
});
import pulumi
import pulumi_aws as aws
current = aws.get_regions(all_regions=True)
variables:
current:
fn::invoke:
Function: aws:getRegions
Arguments:
allRegions: true
or no results will be returned.
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var current = Aws.GetRegions.Invoke(new()
{
AllRegions = true,
Filters = new[]
{
new Aws.Inputs.GetRegionsFilterInputArgs
{
Name = "opt-in-status",
Values = new[]
{
"not-opted-in",
},
},
},
});
});
package main
import (
"github.com/pulumi/pulumi-aws/sdk/v5/go/aws"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := aws.GetRegions(ctx, &aws.GetRegionsArgs{
AllRegions: pulumi.BoolRef(true),
Filters: []aws.GetRegionsFilter{
{
Name: "opt-in-status",
Values: []string{
"not-opted-in",
},
},
},
}, nil)
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.AwsFunctions;
import com.pulumi.aws.inputs.GetRegionsArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var current = AwsFunctions.getRegions(GetRegionsArgs.builder()
.allRegions(true)
.filters(GetRegionsFilterArgs.builder()
.name("opt-in-status")
.values("not-opted-in")
.build())
.build());
}
}
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const current = aws.getRegions({
allRegions: true,
filters: [{
name: "opt-in-status",
values: ["not-opted-in"],
}],
});
import pulumi
import pulumi_aws as aws
current = aws.get_regions(all_regions=True,
filters=[aws.GetRegionsFilterArgs(
name="opt-in-status",
values=["not-opted-in"],
)])
variables:
current:
fn::invoke:
Function: aws:getRegions
Arguments:
allRegions: true
filters:
- name: opt-in-status
values:
- not-opted-in
Using getRegions
Two invocation forms are available. The direct form accepts plain arguments and either blocks until the result value is available, or returns a Promise-wrapped result. The output form accepts Input-wrapped arguments and returns an Output-wrapped result.
function getRegions(args: GetRegionsArgs, opts?: InvokeOptions): Promise<GetRegionsResult>
function getRegionsOutput(args: GetRegionsOutputArgs, opts?: InvokeOptions): Output<GetRegionsResult>def get_regions(all_regions: Optional[bool] = None,
filters: Optional[Sequence[GetRegionsFilter]] = None,
opts: Optional[InvokeOptions] = None) -> GetRegionsResult
def get_regions_output(all_regions: Optional[pulumi.Input[bool]] = None,
filters: Optional[pulumi.Input[Sequence[pulumi.Input[GetRegionsFilterArgs]]]] = None,
opts: Optional[InvokeOptions] = None) -> Output[GetRegionsResult]func GetRegions(ctx *Context, args *GetRegionsArgs, opts ...InvokeOption) (*GetRegionsResult, error)
func GetRegionsOutput(ctx *Context, args *GetRegionsOutputArgs, opts ...InvokeOption) GetRegionsResultOutput> Note: This function is named GetRegions in the Go SDK.
public static class GetRegions
{
public static Task<GetRegionsResult> InvokeAsync(GetRegionsArgs args, InvokeOptions? opts = null)
public static Output<GetRegionsResult> Invoke(GetRegionsInvokeArgs args, InvokeOptions? opts = null)
}public static CompletableFuture<GetRegionsResult> getRegions(GetRegionsArgs args, InvokeOptions options)
public static Output<GetRegionsResult> getRegions(GetRegionsArgs args, InvokeOptions options)
fn::invoke:
function: aws:index/getRegions:getRegions
arguments:
# arguments dictionaryThe following arguments are supported:
- All
Regions bool - If true the source will query all regions regardless of availability.
- Filters
List<Get
Regions Filter> - Configuration block(s) to use as filters. Detailed below.
- All
Regions bool - If true the source will query all regions regardless of availability.
- Filters
[]Get
Regions Filter - Configuration block(s) to use as filters. Detailed below.
- all
Regions Boolean - If true the source will query all regions regardless of availability.
- filters
List<Get
Regions Filter> - Configuration block(s) to use as filters. Detailed below.
- all
Regions boolean - If true the source will query all regions regardless of availability.
- filters
Get
Regions Filter[] - Configuration block(s) to use as filters. Detailed below.
- all_
regions bool - If true the source will query all regions regardless of availability.
- filters
Sequence[Get
Regions Filter] - Configuration block(s) to use as filters. Detailed below.
- all
Regions Boolean - If true the source will query all regions regardless of availability.
- filters List<Property Map>
- Configuration block(s) to use as filters. Detailed below.
getRegions Result
The following output properties are available:
- Id string
- The provider-assigned unique ID for this managed resource.
- Names List<string>
- Names of regions that meets the criteria.
- All
Regions bool - Filters
List<Get
Regions Filter>
- Id string
- The provider-assigned unique ID for this managed resource.
- Names []string
- Names of regions that meets the criteria.
- All
Regions bool - Filters
[]Get
Regions Filter
- id String
- The provider-assigned unique ID for this managed resource.
- names List<String>
- Names of regions that meets the criteria.
- all
Regions Boolean - filters
List<Get
Regions Filter>
- id string
- The provider-assigned unique ID for this managed resource.
- names string[]
- Names of regions that meets the criteria.
- all
Regions boolean - filters
Get
Regions Filter[]
- id str
- The provider-assigned unique ID for this managed resource.
- names Sequence[str]
- Names of regions that meets the criteria.
- all_
regions bool - filters
Sequence[Get
Regions Filter]
- id String
- The provider-assigned unique ID for this managed resource.
- names List<String>
- Names of regions that meets the criteria.
- all
Regions Boolean - filters List<Property Map>
Supporting Types
GetRegionsFilter
Package Details
- Repository
- AWS Classic pulumi/pulumi-aws
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the
awsTerraform Provider.
published on Tuesday, Mar 10, 2026 by Pulumi
