AWS v7.10.0 published on Friday, Oct 24, 2025 by Pulumi
aws.apigateway.getRestApi
Use this data source to get the id and root_resource_id of a REST API in API Gateway. To fetch the REST API you must provide a name to match against. As there is no unique name constraint on REST APIs this data source will error if there is more than one match.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const myRestApi = aws.apigateway.getRestApi({
    name: "my-rest-api",
});
import pulumi
import pulumi_aws as aws
my_rest_api = aws.apigateway.get_rest_api(name="my-rest-api")
package main
import (
	"github.com/pulumi/pulumi-aws/sdk/v7/go/aws/apigateway"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_, err := apigateway.LookupRestApi(ctx, &apigateway.LookupRestApiArgs{
			Name: "my-rest-api",
		}, nil)
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() => 
{
    var myRestApi = Aws.ApiGateway.GetRestApi.Invoke(new()
    {
        Name = "my-rest-api",
    });
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.apigateway.ApigatewayFunctions;
import com.pulumi.aws.apigateway.inputs.GetRestApiArgs;
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 myRestApi = ApigatewayFunctions.getRestApi(GetRestApiArgs.builder()
            .name("my-rest-api")
            .build());
    }
}
variables:
  myRestApi:
    fn::invoke:
      function: aws:apigateway:getRestApi
      arguments:
        name: my-rest-api
Using getRestApi
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 getRestApi(args: GetRestApiArgs, opts?: InvokeOptions): Promise<GetRestApiResult>
function getRestApiOutput(args: GetRestApiOutputArgs, opts?: InvokeOptions): Output<GetRestApiResult>def get_rest_api(name: Optional[str] = None,
                 region: Optional[str] = None,
                 tags: Optional[Mapping[str, str]] = None,
                 opts: Optional[InvokeOptions] = None) -> GetRestApiResult
def get_rest_api_output(name: Optional[pulumi.Input[str]] = None,
                 region: Optional[pulumi.Input[str]] = None,
                 tags: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
                 opts: Optional[InvokeOptions] = None) -> Output[GetRestApiResult]func LookupRestApi(ctx *Context, args *LookupRestApiArgs, opts ...InvokeOption) (*LookupRestApiResult, error)
func LookupRestApiOutput(ctx *Context, args *LookupRestApiOutputArgs, opts ...InvokeOption) LookupRestApiResultOutput> Note: This function is named LookupRestApi in the Go SDK.
public static class GetRestApi 
{
    public static Task<GetRestApiResult> InvokeAsync(GetRestApiArgs args, InvokeOptions? opts = null)
    public static Output<GetRestApiResult> Invoke(GetRestApiInvokeArgs args, InvokeOptions? opts = null)
}public static CompletableFuture<GetRestApiResult> getRestApi(GetRestApiArgs args, InvokeOptions options)
public static Output<GetRestApiResult> getRestApi(GetRestApiArgs args, InvokeOptions options)
fn::invoke:
  function: aws:apigateway/getRestApi:getRestApi
  arguments:
    # arguments dictionaryThe following arguments are supported:
