{ "version":"2.0", "metadata":{ "apiVersion":"2021-09-30", "endpointPrefix":"cloudcontrolapi", "jsonVersion":"1.0", "protocol":"json", "serviceAbbreviation":"CloudControlApi", "serviceFullName":"AWS Cloud Control API", "serviceId":"CloudControl", "signatureVersion":"v4", "signingName":"cloudcontrolapi", "targetPrefix":"CloudApiService", "uid":"cloudcontrol-2021-09-30" }, "operations":{ "CancelResourceRequest":{ "name":"CancelResourceRequest", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"CancelResourceRequestInput"}, "output":{"shape":"CancelResourceRequestOutput"}, "errors":[ {"shape":"RequestTokenNotFoundException"}, {"shape":"ConcurrentModificationException"} ], "documentation":"

Cancels the specified resource operation request. For more information, see Canceling resource operation requests in the Amazon Web Services Cloud Control API User Guide.

Only resource operations requests with a status of PENDING or IN_PROGRESS can be cancelled.

", "idempotent":true }, "CreateResource":{ "name":"CreateResource", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"CreateResourceInput"}, "output":{"shape":"CreateResourceOutput"}, "errors":[ {"shape":"ConcurrentOperationException"}, {"shape":"ClientTokenConflictException"}, {"shape":"UnsupportedActionException"}, {"shape":"TypeNotFoundException"}, {"shape":"AlreadyExistsException"}, {"shape":"GeneralServiceException"}, {"shape":"HandlerInternalFailureException"}, {"shape":"InvalidCredentialsException"}, {"shape":"InvalidRequestException"}, {"shape":"NetworkFailureException"}, {"shape":"ResourceNotFoundException"}, {"shape":"NotStabilizedException"}, {"shape":"NotUpdatableException"}, {"shape":"ResourceConflictException"}, {"shape":"ServiceInternalErrorException"}, {"shape":"ServiceLimitExceededException"}, {"shape":"ThrottlingException"}, {"shape":"PrivateTypeException"}, {"shape":"HandlerFailureException"} ], "documentation":"

Creates the specified resource. For more information, see Creating a resource in the Amazon Web Services Cloud Control API User Guide.

After you have initiated a resource creation request, you can monitor the progress of your request by calling GetResourceRequestStatus using the RequestToken of the ProgressEvent type returned by CreateResource.

" }, "DeleteResource":{ "name":"DeleteResource", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"DeleteResourceInput"}, "output":{"shape":"DeleteResourceOutput"}, "errors":[ {"shape":"ConcurrentOperationException"}, {"shape":"ClientTokenConflictException"}, {"shape":"UnsupportedActionException"}, {"shape":"TypeNotFoundException"}, {"shape":"AlreadyExistsException"}, {"shape":"GeneralServiceException"}, {"shape":"HandlerInternalFailureException"}, {"shape":"InvalidCredentialsException"}, {"shape":"InvalidRequestException"}, {"shape":"NetworkFailureException"}, {"shape":"ResourceNotFoundException"}, {"shape":"NotStabilizedException"}, {"shape":"NotUpdatableException"}, {"shape":"ResourceConflictException"}, {"shape":"ServiceInternalErrorException"}, {"shape":"ServiceLimitExceededException"}, {"shape":"ThrottlingException"}, {"shape":"PrivateTypeException"}, {"shape":"HandlerFailureException"} ], "documentation":"

Deletes the specified resource. For details, see Deleting a resource in the Amazon Web Services Cloud Control API User Guide.

After you have initiated a resource deletion request, you can monitor the progress of your request by calling GetResourceRequestStatus using the RequestToken of the ProgressEvent returned by DeleteResource.

" }, "GetResource":{ "name":"GetResource", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"GetResourceInput"}, "output":{"shape":"GetResourceOutput"}, "errors":[ {"shape":"UnsupportedActionException"}, {"shape":"TypeNotFoundException"}, {"shape":"AlreadyExistsException"}, {"shape":"GeneralServiceException"}, {"shape":"HandlerInternalFailureException"}, {"shape":"InvalidCredentialsException"}, {"shape":"InvalidRequestException"}, {"shape":"NetworkFailureException"}, {"shape":"ResourceNotFoundException"}, {"shape":"NotStabilizedException"}, {"shape":"NotUpdatableException"}, {"shape":"ResourceConflictException"}, {"shape":"ServiceInternalErrorException"}, {"shape":"ServiceLimitExceededException"}, {"shape":"ThrottlingException"}, {"shape":"PrivateTypeException"}, {"shape":"HandlerFailureException"} ], "documentation":"

Returns information about the current state of the specified resource. For details, see Reading a resource's current state.

You can use this action to return information about an existing resource in your account and Amazon Web Services Region, whether or not those resources were provisioned using Cloud Control API.

" }, "GetResourceRequestStatus":{ "name":"GetResourceRequestStatus", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"GetResourceRequestStatusInput"}, "output":{"shape":"GetResourceRequestStatusOutput"}, "errors":[ {"shape":"RequestTokenNotFoundException"} ], "documentation":"

Returns the current status of a resource operation request. For more information, see Tracking the progress of resource operation requests in the Amazon Web Services Cloud Control API User Guide.

" }, "ListResourceRequests":{ "name":"ListResourceRequests", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"ListResourceRequestsInput"}, "output":{"shape":"ListResourceRequestsOutput"}, "documentation":"

Returns existing resource operation requests. This includes requests of all status types. For more information, see Listing active resource operation requests in the Amazon Web Services Cloud Control API User Guide.

Resource operation requests expire after seven days.

" }, "ListResources":{ "name":"ListResources", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"ListResourcesInput"}, "output":{"shape":"ListResourcesOutput"}, "errors":[ {"shape":"UnsupportedActionException"}, {"shape":"TypeNotFoundException"}, {"shape":"AlreadyExistsException"}, {"shape":"GeneralServiceException"}, {"shape":"HandlerInternalFailureException"}, {"shape":"InvalidCredentialsException"}, {"shape":"InvalidRequestException"}, {"shape":"NetworkFailureException"}, {"shape":"ResourceNotFoundException"}, {"shape":"NotStabilizedException"}, {"shape":"NotUpdatableException"}, {"shape":"ResourceConflictException"}, {"shape":"ServiceInternalErrorException"}, {"shape":"ServiceLimitExceededException"}, {"shape":"ThrottlingException"}, {"shape":"PrivateTypeException"}, {"shape":"HandlerFailureException"} ], "documentation":"

Returns information about the specified resources. For more information, see Discovering resources in the Amazon Web Services Cloud Control API User Guide.

You can use this action to return information about existing resources in your account and Amazon Web Services Region, whether or not those resources were provisioned using Cloud Control API.

" }, "UpdateResource":{ "name":"UpdateResource", "http":{ "method":"POST", "requestUri":"/" }, "input":{"shape":"UpdateResourceInput"}, "output":{"shape":"UpdateResourceOutput"}, "errors":[ {"shape":"ConcurrentOperationException"}, {"shape":"ClientTokenConflictException"}, {"shape":"UnsupportedActionException"}, {"shape":"TypeNotFoundException"}, {"shape":"AlreadyExistsException"}, {"shape":"GeneralServiceException"}, {"shape":"HandlerInternalFailureException"}, {"shape":"InvalidCredentialsException"}, {"shape":"InvalidRequestException"}, {"shape":"NetworkFailureException"}, {"shape":"ResourceNotFoundException"}, {"shape":"NotStabilizedException"}, {"shape":"NotUpdatableException"}, {"shape":"ResourceConflictException"}, {"shape":"ServiceInternalErrorException"}, {"shape":"ServiceLimitExceededException"}, {"shape":"ThrottlingException"}, {"shape":"PrivateTypeException"}, {"shape":"HandlerFailureException"} ], "documentation":"

Updates the specified property values in the resource.

You specify your resource property updates as a list of patch operations contained in a JSON patch document that adheres to the RFC 6902 - JavaScript Object Notation (JSON) Patch standard.

For details on how Cloud Control API performs resource update operations, see Updating a resource in the Amazon Web Services Cloud Control API User Guide.

After you have initiated a resource update request, you can monitor the progress of your request by calling GetResourceRequestStatus using the RequestToken of the ProgressEvent returned by UpdateResource.

For more information about the properties of a specific resource, refer to the related topic for the resource in the Resource and property types reference in the Amazon Web Services CloudFormation Users Guide.

" } }, "shapes":{ "AlreadyExistsException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource with the name requested already exists.

", "exception":true }, "CancelResourceRequestInput":{ "type":"structure", "required":["RequestToken"], "members":{ "RequestToken":{ "shape":"RequestToken", "documentation":"

The RequestToken of the ProgressEvent object returned by the resource operation request.

" } } }, "CancelResourceRequestOutput":{ "type":"structure", "members":{ "ProgressEvent":{"shape":"ProgressEvent"} } }, "ClientToken":{ "type":"string", "max":128, "min":1, "pattern":"[-A-Za-z0-9+/=]+" }, "ClientTokenConflictException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The specified client token has already been used in another resource request.

It is best practice for client tokens to be unique for each resource operation request. However, client token expire after 36 hours.

", "exception":true }, "ConcurrentModificationException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource is currently being modified by another operation.

", "exception":true }, "ConcurrentOperationException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

Another resource operation is currently being performed on this resource.

", "exception":true }, "CreateResourceInput":{ "type":"structure", "required":[ "TypeName", "DesiredState" ], "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "TypeVersionId":{ "shape":"TypeVersionId", "documentation":"

For private resource types, the type version to use in this resource operation. If you do not specify a resource version, CloudFormation uses the default version.

" }, "RoleArn":{ "shape":"RoleArn", "documentation":"

The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) for Cloud Control API to use when performing this resource operation. The role specified must have the permissions required for this operation. The necessary permissions for each event handler are defined in the handlers section of the resource type definition schema.

If you do not specify a role, Cloud Control API uses a temporary session created using your Amazon Web Services user credentials.

For more information, see Specifying credentials in the Amazon Web Services Cloud Control API User Guide.

" }, "ClientToken":{ "shape":"ClientToken", "documentation":"

A unique identifier to ensure the idempotency of the resource request. As a best practice, specify this token to ensure idempotency, so that Amazon Web Services Cloud Control API can accurately distinguish between request retries and new resource requests. You might retry a resource request to ensure that it was successfully received.

A client token is valid for 36 hours once used. After that, a resource request with the same client token is treated as a new request.

If you do not specify a client token, one is generated for inclusion in the request.

For more information, see Ensuring resource operation requests are unique in the Amazon Web Services Cloud Control API User Guide.

", "idempotencyToken":true }, "DesiredState":{ "shape":"Properties", "documentation":"

Structured data format representing the desired state of the resource, consisting of that resource's properties and their desired values.

Cloud Control API currently supports JSON as a structured data format.

Specify the desired state as one of the following:

For more information, see Composing the desired state of the resource in the Amazon Web Services Cloud Control API User Guide.

For more information about the properties of a specific resource, refer to the related topic for the resource in the Resource and property types reference in the Amazon Web Services CloudFormation Users Guide.

" } } }, "CreateResourceOutput":{ "type":"structure", "members":{ "ProgressEvent":{ "shape":"ProgressEvent", "documentation":"

Represents the current status of the resource creation request.

After you have initiated a resource creation request, you can monitor the progress of your request by calling GetResourceRequestStatus using the RequestToken of the ProgressEvent returned by CreateResource.

" } } }, "DeleteResourceInput":{ "type":"structure", "required":[ "TypeName", "Identifier" ], "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "TypeVersionId":{ "shape":"TypeVersionId", "documentation":"

For private resource types, the type version to use in this resource operation. If you do not specify a resource version, CloudFormation uses the default version.

" }, "RoleArn":{ "shape":"RoleArn", "documentation":"

The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) for Cloud Control API to use when performing this resource operation. The role specified must have the permissions required for this operation. The necessary permissions for each event handler are defined in the handlers section of the resource type definition schema.

If you do not specify a role, Cloud Control API uses a temporary session created using your Amazon Web Services user credentials.

For more information, see Specifying credentials in the Amazon Web Services Cloud Control API User Guide.

" }, "ClientToken":{ "shape":"ClientToken", "documentation":"

A unique identifier to ensure the idempotency of the resource request. As a best practice, specify this token to ensure idempotency, so that Amazon Web Services Cloud Control API can accurately distinguish between request retries and new resource requests. You might retry a resource request to ensure that it was successfully received.

A client token is valid for 36 hours once used. After that, a resource request with the same client token is treated as a new request.

If you do not specify a client token, one is generated for inclusion in the request.

For more information, see Ensuring resource operation requests are unique in the Amazon Web Services Cloud Control API User Guide.

", "idempotencyToken":true }, "Identifier":{ "shape":"Identifier", "documentation":"

The identifier for the resource.

You can specify the primary identifier, or any secondary identifier defined for the resource type in its resource schema. You can only specify one identifier. Primary identifiers can be specified as a string or JSON; secondary identifiers must be specified as JSON.

For compound primary identifiers (that is, one that consists of multiple resource properties strung together), to specify the primary identifier as a string, list the property values in the order they are specified in the primary identifier definition, separated by |.

For more information, see Identifying resources in the Amazon Web Services Cloud Control API User Guide.

" } } }, "DeleteResourceOutput":{ "type":"structure", "members":{ "ProgressEvent":{ "shape":"ProgressEvent", "documentation":"

Represents the current status of the resource deletion request.

After you have initiated a resource deletion request, you can monitor the progress of your request by calling GetResourceRequestStatus using the RequestToken of the ProgressEvent returned by DeleteResource.

" } } }, "ErrorMessage":{ "type":"string", "max":1024, "min":1 }, "GeneralServiceException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that the downstream service generated an error that does not map to any other handler error code.

", "exception":true }, "GetResourceInput":{ "type":"structure", "required":[ "TypeName", "Identifier" ], "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "TypeVersionId":{ "shape":"TypeVersionId", "documentation":"

For private resource types, the type version to use in this resource operation. If you do not specify a resource version, CloudFormation uses the default version.

" }, "RoleArn":{ "shape":"RoleArn", "documentation":"

The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) for Cloud Control API to use when performing this resource operation. The role specified must have the permissions required for this operation. The necessary permissions for each event handler are defined in the handlers section of the resource type definition schema.

If you do not specify a role, Cloud Control API uses a temporary session created using your Amazon Web Services user credentials.

For more information, see Specifying credentials in the Amazon Web Services Cloud Control API User Guide.

" }, "Identifier":{ "shape":"Identifier", "documentation":"

The identifier for the resource.

You can specify the primary identifier, or any secondary identifier defined for the resource type in its resource schema. You can only specify one identifier. Primary identifiers can be specified as a string or JSON; secondary identifiers must be specified as JSON.

For compound primary identifiers (that is, one that consists of multiple resource properties strung together), to specify the primary identifier as a string, list the property values in the order they are specified in the primary identifier definition, separated by |.

For more information, see Identifying resources in the Amazon Web Services Cloud Control API User Guide.

" } } }, "GetResourceOutput":{ "type":"structure", "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "ResourceDescription":{"shape":"ResourceDescription"} } }, "GetResourceRequestStatusInput":{ "type":"structure", "required":["RequestToken"], "members":{ "RequestToken":{ "shape":"RequestToken", "documentation":"

A unique token used to track the progress of the resource operation request.

Request tokens are included in the ProgressEvent type returned by a resource operation request.

" } } }, "GetResourceRequestStatusOutput":{ "type":"structure", "members":{ "ProgressEvent":{ "shape":"ProgressEvent", "documentation":"

Represents the current status of the resource operation request.

" } } }, "HandlerErrorCode":{ "type":"string", "enum":[ "NotUpdatable", "InvalidRequest", "AccessDenied", "InvalidCredentials", "AlreadyExists", "NotFound", "ResourceConflict", "Throttling", "ServiceLimitExceeded", "NotStabilized", "GeneralServiceException", "ServiceInternalError", "ServiceTimeout", "NetworkFailure", "InternalFailure" ] }, "HandlerFailureException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has failed without a returning a more specific error code. This can include timeouts.

", "exception":true }, "HandlerInternalFailureException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that an unexpected error occurred within the resource handler.

", "exception":true }, "HandlerNextToken":{ "type":"string", "max":2048, "min":1, "pattern":".+" }, "Identifier":{ "type":"string", "max":1024, "min":1, "pattern":".+" }, "InvalidCredentialsException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that the credentials provided by the user are invalid.

", "exception":true }, "InvalidRequestException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that invalid input from the user has generated a generic exception.

", "exception":true }, "ListResourceRequestsInput":{ "type":"structure", "members":{ "MaxResults":{ "shape":"MaxResults", "documentation":"

The maximum number of results to be returned with a single call. If the number of available results exceeds this maximum, the response includes a NextToken value that you can assign to the NextToken request parameter to get the next set of results.

The default is 20.

" }, "NextToken":{ "shape":"NextToken", "documentation":"

If the previous paginated request didn't return all of the remaining results, the response object's NextToken parameter value is set to a token. To retrieve the next set of results, call this action again and assign that token to the request object's NextToken parameter. If there are no remaining results, the previous response object's NextToken parameter is set to null.

" }, "ResourceRequestStatusFilter":{ "shape":"ResourceRequestStatusFilter", "documentation":"

The filter criteria to apply to the requests returned.

" } } }, "ListResourceRequestsOutput":{ "type":"structure", "members":{ "ResourceRequestStatusSummaries":{ "shape":"ResourceRequestStatusSummaries", "documentation":"

The requests that match the specified filter criteria.

" }, "NextToken":{ "shape":"NextToken", "documentation":"

If the request doesn't return all of the remaining results, NextToken is set to a token. To retrieve the next set of results, call ListResources again and assign that token to the request object's NextToken parameter. If the request returns all results, NextToken is set to null.

" } } }, "ListResourcesInput":{ "type":"structure", "required":["TypeName"], "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "TypeVersionId":{ "shape":"TypeVersionId", "documentation":"

For private resource types, the type version to use in this resource operation. If you do not specify a resource version, CloudFormation uses the default version.

" }, "RoleArn":{ "shape":"RoleArn", "documentation":"

The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) for Cloud Control API to use when performing this resource operation. The role specified must have the permissions required for this operation. The necessary permissions for each event handler are defined in the handlers section of the resource type definition schema.

If you do not specify a role, Cloud Control API uses a temporary session created using your Amazon Web Services user credentials.

For more information, see Specifying credentials in the Amazon Web Services Cloud Control API User Guide.

" }, "NextToken":{ "shape":"HandlerNextToken", "documentation":"

If the previous paginated request didn't return all of the remaining results, the response object's NextToken parameter value is set to a token. To retrieve the next set of results, call this action again and assign that token to the request object's NextToken parameter. If there are no remaining results, the previous response object's NextToken parameter is set to null.

" }, "MaxResults":{ "shape":"MaxResults", "documentation":"

The maximum number of results to be returned with a single call. If the number of available results exceeds this maximum, the response includes a NextToken value that you can assign to the NextToken request parameter to get the next set of results.

The default is 20.

" }, "ResourceModel":{ "shape":"Properties", "documentation":"

The resource model to use to select the resources to return.

" } } }, "ListResourcesOutput":{ "type":"structure", "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "ResourceDescriptions":{ "shape":"ResourceDescriptions", "documentation":"

Information about the specified resources, including primary identifier and resource model.

" }, "NextToken":{ "shape":"HandlerNextToken", "documentation":"

If the request doesn't return all of the remaining results, NextToken is set to a token. To retrieve the next set of results, call ListResources again and assign that token to the request object's NextToken parameter. If the request returns all results, NextToken is set to null.

" } } }, "MaxResults":{ "type":"integer", "max":100, "min":1 }, "NetworkFailureException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that the request could not be completed due to networking issues, such as a failure to receive a response from the server.

", "exception":true }, "NextToken":{ "type":"string", "max":2048, "min":1, "pattern":"[-A-Za-z0-9+/=]+" }, "NotStabilizedException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that the downstream resource failed to complete all of its ready-state checks.

", "exception":true }, "NotUpdatableException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

One or more properties included in this resource operation are defined as create-only, and therefore cannot be updated.

", "exception":true }, "Operation":{ "type":"string", "enum":[ "CREATE", "DELETE", "UPDATE" ] }, "OperationStatus":{ "type":"string", "enum":[ "PENDING", "IN_PROGRESS", "SUCCESS", "FAILED", "CANCEL_IN_PROGRESS", "CANCEL_COMPLETE" ] }, "OperationStatuses":{ "type":"list", "member":{"shape":"OperationStatus"} }, "Operations":{ "type":"list", "member":{"shape":"Operation"} }, "PatchDocument":{ "type":"string", "max":65536, "min":1, "pattern":"(.|\\s)*", "sensitive":true }, "PrivateTypeException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

Cloud Control API has not received a valid response from the resource handler, due to a configuration error. This includes issues such as the resource handler returning an invalid response, or timing out.

", "exception":true }, "ProgressEvent":{ "type":"structure", "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type used in the operation.

" }, "Identifier":{ "shape":"Identifier", "documentation":"

The primary identifier for the resource.

In some cases, the resource identifier may be available before the resource operation has reached a status of SUCCESS.

" }, "RequestToken":{ "shape":"RequestToken", "documentation":"

The unique token representing this resource operation request.

Use the RequestToken with GetResourceRequestStatus to return the current status of a resource operation request.

" }, "Operation":{ "shape":"Operation", "documentation":"

The resource operation type.

" }, "OperationStatus":{ "shape":"OperationStatus", "documentation":"

The current status of the resource operation request.

" }, "EventTime":{ "shape":"Timestamp", "documentation":"

When the resource operation request was initiated.

" }, "ResourceModel":{ "shape":"Properties", "documentation":"

A JSON string containing the resource model, consisting of each resource property and its current value.

" }, "StatusMessage":{ "shape":"StatusMessage", "documentation":"

Any message explaining the current status.

" }, "ErrorCode":{ "shape":"HandlerErrorCode", "documentation":"

For requests with a status of FAILED, the associated error code.

For error code definitions, see Handler error codes in the CloudFormation Command Line Interface User Guide for Extension Development.

" }, "RetryAfter":{ "shape":"Timestamp", "documentation":"

When to next request the status of this resource operation request.

" } }, "documentation":"

Represents the current status of a resource operation request. For more information, see Managing resource operation requests in the Amazon Web Services Cloud Control API User Guide.

" }, "Properties":{ "type":"string", "max":16384, "min":1, "pattern":"(.|\\s)*", "sensitive":true }, "RequestToken":{ "type":"string", "max":128, "min":1, "pattern":"[-A-Za-z0-9+/=]+" }, "RequestTokenNotFoundException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

A resource operation with the specified request token cannot be found.

", "exception":true }, "ResourceConflictException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource is temporarily unavailable to be acted upon. For example, if the resource is currently undergoing an operation and cannot be acted upon until that operation is finished.

", "exception":true }, "ResourceDescription":{ "type":"structure", "members":{ "Identifier":{ "shape":"Identifier", "documentation":"

The primary identifier for the resource.

For more information, see Identifying resources in the Amazon Web Services Cloud Control API User Guide.

" }, "Properties":{ "shape":"Properties", "documentation":"

A list of the resource properties and their current values.

" } }, "documentation":"

Represents information about a provisioned resource.

" }, "ResourceDescriptions":{ "type":"list", "member":{"shape":"ResourceDescription"} }, "ResourceNotFoundException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

A resource with the specified identifier cannot be found.

", "exception":true }, "ResourceRequestStatusFilter":{ "type":"structure", "members":{ "Operations":{ "shape":"Operations", "documentation":"

The operation types to include in the filter.

" }, "OperationStatuses":{ "shape":"OperationStatuses", "documentation":"

The operation statuses to include in the filter.

" } }, "documentation":"

The filter criteria to use in determining the requests returned.

" }, "ResourceRequestStatusSummaries":{ "type":"list", "member":{"shape":"ProgressEvent"} }, "RoleArn":{ "type":"string", "max":2048, "min":20, "pattern":"arn:.+:iam::[0-9]{12}:role/.+" }, "ServiceInternalErrorException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that the downstream service returned an internal error, typically with a 5XX HTTP status code.

", "exception":true }, "ServiceLimitExceededException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The resource handler has returned that a non-transient resource limit was reached on the service side.

", "exception":true }, "StatusMessage":{ "type":"string", "max":1024, "pattern":"(.|\\s)*" }, "ThrottlingException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The request was denied due to request throttling.

", "exception":true }, "Timestamp":{"type":"timestamp"}, "TypeName":{ "type":"string", "max":196, "min":10, "pattern":"[A-Za-z0-9]{2,64}::[A-Za-z0-9]{2,64}::[A-Za-z0-9]{2,64}" }, "TypeNotFoundException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The specified extension does not exist in the CloudFormation registry.

", "exception":true }, "TypeVersionId":{ "type":"string", "max":128, "min":1, "pattern":"[A-Za-z0-9-]+" }, "UnsupportedActionException":{ "type":"structure", "members":{ "Message":{"shape":"ErrorMessage"} }, "documentation":"

The specified resource does not support this resource operation.

", "exception":true }, "UpdateResourceInput":{ "type":"structure", "required":[ "TypeName", "Identifier", "PatchDocument" ], "members":{ "TypeName":{ "shape":"TypeName", "documentation":"

The name of the resource type.

" }, "TypeVersionId":{ "shape":"TypeVersionId", "documentation":"

For private resource types, the type version to use in this resource operation. If you do not specify a resource version, CloudFormation uses the default version.

" }, "RoleArn":{ "shape":"RoleArn", "documentation":"

The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) for Cloud Control API to use when performing this resource operation. The role specified must have the permissions required for this operation. The necessary permissions for each event handler are defined in the handlers section of the resource type definition schema.

If you do not specify a role, Cloud Control API uses a temporary session created using your Amazon Web Services user credentials.

For more information, see Specifying credentials in the Amazon Web Services Cloud Control API User Guide.

" }, "ClientToken":{ "shape":"ClientToken", "documentation":"

A unique identifier to ensure the idempotency of the resource request. As a best practice, specify this token to ensure idempotency, so that Amazon Web Services Cloud Control API can accurately distinguish between request retries and new resource requests. You might retry a resource request to ensure that it was successfully received.

A client token is valid for 36 hours once used. After that, a resource request with the same client token is treated as a new request.

If you do not specify a client token, one is generated for inclusion in the request.

For more information, see Ensuring resource operation requests are unique in the Amazon Web Services Cloud Control API User Guide.

", "idempotencyToken":true }, "Identifier":{ "shape":"Identifier", "documentation":"

The identifier for the resource.

You can specify the primary identifier, or any secondary identifier defined for the resource type in its resource schema. You can only specify one identifier. Primary identifiers can be specified as a string or JSON; secondary identifiers must be specified as JSON.

For compound primary identifiers (that is, one that consists of multiple resource properties strung together), to specify the primary identifier as a string, list the property values in the order they are specified in the primary identifier definition, separated by |.

For more information, see Identifying resources in the Amazon Web Services Cloud Control API User Guide.

" }, "PatchDocument":{ "shape":"PatchDocument", "documentation":"

A JavaScript Object Notation (JSON) document listing the patch operations that represent the updates to apply to the current resource properties. For details, see Composing the patch document in the Amazon Web Services Cloud Control API User Guide.

" } } }, "UpdateResourceOutput":{ "type":"structure", "members":{ "ProgressEvent":{ "shape":"ProgressEvent", "documentation":"

Represents the current status of the resource update request.

Use the RequestToken of the ProgressEvent with GetResourceRequestStatus to return the current status of a resource operation request.

" } } } }, "documentation":"

Use Amazon Web Services Cloud Control API to create, read, update, delete, and list (CRUD-L) your cloud resources that belong to a wide range of services--both Amazon Web Services and third-party. With the Cloud Control API standardized set of application programming interfaces (APIs), you can perform CRUD-L operations on any supported resources in your Amazon Web Services account. Using Cloud Control API, you won't have to generate code or scripts specific to each individual service responsible for those resources.

For more information about Amazon Web Services Cloud Control API, see the Amazon Web Services Cloud Control API User Guide.

" }