Interface IResource.Jsii$Default

All Superinterfaces:
software.constructs.IConstruct, software.constructs.IConstruct.Jsii$Default, software.constructs.IDependable, software.constructs.IDependable.Jsii$Default, IEnvironmentAware, IEnvironmentAware.Jsii$Default, IResource, IResource, IResource.Jsii$Default, IResourceRef, IResourceRef.Jsii$Default, software.amazon.jsii.JsiiSerializable
All Known Implementing Classes:
IResource.Jsii$Proxy
Enclosing interface:
IResource

@Internal public static interface IResource.Jsii$Default extends IResource, IResource.Jsii$Default, IResourceRef.Jsii$Default
Internal default implementation for IResource.
  • Method Details

    • getApi

      @Stability(Stable) @NotNull default IRestApi getApi()
      The rest API that this resource is part of.

      The reason we need the RestApi object itself and not just the ID is because the model is being tracked by the top-level RestApi object for the purpose of calculating it's hash to determine the ID of the deployment. This allows us to automatically update the deployment when the model of the REST API changes.

      Specified by:
      getApi in interface IResource
    • getPath

      @Stability(Stable) @NotNull default String getPath()
      The full path of this resource.
      Specified by:
      getPath in interface IResource
    • getResourceId

      @Stability(Stable) @NotNull default String getResourceId()
      The ID of the resource.
      Specified by:
      getResourceId in interface IResource
    • getDefaultCorsPreflightOptions

      @Stability(Stable) @Nullable default CorsOptions getDefaultCorsPreflightOptions()
      Default options for CORS preflight OPTIONS method.
      Specified by:
      getDefaultCorsPreflightOptions in interface IResource
    • getDefaultIntegration

      @Stability(Stable) @Nullable default Integration getDefaultIntegration()
      An integration to use as a default for all methods created within this API unless an integration is specified.
      Specified by:
      getDefaultIntegration in interface IResource
    • getDefaultMethodOptions

      @Stability(Stable) @Nullable default MethodOptions getDefaultMethodOptions()
      Method options to use as a default for all methods created within this API unless custom options are specified.
      Specified by:
      getDefaultMethodOptions in interface IResource
    • getParentResource

      @Stability(Stable) @Nullable default IResource getParentResource()
      The parent of this resource or undefined for the root resource.
      Specified by:
      getParentResource in interface IResource
    • addCorsPreflight

      @Stability(Stable) @NotNull default Method addCorsPreflight(@NotNull CorsOptions options)
      Adds an OPTIONS method to this resource which responds to Cross-Origin Resource Sharing (CORS) preflight requests.

      Cross-Origin Resource Sharing (CORS) is a mechanism that uses additional HTTP headers to tell browsers to give a web application running at one origin, access to selected resources from a different origin. A web application executes a cross-origin HTTP request when it requests a resource that has a different origin (domain, protocol, or port) from its own.

      Specified by:
      addCorsPreflight in interface IResource
      Parameters:
      options - CORS options. This parameter is required.
      Returns:
      a Method object
      See Also:
    • addMethod

      @Stability(Stable) @NotNull default Method addMethod(@NotNull String httpMethod, @Nullable Integration target, @Nullable MethodOptions options)
      Defines a new method for this resource.

      Specified by:
      addMethod in interface IResource
      Parameters:
      httpMethod - The HTTP method. This parameter is required.
      target - The target backend integration for this method.
      options - Method options, such as authentication.
      Returns:
      The newly created Method object.
    • addMethod

      @Stability(Stable) @NotNull default Method addMethod(@NotNull String httpMethod, @Nullable Integration target)
      Defines a new method for this resource.

      Specified by:
      addMethod in interface IResource
      Parameters:
      httpMethod - The HTTP method. This parameter is required.
      target - The target backend integration for this method.
      Returns:
      The newly created Method object.
    • addMethod

      @Stability(Stable) @NotNull default Method addMethod(@NotNull String httpMethod)
      Defines a new method for this resource.

      Specified by:
      addMethod in interface IResource
      Parameters:
      httpMethod - The HTTP method. This parameter is required.
      Returns:
      The newly created Method object.
    • addProxy

      @Stability(Stable) @NotNull default ProxyResource addProxy(@Nullable ProxyResourceOptions options)
      Adds a greedy proxy resource ("{proxy+}") and an ANY method to this route.

      Specified by:
      addProxy in interface IResource
      Parameters:
      options - Default integration and method options.
    • addProxy

      @Stability(Stable) @NotNull default ProxyResource addProxy()
      Adds a greedy proxy resource ("{proxy+}") and an ANY method to this route.
      Specified by:
      addProxy in interface IResource
    • addResource

      @Stability(Stable) @NotNull default Resource addResource(@NotNull String pathPart, @Nullable ResourceOptions options)
      Defines a new child resource where this resource is the parent.

      Specified by:
      addResource in interface IResource
      Parameters:
      pathPart - The path part for the child resource. This parameter is required.
      options - Resource options.
      Returns:
      A Resource object
    • addResource

      @Stability(Stable) @NotNull default Resource addResource(@NotNull String pathPart)
      Defines a new child resource where this resource is the parent.

      Specified by:
      addResource in interface IResource
      Parameters:
      pathPart - The path part for the child resource. This parameter is required.
      Returns:
      A Resource object
    • getResource

      @Stability(Stable) @Nullable default IResource getResource(@NotNull String pathPart)
      Retrieves a child resource by path part.

      Specified by:
      getResource in interface IResource
      Parameters:
      pathPart - The path part of the child resource. This parameter is required.
      Returns:
      the child resource or undefined if not found
    • resourceForPath

      @Stability(Stable) @NotNull default Resource resourceForPath(@NotNull String path)
      Gets or create all resources leading up to the specified path.

      • Path may only start with "/" if this method is called on the root resource.
      • All resources are created using default options.

      Specified by:
      resourceForPath in interface IResource
      Parameters:
      path - The relative path. This parameter is required.
      Returns:
      a new or existing resource.