- Name string
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- Region string
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- Dictionary<string, string>
- Key-value map of resource tags.
- Name string
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- Region string
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- map[string]string
- Key-value map of resource tags.
- name String
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- region String
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- Map<String,String>
- Key-value map of resource tags.
- name string
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- region string
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- {[key: string]: string}
- Key-value map of resource tags.
- name str
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- region str
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- Mapping[str, str]
- Key-value map of resource tags.
- name String
- Name of the REST API to look up. If no REST API is found with this name, an error will be returned. If multiple REST APIs are found with this name, an error will be returned.
- region String
- Region where this resource will be managed. Defaults to the Region set in the provider configuration.
- Map<String>
- Key-value map of resource tags.
getRestApi Result
The following output properties are available:
- ApiKey stringSource 
- Source of the API key for requests.
- Arn string
- ARN of the REST API.
- BinaryMedia List<string>Types 
- List of binary media types supported by the REST API.
- Description string
- Description of the REST API.
- EndpointConfigurations List<GetRest Api Endpoint Configuration> 
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- ExecutionArn string
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- Id string
- The provider-assigned unique ID for this managed resource.
- MinimumCompression stringSize 
- Minimum response size to compress for the REST API.
- Name string
- Policy string
- JSON formatted policy document that controls access to the API Gateway.
- Region string
- RootResource stringId 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- Dictionary<string, string>
- Key-value map of resource tags.
- ApiKey stringSource 
- Source of the API key for requests.
- Arn string
- ARN of the REST API.
- BinaryMedia []stringTypes 
- List of binary media types supported by the REST API.
- Description string
- Description of the REST API.
- EndpointConfigurations []GetRest Api Endpoint Configuration 
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- ExecutionArn string
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- Id string
- The provider-assigned unique ID for this managed resource.
- MinimumCompression stringSize 
- Minimum response size to compress for the REST API.
- Name string
- Policy string
- JSON formatted policy document that controls access to the API Gateway.
- Region string
- RootResource stringId 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- map[string]string
- Key-value map of resource tags.
- apiKey StringSource 
- Source of the API key for requests.
- arn String
- ARN of the REST API.
- binaryMedia List<String>Types 
- List of binary media types supported by the REST API.
- description String
- Description of the REST API.
- endpointConfigurations List<GetRest Api Endpoint Configuration> 
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- executionArn String
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- id String
- The provider-assigned unique ID for this managed resource.
- minimumCompression StringSize 
- Minimum response size to compress for the REST API.
- name String
- policy String
- JSON formatted policy document that controls access to the API Gateway.
- region String
- rootResource StringId 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- Map<String,String>
- Key-value map of resource tags.
- apiKey stringSource 
- Source of the API key for requests.
- arn string
- ARN of the REST API.
- binaryMedia string[]Types 
- List of binary media types supported by the REST API.
- description string
- Description of the REST API.
- endpointConfigurations GetRest Api Endpoint Configuration[] 
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- executionArn string
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- id string
- The provider-assigned unique ID for this managed resource.
- minimumCompression stringSize 
- Minimum response size to compress for the REST API.
- name string
- policy string
- JSON formatted policy document that controls access to the API Gateway.
- region string
- rootResource stringId 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- {[key: string]: string}
- Key-value map of resource tags.
- api_key_ strsource 
- Source of the API key for requests.
- arn str
- ARN of the REST API.
- binary_media_ Sequence[str]types 
- List of binary media types supported by the REST API.
- description str
- Description of the REST API.
- endpoint_configurations Sequence[GetRest Api Endpoint Configuration] 
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- execution_arn str
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- id str
- The provider-assigned unique ID for this managed resource.
- minimum_compression_ strsize 
- Minimum response size to compress for the REST API.
- name str
- policy str
- JSON formatted policy document that controls access to the API Gateway.
- region str
- root_resource_ strid 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- Mapping[str, str]
- Key-value map of resource tags.
- apiKey StringSource 
- Source of the API key for requests.
- arn String
- ARN of the REST API.
- binaryMedia List<String>Types 
- List of binary media types supported by the REST API.
- description String
- Description of the REST API.
- endpointConfigurations List<Property Map>
- The endpoint configuration of this RestApi showing the endpoint types of the API.
- executionArn String
- Execution ARN part to be used in lambda_permission'ssource_arnwhen allowing API Gateway to invoke a Lambda function, e.g.,arn:aws:execute-api:eu-west-2:123456789012:z4675bid1j, which can be concatenated with allowed stage, method and resource path.
- id String
- The provider-assigned unique ID for this managed resource.
- minimumCompression StringSize 
- Minimum response size to compress for the REST API.
- name String
- policy String
- JSON formatted policy document that controls access to the API Gateway.
- region String
- rootResource StringId 
- Set to the ID of the API Gateway Resource on the found REST API where the route matches '/'.
- Map<String>
- Key-value map of resource tags.
Supporting Types
GetRestApiEndpointConfiguration    
- IpAddress stringType 
- The IP address types that can invoke an API (RestApi).
- Types List<string>
- List of endpoint types.
- VpcEndpoint List<string>Ids 
- Set of VPC Endpoint identifiers.
- IpAddress stringType 
- The IP address types that can invoke an API (RestApi).
- Types []string
- List of endpoint types.
- VpcEndpoint []stringIds 
- Set of VPC Endpoint identifiers.
- ipAddress StringType 
- The IP address types that can invoke an API (RestApi).
- types List<String>
- List of endpoint types.
- vpcEndpoint List<String>Ids 
- Set of VPC Endpoint identifiers.
- ipAddress stringType 
- The IP address types that can invoke an API (RestApi).
- types string[]
- List of endpoint types.
- vpcEndpoint string[]Ids 
- Set of VPC Endpoint identifiers.
- ip_address_ strtype 
- The IP address types that can invoke an API (RestApi).
- types Sequence[str]
- List of endpoint types.
- vpc_endpoint_ Sequence[str]ids 
- Set of VPC Endpoint identifiers.
- ipAddress StringType 
- The IP address types that can invoke an API (RestApi).
- types List<String>
- List of endpoint types.
- vpcEndpoint List<String>Ids 
- Set of VPC Endpoint identifiers.
Package Details
- Repository
- AWS Classic pulumi/pulumi-aws
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the awsTerraform Provider.
