2018-02-22 14:58:04 +01:00
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
2017-02-07 22:33:23 +01:00
package ecs
import (
"fmt"
"time"
2018-02-22 14:58:04 +01:00
"github.com/aws/aws-sdk-go/aws"
2017-02-07 22:33:23 +01:00
"github.com/aws/aws-sdk-go/aws/awsutil"
"github.com/aws/aws-sdk-go/aws/request"
)
const opCreateCluster = "CreateCluster"
// CreateClusterRequest generates a "aws/request.Request" representing the
// client's request for the CreateCluster operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See CreateCluster for more information on using the CreateCluster
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the CreateClusterRequest method.
// req, resp := client.CreateClusterRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/CreateCluster
2017-02-07 22:33:23 +01:00
func ( c * ECS ) CreateClusterRequest ( input * CreateClusterInput ) ( req * request . Request , output * CreateClusterOutput ) {
op := & request . Operation {
Name : opCreateCluster ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & CreateClusterInput { }
}
output = & CreateClusterOutput { }
req = c . newRequest ( op , input , output )
return
}
// CreateCluster API operation for Amazon EC2 Container Service.
//
// Creates a new Amazon ECS cluster. By default, your account receives a default
// cluster when you launch your first container instance. However, you can create
// your own cluster with a unique name with the CreateCluster action.
//
2018-02-22 14:58:04 +01:00
// When you call the CreateCluster API operation, Amazon ECS attempts to create
// the service-linked role for your account so that required resources in other
// AWS services can be managed on your behalf. However, if the IAM user that
// makes the call does not have permissions to create the service-linked role,
// it is not created. For more information, see Using Service-Linked Roles for
// Amazon ECS (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/using-service-linked-roles.html)
// in the Amazon Elastic Container Service Developer Guide.
//
2017-02-07 22:33:23 +01:00
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation CreateCluster for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/CreateCluster
2017-02-07 22:33:23 +01:00
func ( c * ECS ) CreateCluster ( input * CreateClusterInput ) ( * CreateClusterOutput , error ) {
req , out := c . CreateClusterRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// CreateClusterWithContext is the same as CreateCluster with the addition of
// the ability to pass a context and additional request options.
//
// See CreateCluster for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) CreateClusterWithContext ( ctx aws . Context , input * CreateClusterInput , opts ... request . Option ) ( * CreateClusterOutput , error ) {
req , out := c . CreateClusterRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opCreateService = "CreateService"
// CreateServiceRequest generates a "aws/request.Request" representing the
// client's request for the CreateService operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See CreateService for more information on using the CreateService
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the CreateServiceRequest method.
// req, resp := client.CreateServiceRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/CreateService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) CreateServiceRequest ( input * CreateServiceInput ) ( req * request . Request , output * CreateServiceOutput ) {
op := & request . Operation {
Name : opCreateService ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & CreateServiceInput { }
}
output = & CreateServiceOutput { }
req = c . newRequest ( op , input , output )
return
}
// CreateService API operation for Amazon EC2 Container Service.
//
// Runs and maintains a desired number of tasks from a specified task definition.
// If the number of tasks running in a service drops below desiredCount, Amazon
// ECS spawns another copy of the task in the specified cluster. To update an
// existing service, see UpdateService.
//
// In addition to maintaining the desired count of tasks in your service, you
// can optionally run your service behind a load balancer. The load balancer
// distributes traffic across the tasks that are associated with the service.
// For more information, see Service Load Balancing (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/service-load-balancing.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// You can optionally specify a deployment configuration for your service. During
2018-02-22 14:58:04 +01:00
// a deployment, the service scheduler uses the minimumHealthyPercent and maximumPercent
// parameters to determine the deployment strategy. The deployment is triggered
// by changing the task definition or the desired count of a service with an
// UpdateService operation.
2017-02-07 22:33:23 +01:00
//
// The minimumHealthyPercent represents a lower limit on the number of your
// service's tasks that must remain in the RUNNING state during a deployment,
// as a percentage of the desiredCount (rounded up to the nearest integer).
// This parameter enables you to deploy without using additional cluster capacity.
2018-02-22 14:58:04 +01:00
// For example, if your service has a desiredCount of four tasks and a minimumHealthyPercent
// of 50%, the scheduler can stop two existing tasks to free up cluster capacity
// before starting two new tasks. Tasks for services that do not use a load
// balancer are considered healthy if they are in the RUNNING state. Tasks for
// services that do use a load balancer are considered healthy if they are in
// the RUNNING state and the container instance they are hosted on is reported
// as healthy by the load balancer. The default value for minimumHealthyPercent
// is 50% in the console and 100% for the AWS CLI, the AWS SDKs, and the APIs.
2017-02-07 22:33:23 +01:00
//
// The maximumPercent parameter represents an upper limit on the number of your
// service's tasks that are allowed in the RUNNING or PENDING state during a
// deployment, as a percentage of the desiredCount (rounded down to the nearest
// integer). This parameter enables you to define the deployment batch size.
2018-02-22 14:58:04 +01:00
// For example, if your service has a desiredCount of four tasks and a maximumPercent
// value of 200%, the scheduler can start four new tasks before stopping the
// four older tasks (provided that the cluster resources required to do this
// are available). The default value for maximumPercent is 200%.
2017-02-07 22:33:23 +01:00
//
// When the service scheduler launches new tasks, it determines task placement
// in your cluster using the following logic:
//
// * Determine which of the container instances in your cluster can support
// your service's task definition (for example, they have the required CPU,
// memory, ports, and container instance attributes).
//
// * By default, the service scheduler attempts to balance tasks across Availability
2018-02-22 14:58:04 +01:00
// Zones in this manner (although you can choose a different placement strategy)
// with the placementStrategy parameter):
2017-02-07 22:33:23 +01:00
//
2018-05-28 18:52:03 +02:00
// Sort the valid container instances, giving priority to instances that have
// the fewest number of running tasks for this service in their respective
// Availability Zone. For example, if zone A has one running service task
// and zones B and C each have zero, valid container instances in either
// zone B or C are considered optimal for placement.
2017-02-07 22:33:23 +01:00
//
// Place the new service task on a valid container instance in an optimal Availability
// Zone (based on the previous steps), favoring container instances with
// the fewest number of running tasks for this service.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation CreateService for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeUnsupportedFeatureException "UnsupportedFeatureException"
// The specified task is not supported in this region.
//
// * ErrCodePlatformUnknownException "PlatformUnknownException"
// The specified platform version does not exist.
//
// * ErrCodePlatformTaskDefinitionIncompatibilityException "PlatformTaskDefinitionIncompatibilityException"
// The specified platform version does not satisfy the task definition’ s required
// capabilities.
//
// * ErrCodeAccessDeniedException "AccessDeniedException"
// You do not have authorization to perform the requested action.
//
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/CreateService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) CreateService ( input * CreateServiceInput ) ( * CreateServiceOutput , error ) {
req , out := c . CreateServiceRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// CreateServiceWithContext is the same as CreateService with the addition of
// the ability to pass a context and additional request options.
//
// See CreateService for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) CreateServiceWithContext ( ctx aws . Context , input * CreateServiceInput , opts ... request . Option ) ( * CreateServiceOutput , error ) {
req , out := c . CreateServiceRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDeleteAttributes = "DeleteAttributes"
// DeleteAttributesRequest generates a "aws/request.Request" representing the
// client's request for the DeleteAttributes operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DeleteAttributes for more information on using the DeleteAttributes
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DeleteAttributesRequest method.
// req, resp := client.DeleteAttributesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteAttributesRequest ( input * DeleteAttributesInput ) ( req * request . Request , output * DeleteAttributesOutput ) {
op := & request . Operation {
Name : opDeleteAttributes ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DeleteAttributesInput { }
}
output = & DeleteAttributesOutput { }
req = c . newRequest ( op , input , output )
return
}
// DeleteAttributes API operation for Amazon EC2 Container Service.
//
// Deletes one or more custom attributes from an Amazon ECS resource.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DeleteAttributes for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeTargetNotFoundException "TargetNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified target could not be found. You can view your available container
// instances with ListContainerInstances. Amazon ECS container instances are
// cluster-specific and region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteAttributes ( input * DeleteAttributesInput ) ( * DeleteAttributesOutput , error ) {
req , out := c . DeleteAttributesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DeleteAttributesWithContext is the same as DeleteAttributes with the addition of
// the ability to pass a context and additional request options.
//
// See DeleteAttributes for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DeleteAttributesWithContext ( ctx aws . Context , input * DeleteAttributesInput , opts ... request . Option ) ( * DeleteAttributesOutput , error ) {
req , out := c . DeleteAttributesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDeleteCluster = "DeleteCluster"
// DeleteClusterRequest generates a "aws/request.Request" representing the
// client's request for the DeleteCluster operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DeleteCluster for more information on using the DeleteCluster
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DeleteClusterRequest method.
// req, resp := client.DeleteClusterRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteCluster
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteClusterRequest ( input * DeleteClusterInput ) ( req * request . Request , output * DeleteClusterOutput ) {
op := & request . Operation {
Name : opDeleteCluster ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DeleteClusterInput { }
}
output = & DeleteClusterOutput { }
req = c . newRequest ( op , input , output )
return
}
// DeleteCluster API operation for Amazon EC2 Container Service.
//
// Deletes the specified cluster. You must deregister all container instances
// from this cluster before you may delete it. You can list the container instances
// in a cluster with ListContainerInstances and deregister them with DeregisterContainerInstance.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DeleteCluster for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterContainsContainerInstancesException "ClusterContainsContainerInstancesException"
2017-02-07 22:33:23 +01:00
// You cannot delete a cluster that has registered container instances. You
// must first deregister the container instances before you can delete the cluster.
// For more information, see DeregisterContainerInstance.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterContainsServicesException "ClusterContainsServicesException"
2017-02-07 22:33:23 +01:00
// You cannot delete a cluster that contains services. You must first update
// the service to reduce its desired task count to 0 and then delete the service.
// For more information, see UpdateService and DeleteService.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterContainsTasksException "ClusterContainsTasksException"
// You cannot delete a cluster that has active tasks.
//
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteCluster
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteCluster ( input * DeleteClusterInput ) ( * DeleteClusterOutput , error ) {
req , out := c . DeleteClusterRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DeleteClusterWithContext is the same as DeleteCluster with the addition of
// the ability to pass a context and additional request options.
//
// See DeleteCluster for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DeleteClusterWithContext ( ctx aws . Context , input * DeleteClusterInput , opts ... request . Option ) ( * DeleteClusterOutput , error ) {
req , out := c . DeleteClusterRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDeleteService = "DeleteService"
// DeleteServiceRequest generates a "aws/request.Request" representing the
// client's request for the DeleteService operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DeleteService for more information on using the DeleteService
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DeleteServiceRequest method.
// req, resp := client.DeleteServiceRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteServiceRequest ( input * DeleteServiceInput ) ( req * request . Request , output * DeleteServiceOutput ) {
op := & request . Operation {
Name : opDeleteService ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DeleteServiceInput { }
}
output = & DeleteServiceOutput { }
req = c . newRequest ( op , input , output )
return
}
// DeleteService API operation for Amazon EC2 Container Service.
//
// Deletes a specified service within a cluster. You can delete a service if
// you have no running tasks in it and the desired task count is zero. If the
// service is actively maintaining tasks, you cannot delete it, and you must
// update the service to a desired task count of zero. For more information,
// see UpdateService.
//
// When you delete a service, if there are still running tasks that require
// cleanup, the service status moves from ACTIVE to DRAINING, and the service
// is no longer visible in the console or in ListServices API operations. After
// the tasks have stopped, then the service status moves from DRAINING to INACTIVE.
// Services in the DRAINING or INACTIVE status can still be viewed with DescribeServices
2018-02-22 14:58:04 +01:00
// API operations. However, in the future, INACTIVE services may be cleaned
2017-02-07 22:33:23 +01:00
// up and purged from Amazon ECS record keeping, and DescribeServices API operations
2018-02-22 14:58:04 +01:00
// on those services return a ServiceNotFoundException error.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DeleteService for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeServiceNotFoundException "ServiceNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified service could not be found. You can view your available services
// with ListServices. Amazon ECS services are cluster-specific and region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeleteService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeleteService ( input * DeleteServiceInput ) ( * DeleteServiceOutput , error ) {
req , out := c . DeleteServiceRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DeleteServiceWithContext is the same as DeleteService with the addition of
// the ability to pass a context and additional request options.
//
// See DeleteService for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DeleteServiceWithContext ( ctx aws . Context , input * DeleteServiceInput , opts ... request . Option ) ( * DeleteServiceOutput , error ) {
req , out := c . DeleteServiceRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDeregisterContainerInstance = "DeregisterContainerInstance"
// DeregisterContainerInstanceRequest generates a "aws/request.Request" representing the
// client's request for the DeregisterContainerInstance operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DeregisterContainerInstance for more information on using the DeregisterContainerInstance
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DeregisterContainerInstanceRequest method.
// req, resp := client.DeregisterContainerInstanceRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeregisterContainerInstance
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeregisterContainerInstanceRequest ( input * DeregisterContainerInstanceInput ) ( req * request . Request , output * DeregisterContainerInstanceOutput ) {
op := & request . Operation {
Name : opDeregisterContainerInstance ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DeregisterContainerInstanceInput { }
}
output = & DeregisterContainerInstanceOutput { }
req = c . newRequest ( op , input , output )
return
}
// DeregisterContainerInstance API operation for Amazon EC2 Container Service.
//
// Deregisters an Amazon ECS container instance from the specified cluster.
// This instance is no longer available to run tasks.
//
// If you intend to use the container instance for some other purpose after
// deregistration, you should stop all of the tasks running on the container
2018-02-22 14:58:04 +01:00
// instance before deregistration. That prevents any orphaned tasks from consuming
2017-02-07 22:33:23 +01:00
// resources.
//
// Deregistering a container instance removes the instance from a cluster, but
// it does not terminate the EC2 instance; if you are finished using the instance,
// be sure to terminate it in the Amazon EC2 console to stop billing.
//
// If you terminate a running container instance, Amazon ECS automatically deregisters
// the instance from your cluster (stopped container instances or instances
// with disconnected agents are not automatically deregistered when terminated).
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DeregisterContainerInstance for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeregisterContainerInstance
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeregisterContainerInstance ( input * DeregisterContainerInstanceInput ) ( * DeregisterContainerInstanceOutput , error ) {
req , out := c . DeregisterContainerInstanceRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DeregisterContainerInstanceWithContext is the same as DeregisterContainerInstance with the addition of
// the ability to pass a context and additional request options.
//
// See DeregisterContainerInstance for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DeregisterContainerInstanceWithContext ( ctx aws . Context , input * DeregisterContainerInstanceInput , opts ... request . Option ) ( * DeregisterContainerInstanceOutput , error ) {
req , out := c . DeregisterContainerInstanceRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDeregisterTaskDefinition = "DeregisterTaskDefinition"
// DeregisterTaskDefinitionRequest generates a "aws/request.Request" representing the
// client's request for the DeregisterTaskDefinition operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DeregisterTaskDefinition for more information on using the DeregisterTaskDefinition
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DeregisterTaskDefinitionRequest method.
// req, resp := client.DeregisterTaskDefinitionRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeregisterTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeregisterTaskDefinitionRequest ( input * DeregisterTaskDefinitionInput ) ( req * request . Request , output * DeregisterTaskDefinitionOutput ) {
op := & request . Operation {
Name : opDeregisterTaskDefinition ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DeregisterTaskDefinitionInput { }
}
output = & DeregisterTaskDefinitionOutput { }
req = c . newRequest ( op , input , output )
return
}
// DeregisterTaskDefinition API operation for Amazon EC2 Container Service.
//
// Deregisters the specified task definition by family and revision. Upon deregistration,
// the task definition is marked as INACTIVE. Existing tasks and services that
// reference an INACTIVE task definition continue to run without disruption.
// Existing services that reference an INACTIVE task definition can still scale
// up or down by modifying the service's desired count.
//
// You cannot use an INACTIVE task definition to run new tasks or create new
// services, and you cannot update an existing service to reference an INACTIVE
2018-02-22 14:58:04 +01:00
// task definition (although there may be up to a 10-minute window following
2017-02-07 22:33:23 +01:00
// deregistration where these restrictions have not yet taken effect).
//
2018-02-22 14:58:04 +01:00
// At this time, INACTIVE task definitions remain discoverable in your account
// indefinitely; however, this behavior is subject to change in the future,
// so you should not rely on INACTIVE task definitions persisting beyond the
// lifecycle of any associated tasks and services.
//
2017-02-07 22:33:23 +01:00
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DeregisterTaskDefinition for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DeregisterTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DeregisterTaskDefinition ( input * DeregisterTaskDefinitionInput ) ( * DeregisterTaskDefinitionOutput , error ) {
req , out := c . DeregisterTaskDefinitionRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DeregisterTaskDefinitionWithContext is the same as DeregisterTaskDefinition with the addition of
// the ability to pass a context and additional request options.
//
// See DeregisterTaskDefinition for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DeregisterTaskDefinitionWithContext ( ctx aws . Context , input * DeregisterTaskDefinitionInput , opts ... request . Option ) ( * DeregisterTaskDefinitionOutput , error ) {
req , out := c . DeregisterTaskDefinitionRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDescribeClusters = "DescribeClusters"
// DescribeClustersRequest generates a "aws/request.Request" representing the
// client's request for the DescribeClusters operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DescribeClusters for more information on using the DescribeClusters
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DescribeClustersRequest method.
// req, resp := client.DescribeClustersRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeClusters
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeClustersRequest ( input * DescribeClustersInput ) ( req * request . Request , output * DescribeClustersOutput ) {
op := & request . Operation {
Name : opDescribeClusters ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DescribeClustersInput { }
}
output = & DescribeClustersOutput { }
req = c . newRequest ( op , input , output )
return
}
// DescribeClusters API operation for Amazon EC2 Container Service.
//
// Describes one or more of your clusters.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DescribeClusters for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeClusters
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeClusters ( input * DescribeClustersInput ) ( * DescribeClustersOutput , error ) {
req , out := c . DescribeClustersRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DescribeClustersWithContext is the same as DescribeClusters with the addition of
// the ability to pass a context and additional request options.
//
// See DescribeClusters for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DescribeClustersWithContext ( ctx aws . Context , input * DescribeClustersInput , opts ... request . Option ) ( * DescribeClustersOutput , error ) {
req , out := c . DescribeClustersRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDescribeContainerInstances = "DescribeContainerInstances"
// DescribeContainerInstancesRequest generates a "aws/request.Request" representing the
// client's request for the DescribeContainerInstances operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DescribeContainerInstances for more information on using the DescribeContainerInstances
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DescribeContainerInstancesRequest method.
// req, resp := client.DescribeContainerInstancesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeContainerInstances
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeContainerInstancesRequest ( input * DescribeContainerInstancesInput ) ( req * request . Request , output * DescribeContainerInstancesOutput ) {
op := & request . Operation {
Name : opDescribeContainerInstances ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DescribeContainerInstancesInput { }
}
output = & DescribeContainerInstancesOutput { }
req = c . newRequest ( op , input , output )
return
}
// DescribeContainerInstances API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// Describes Amazon Elastic Container Service container instances. Returns metadata
2017-02-07 22:33:23 +01:00
// about registered and remaining resources on each container instance requested.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DescribeContainerInstances for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeContainerInstances
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeContainerInstances ( input * DescribeContainerInstancesInput ) ( * DescribeContainerInstancesOutput , error ) {
req , out := c . DescribeContainerInstancesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DescribeContainerInstancesWithContext is the same as DescribeContainerInstances with the addition of
// the ability to pass a context and additional request options.
//
// See DescribeContainerInstances for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DescribeContainerInstancesWithContext ( ctx aws . Context , input * DescribeContainerInstancesInput , opts ... request . Option ) ( * DescribeContainerInstancesOutput , error ) {
req , out := c . DescribeContainerInstancesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDescribeServices = "DescribeServices"
// DescribeServicesRequest generates a "aws/request.Request" representing the
// client's request for the DescribeServices operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DescribeServices for more information on using the DescribeServices
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DescribeServicesRequest method.
// req, resp := client.DescribeServicesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeServices
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeServicesRequest ( input * DescribeServicesInput ) ( req * request . Request , output * DescribeServicesOutput ) {
op := & request . Operation {
Name : opDescribeServices ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DescribeServicesInput { }
}
output = & DescribeServicesOutput { }
req = c . newRequest ( op , input , output )
return
}
// DescribeServices API operation for Amazon EC2 Container Service.
//
// Describes the specified services running in your cluster.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DescribeServices for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeServices
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeServices ( input * DescribeServicesInput ) ( * DescribeServicesOutput , error ) {
req , out := c . DescribeServicesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DescribeServicesWithContext is the same as DescribeServices with the addition of
// the ability to pass a context and additional request options.
//
// See DescribeServices for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DescribeServicesWithContext ( ctx aws . Context , input * DescribeServicesInput , opts ... request . Option ) ( * DescribeServicesOutput , error ) {
req , out := c . DescribeServicesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDescribeTaskDefinition = "DescribeTaskDefinition"
// DescribeTaskDefinitionRequest generates a "aws/request.Request" representing the
// client's request for the DescribeTaskDefinition operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DescribeTaskDefinition for more information on using the DescribeTaskDefinition
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DescribeTaskDefinitionRequest method.
// req, resp := client.DescribeTaskDefinitionRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeTaskDefinitionRequest ( input * DescribeTaskDefinitionInput ) ( req * request . Request , output * DescribeTaskDefinitionOutput ) {
op := & request . Operation {
Name : opDescribeTaskDefinition ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DescribeTaskDefinitionInput { }
}
output = & DescribeTaskDefinitionOutput { }
req = c . newRequest ( op , input , output )
return
}
// DescribeTaskDefinition API operation for Amazon EC2 Container Service.
//
// Describes a task definition. You can specify a family and revision to find
// information about a specific task definition, or you can simply specify the
// family to find the latest ACTIVE revision in that family.
//
// You can only describe INACTIVE task definitions while an active task or service
// references them.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DescribeTaskDefinition for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeTaskDefinition ( input * DescribeTaskDefinitionInput ) ( * DescribeTaskDefinitionOutput , error ) {
req , out := c . DescribeTaskDefinitionRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DescribeTaskDefinitionWithContext is the same as DescribeTaskDefinition with the addition of
// the ability to pass a context and additional request options.
//
// See DescribeTaskDefinition for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DescribeTaskDefinitionWithContext ( ctx aws . Context , input * DescribeTaskDefinitionInput , opts ... request . Option ) ( * DescribeTaskDefinitionOutput , error ) {
req , out := c . DescribeTaskDefinitionRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDescribeTasks = "DescribeTasks"
// DescribeTasksRequest generates a "aws/request.Request" representing the
// client's request for the DescribeTasks operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DescribeTasks for more information on using the DescribeTasks
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DescribeTasksRequest method.
// req, resp := client.DescribeTasksRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeTasks
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeTasksRequest ( input * DescribeTasksInput ) ( req * request . Request , output * DescribeTasksOutput ) {
op := & request . Operation {
Name : opDescribeTasks ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DescribeTasksInput { }
}
output = & DescribeTasksOutput { }
req = c . newRequest ( op , input , output )
return
}
// DescribeTasks API operation for Amazon EC2 Container Service.
//
// Describes a specified task or tasks.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DescribeTasks for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DescribeTasks
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DescribeTasks ( input * DescribeTasksInput ) ( * DescribeTasksOutput , error ) {
req , out := c . DescribeTasksRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DescribeTasksWithContext is the same as DescribeTasks with the addition of
// the ability to pass a context and additional request options.
//
// See DescribeTasks for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DescribeTasksWithContext ( ctx aws . Context , input * DescribeTasksInput , opts ... request . Option ) ( * DescribeTasksOutput , error ) {
req , out := c . DescribeTasksRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opDiscoverPollEndpoint = "DiscoverPollEndpoint"
// DiscoverPollEndpointRequest generates a "aws/request.Request" representing the
// client's request for the DiscoverPollEndpoint operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See DiscoverPollEndpoint for more information on using the DiscoverPollEndpoint
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the DiscoverPollEndpointRequest method.
// req, resp := client.DiscoverPollEndpointRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DiscoverPollEndpoint
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DiscoverPollEndpointRequest ( input * DiscoverPollEndpointInput ) ( req * request . Request , output * DiscoverPollEndpointOutput ) {
op := & request . Operation {
Name : opDiscoverPollEndpoint ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & DiscoverPollEndpointInput { }
}
output = & DiscoverPollEndpointOutput { }
req = c . newRequest ( op , input , output )
return
}
// DiscoverPollEndpoint API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// This action is only used by the Amazon ECS agent, and it is not intended
// for use outside of the agent.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Returns an endpoint for the Amazon ECS agent to poll for updates.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation DiscoverPollEndpoint for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/DiscoverPollEndpoint
2017-02-07 22:33:23 +01:00
func ( c * ECS ) DiscoverPollEndpoint ( input * DiscoverPollEndpointInput ) ( * DiscoverPollEndpointOutput , error ) {
req , out := c . DiscoverPollEndpointRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// DiscoverPollEndpointWithContext is the same as DiscoverPollEndpoint with the addition of
// the ability to pass a context and additional request options.
//
// See DiscoverPollEndpoint for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) DiscoverPollEndpointWithContext ( ctx aws . Context , input * DiscoverPollEndpointInput , opts ... request . Option ) ( * DiscoverPollEndpointOutput , error ) {
req , out := c . DiscoverPollEndpointRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opListAttributes = "ListAttributes"
// ListAttributesRequest generates a "aws/request.Request" representing the
// client's request for the ListAttributes operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListAttributes for more information on using the ListAttributes
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListAttributesRequest method.
// req, resp := client.ListAttributesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListAttributesRequest ( input * ListAttributesInput ) ( req * request . Request , output * ListAttributesOutput ) {
op := & request . Operation {
Name : opListAttributes ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & ListAttributesInput { }
}
output = & ListAttributesOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListAttributes API operation for Amazon EC2 Container Service.
//
// Lists the attributes for Amazon ECS resources within a specified target type
2018-02-22 14:58:04 +01:00
// and cluster. When you specify a target type and cluster, ListAttributes returns
2017-02-07 22:33:23 +01:00
// a list of attribute objects, one for each attribute on each resource. You
// can filter the list of results to a single attribute name to only return
// results that have that name. You can also filter the results by attribute
// name and value, for example, to see which container instances in a cluster
// are running a Linux AMI (ecs.os-type=linux).
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListAttributes for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListAttributes ( input * ListAttributesInput ) ( * ListAttributesOutput , error ) {
req , out := c . ListAttributesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListAttributesWithContext is the same as ListAttributes with the addition of
// the ability to pass a context and additional request options.
//
// See ListAttributes for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListAttributesWithContext ( ctx aws . Context , input * ListAttributesInput , opts ... request . Option ) ( * ListAttributesOutput , error ) {
req , out := c . ListAttributesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opListClusters = "ListClusters"
// ListClustersRequest generates a "aws/request.Request" representing the
// client's request for the ListClusters operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListClusters for more information on using the ListClusters
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListClustersRequest method.
// req, resp := client.ListClustersRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListClusters
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListClustersRequest ( input * ListClustersInput ) ( req * request . Request , output * ListClustersOutput ) {
op := & request . Operation {
Name : opListClusters ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListClustersInput { }
}
output = & ListClustersOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListClusters API operation for Amazon EC2 Container Service.
//
// Returns a list of existing clusters.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListClusters for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListClusters
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListClusters ( input * ListClustersInput ) ( * ListClustersOutput , error ) {
req , out := c . ListClustersRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListClustersWithContext is the same as ListClusters with the addition of
// the ability to pass a context and additional request options.
//
// See ListClusters for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListClustersWithContext ( ctx aws . Context , input * ListClustersInput , opts ... request . Option ) ( * ListClustersOutput , error ) {
req , out := c . ListClustersRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListClustersPages iterates over the pages of a ListClusters operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListClusters method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListClusters operation.
// pageNum := 0
// err := client.ListClustersPages(params,
// func(page *ListClustersOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListClustersPages ( input * ListClustersInput , fn func ( * ListClustersOutput , bool ) bool ) error {
return c . ListClustersPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListClustersPagesWithContext same as ListClustersPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListClustersPagesWithContext ( ctx aws . Context , input * ListClustersInput , fn func ( * ListClustersOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListClustersInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListClustersRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListClustersOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opListContainerInstances = "ListContainerInstances"
// ListContainerInstancesRequest generates a "aws/request.Request" representing the
// client's request for the ListContainerInstances operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListContainerInstances for more information on using the ListContainerInstances
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListContainerInstancesRequest method.
// req, resp := client.ListContainerInstancesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListContainerInstances
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListContainerInstancesRequest ( input * ListContainerInstancesInput ) ( req * request . Request , output * ListContainerInstancesOutput ) {
op := & request . Operation {
Name : opListContainerInstances ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListContainerInstancesInput { }
}
output = & ListContainerInstancesOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListContainerInstances API operation for Amazon EC2 Container Service.
//
// Returns a list of container instances in a specified cluster. You can filter
// the results of a ListContainerInstances operation with cluster query language
// statements inside the filter parameter. For more information, see Cluster
// Query Language (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/cluster-query-language.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListContainerInstances for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListContainerInstances
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListContainerInstances ( input * ListContainerInstancesInput ) ( * ListContainerInstancesOutput , error ) {
req , out := c . ListContainerInstancesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListContainerInstancesWithContext is the same as ListContainerInstances with the addition of
// the ability to pass a context and additional request options.
//
// See ListContainerInstances for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListContainerInstancesWithContext ( ctx aws . Context , input * ListContainerInstancesInput , opts ... request . Option ) ( * ListContainerInstancesOutput , error ) {
req , out := c . ListContainerInstancesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListContainerInstancesPages iterates over the pages of a ListContainerInstances operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListContainerInstances method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListContainerInstances operation.
// pageNum := 0
// err := client.ListContainerInstancesPages(params,
// func(page *ListContainerInstancesOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListContainerInstancesPages ( input * ListContainerInstancesInput , fn func ( * ListContainerInstancesOutput , bool ) bool ) error {
return c . ListContainerInstancesPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListContainerInstancesPagesWithContext same as ListContainerInstancesPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListContainerInstancesPagesWithContext ( ctx aws . Context , input * ListContainerInstancesInput , fn func ( * ListContainerInstancesOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListContainerInstancesInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListContainerInstancesRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListContainerInstancesOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opListServices = "ListServices"
// ListServicesRequest generates a "aws/request.Request" representing the
// client's request for the ListServices operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListServices for more information on using the ListServices
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListServicesRequest method.
// req, resp := client.ListServicesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListServices
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListServicesRequest ( input * ListServicesInput ) ( req * request . Request , output * ListServicesOutput ) {
op := & request . Operation {
Name : opListServices ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListServicesInput { }
}
output = & ListServicesOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListServices API operation for Amazon EC2 Container Service.
//
// Lists the services that are running in a specified cluster.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListServices for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListServices
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListServices ( input * ListServicesInput ) ( * ListServicesOutput , error ) {
req , out := c . ListServicesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListServicesWithContext is the same as ListServices with the addition of
// the ability to pass a context and additional request options.
//
// See ListServices for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListServicesWithContext ( ctx aws . Context , input * ListServicesInput , opts ... request . Option ) ( * ListServicesOutput , error ) {
req , out := c . ListServicesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListServicesPages iterates over the pages of a ListServices operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListServices method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListServices operation.
// pageNum := 0
// err := client.ListServicesPages(params,
// func(page *ListServicesOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListServicesPages ( input * ListServicesInput , fn func ( * ListServicesOutput , bool ) bool ) error {
return c . ListServicesPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListServicesPagesWithContext same as ListServicesPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListServicesPagesWithContext ( ctx aws . Context , input * ListServicesInput , fn func ( * ListServicesOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListServicesInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListServicesRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListServicesOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opListTaskDefinitionFamilies = "ListTaskDefinitionFamilies"
// ListTaskDefinitionFamiliesRequest generates a "aws/request.Request" representing the
// client's request for the ListTaskDefinitionFamilies operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListTaskDefinitionFamilies for more information on using the ListTaskDefinitionFamilies
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListTaskDefinitionFamiliesRequest method.
// req, resp := client.ListTaskDefinitionFamiliesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTaskDefinitionFamilies
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTaskDefinitionFamiliesRequest ( input * ListTaskDefinitionFamiliesInput ) ( req * request . Request , output * ListTaskDefinitionFamiliesOutput ) {
op := & request . Operation {
Name : opListTaskDefinitionFamilies ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListTaskDefinitionFamiliesInput { }
}
output = & ListTaskDefinitionFamiliesOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListTaskDefinitionFamilies API operation for Amazon EC2 Container Service.
//
// Returns a list of task definition families that are registered to your account
// (which may include task definition families that no longer have any ACTIVE
// task definition revisions).
//
// You can filter out task definition families that do not contain any ACTIVE
// task definition revisions by setting the status parameter to ACTIVE. You
// can also filter the results with the familyPrefix parameter.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListTaskDefinitionFamilies for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTaskDefinitionFamilies
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTaskDefinitionFamilies ( input * ListTaskDefinitionFamiliesInput ) ( * ListTaskDefinitionFamiliesOutput , error ) {
req , out := c . ListTaskDefinitionFamiliesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListTaskDefinitionFamiliesWithContext is the same as ListTaskDefinitionFamilies with the addition of
// the ability to pass a context and additional request options.
//
// See ListTaskDefinitionFamilies for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTaskDefinitionFamiliesWithContext ( ctx aws . Context , input * ListTaskDefinitionFamiliesInput , opts ... request . Option ) ( * ListTaskDefinitionFamiliesOutput , error ) {
req , out := c . ListTaskDefinitionFamiliesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListTaskDefinitionFamiliesPages iterates over the pages of a ListTaskDefinitionFamilies operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListTaskDefinitionFamilies method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListTaskDefinitionFamilies operation.
// pageNum := 0
// err := client.ListTaskDefinitionFamiliesPages(params,
// func(page *ListTaskDefinitionFamiliesOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListTaskDefinitionFamiliesPages ( input * ListTaskDefinitionFamiliesInput , fn func ( * ListTaskDefinitionFamiliesOutput , bool ) bool ) error {
return c . ListTaskDefinitionFamiliesPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListTaskDefinitionFamiliesPagesWithContext same as ListTaskDefinitionFamiliesPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTaskDefinitionFamiliesPagesWithContext ( ctx aws . Context , input * ListTaskDefinitionFamiliesInput , fn func ( * ListTaskDefinitionFamiliesOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListTaskDefinitionFamiliesInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListTaskDefinitionFamiliesRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListTaskDefinitionFamiliesOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opListTaskDefinitions = "ListTaskDefinitions"
// ListTaskDefinitionsRequest generates a "aws/request.Request" representing the
// client's request for the ListTaskDefinitions operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListTaskDefinitions for more information on using the ListTaskDefinitions
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListTaskDefinitionsRequest method.
// req, resp := client.ListTaskDefinitionsRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTaskDefinitions
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTaskDefinitionsRequest ( input * ListTaskDefinitionsInput ) ( req * request . Request , output * ListTaskDefinitionsOutput ) {
op := & request . Operation {
Name : opListTaskDefinitions ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListTaskDefinitionsInput { }
}
output = & ListTaskDefinitionsOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListTaskDefinitions API operation for Amazon EC2 Container Service.
//
// Returns a list of task definitions that are registered to your account. You
// can filter the results by family name with the familyPrefix parameter or
// by status with the status parameter.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListTaskDefinitions for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTaskDefinitions
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTaskDefinitions ( input * ListTaskDefinitionsInput ) ( * ListTaskDefinitionsOutput , error ) {
req , out := c . ListTaskDefinitionsRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListTaskDefinitionsWithContext is the same as ListTaskDefinitions with the addition of
// the ability to pass a context and additional request options.
//
// See ListTaskDefinitions for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTaskDefinitionsWithContext ( ctx aws . Context , input * ListTaskDefinitionsInput , opts ... request . Option ) ( * ListTaskDefinitionsOutput , error ) {
req , out := c . ListTaskDefinitionsRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListTaskDefinitionsPages iterates over the pages of a ListTaskDefinitions operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListTaskDefinitions method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListTaskDefinitions operation.
// pageNum := 0
// err := client.ListTaskDefinitionsPages(params,
// func(page *ListTaskDefinitionsOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListTaskDefinitionsPages ( input * ListTaskDefinitionsInput , fn func ( * ListTaskDefinitionsOutput , bool ) bool ) error {
return c . ListTaskDefinitionsPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListTaskDefinitionsPagesWithContext same as ListTaskDefinitionsPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTaskDefinitionsPagesWithContext ( ctx aws . Context , input * ListTaskDefinitionsInput , fn func ( * ListTaskDefinitionsOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListTaskDefinitionsInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListTaskDefinitionsRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListTaskDefinitionsOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opListTasks = "ListTasks"
// ListTasksRequest generates a "aws/request.Request" representing the
// client's request for the ListTasks operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See ListTasks for more information on using the ListTasks
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the ListTasksRequest method.
// req, resp := client.ListTasksRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTasks
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTasksRequest ( input * ListTasksInput ) ( req * request . Request , output * ListTasksOutput ) {
op := & request . Operation {
Name : opListTasks ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
Paginator : & request . Paginator {
InputTokens : [ ] string { "nextToken" } ,
OutputTokens : [ ] string { "nextToken" } ,
LimitToken : "maxResults" ,
TruncationToken : "" ,
} ,
}
if input == nil {
input = & ListTasksInput { }
}
output = & ListTasksOutput { }
req = c . newRequest ( op , input , output )
return
}
// ListTasks API operation for Amazon EC2 Container Service.
//
// Returns a list of tasks for a specified cluster. You can filter the results
// by family name, by a particular container instance, or by the desired status
// of the task with the family, containerInstance, and desiredStatus parameters.
//
2018-02-22 14:58:04 +01:00
// Recently stopped tasks might appear in the returned results. Currently, stopped
2017-02-07 22:33:23 +01:00
// tasks appear in the returned results for at least one hour.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation ListTasks for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeServiceNotFoundException "ServiceNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified service could not be found. You can view your available services
// with ListServices. Amazon ECS services are cluster-specific and region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/ListTasks
2017-02-07 22:33:23 +01:00
func ( c * ECS ) ListTasks ( input * ListTasksInput ) ( * ListTasksOutput , error ) {
req , out := c . ListTasksRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// ListTasksWithContext is the same as ListTasks with the addition of
// the ability to pass a context and additional request options.
//
// See ListTasks for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTasksWithContext ( ctx aws . Context , input * ListTasksInput , opts ... request . Option ) ( * ListTasksOutput , error ) {
req , out := c . ListTasksRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
// ListTasksPages iterates over the pages of a ListTasks operation,
// calling the "fn" function with the response data for each page. To stop
// iterating, return false from the fn function.
//
// See ListTasks method for more information on how to use this operation.
//
// Note: This operation can generate multiple requests to a service.
//
// // Example iterating over at most 3 pages of a ListTasks operation.
// pageNum := 0
// err := client.ListTasksPages(params,
// func(page *ListTasksOutput, lastPage bool) bool {
// pageNum++
// fmt.Println(page)
// return pageNum <= 3
// })
//
2018-02-22 14:58:04 +01:00
func ( c * ECS ) ListTasksPages ( input * ListTasksInput , fn func ( * ListTasksOutput , bool ) bool ) error {
return c . ListTasksPagesWithContext ( aws . BackgroundContext ( ) , input , fn )
}
// ListTasksPagesWithContext same as ListTasksPages except
// it takes a Context and allows setting request options on the pages.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) ListTasksPagesWithContext ( ctx aws . Context , input * ListTasksInput , fn func ( * ListTasksOutput , bool ) bool , opts ... request . Option ) error {
p := request . Pagination {
NewRequest : func ( ) ( * request . Request , error ) {
var inCpy * ListTasksInput
if input != nil {
tmp := * input
inCpy = & tmp
}
req , _ := c . ListTasksRequest ( inCpy )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return req , nil
} ,
}
cont := true
for p . Next ( ) && cont {
cont = fn ( p . Page ( ) . ( * ListTasksOutput ) , ! p . HasNextPage ( ) )
}
return p . Err ( )
2017-02-07 22:33:23 +01:00
}
const opPutAttributes = "PutAttributes"
// PutAttributesRequest generates a "aws/request.Request" representing the
// client's request for the PutAttributes operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See PutAttributes for more information on using the PutAttributes
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the PutAttributesRequest method.
// req, resp := client.PutAttributesRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/PutAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) PutAttributesRequest ( input * PutAttributesInput ) ( req * request . Request , output * PutAttributesOutput ) {
op := & request . Operation {
Name : opPutAttributes ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & PutAttributesInput { }
}
output = & PutAttributesOutput { }
req = c . newRequest ( op , input , output )
return
}
// PutAttributes API operation for Amazon EC2 Container Service.
//
// Create or update an attribute on an Amazon ECS resource. If the attribute
// does not exist, it is created. If the attribute exists, its value is replaced
// with the specified value. To delete an attribute, use DeleteAttributes. For
// more information, see Attributes (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html#attributes)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation PutAttributes for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeTargetNotFoundException "TargetNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified target could not be found. You can view your available container
// instances with ListContainerInstances. Amazon ECS container instances are
// cluster-specific and region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeAttributeLimitExceededException "AttributeLimitExceededException"
2017-02-07 22:33:23 +01:00
// You can apply up to 10 custom attributes per resource. You can view the attributes
// of a resource with ListAttributes. You can remove existing attributes on
// a resource with DeleteAttributes.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/PutAttributes
2017-02-07 22:33:23 +01:00
func ( c * ECS ) PutAttributes ( input * PutAttributesInput ) ( * PutAttributesOutput , error ) {
req , out := c . PutAttributesRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// PutAttributesWithContext is the same as PutAttributes with the addition of
// the ability to pass a context and additional request options.
//
// See PutAttributes for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) PutAttributesWithContext ( ctx aws . Context , input * PutAttributesInput , opts ... request . Option ) ( * PutAttributesOutput , error ) {
req , out := c . PutAttributesRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opRegisterContainerInstance = "RegisterContainerInstance"
// RegisterContainerInstanceRequest generates a "aws/request.Request" representing the
// client's request for the RegisterContainerInstance operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See RegisterContainerInstance for more information on using the RegisterContainerInstance
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the RegisterContainerInstanceRequest method.
// req, resp := client.RegisterContainerInstanceRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RegisterContainerInstance
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RegisterContainerInstanceRequest ( input * RegisterContainerInstanceInput ) ( req * request . Request , output * RegisterContainerInstanceOutput ) {
op := & request . Operation {
Name : opRegisterContainerInstance ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & RegisterContainerInstanceInput { }
}
output = & RegisterContainerInstanceOutput { }
req = c . newRequest ( op , input , output )
return
}
// RegisterContainerInstance API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// This action is only used by the Amazon ECS agent, and it is not intended
// for use outside of the agent.
2017-02-07 22:33:23 +01:00
//
// Registers an EC2 instance into the specified cluster. This instance becomes
// available to place containers on.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation RegisterContainerInstance for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
//
// * ErrCodeInvalidParameterException "InvalidParameterException"
// The specified parameter is invalid. Review the available parameters for the
// API request.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RegisterContainerInstance
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RegisterContainerInstance ( input * RegisterContainerInstanceInput ) ( * RegisterContainerInstanceOutput , error ) {
req , out := c . RegisterContainerInstanceRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// RegisterContainerInstanceWithContext is the same as RegisterContainerInstance with the addition of
// the ability to pass a context and additional request options.
//
// See RegisterContainerInstance for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) RegisterContainerInstanceWithContext ( ctx aws . Context , input * RegisterContainerInstanceInput , opts ... request . Option ) ( * RegisterContainerInstanceOutput , error ) {
req , out := c . RegisterContainerInstanceRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opRegisterTaskDefinition = "RegisterTaskDefinition"
// RegisterTaskDefinitionRequest generates a "aws/request.Request" representing the
// client's request for the RegisterTaskDefinition operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See RegisterTaskDefinition for more information on using the RegisterTaskDefinition
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the RegisterTaskDefinitionRequest method.
// req, resp := client.RegisterTaskDefinitionRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RegisterTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RegisterTaskDefinitionRequest ( input * RegisterTaskDefinitionInput ) ( req * request . Request , output * RegisterTaskDefinitionOutput ) {
op := & request . Operation {
Name : opRegisterTaskDefinition ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & RegisterTaskDefinitionInput { }
}
output = & RegisterTaskDefinitionOutput { }
req = c . newRequest ( op , input , output )
return
}
// RegisterTaskDefinition API operation for Amazon EC2 Container Service.
//
// Registers a new task definition from the supplied family and containerDefinitions.
// Optionally, you can add data volumes to your containers with the volumes
// parameter. For more information about task definition parameters and defaults,
// see Amazon ECS Task Definitions (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_defintions.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// You can specify an IAM role for your task with the taskRoleArn parameter.
// When you specify an IAM role for a task, its containers can then use the
// latest versions of the AWS CLI or SDKs to make API requests to the AWS services
// that are specified in the IAM policy associated with the role. For more information,
// see IAM Roles for Tasks (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// You can specify a Docker networking mode for the containers in your task
// definition with the networkMode parameter. The available network modes correspond
// to those described in Network settings (https://docs.docker.com/engine/reference/run/#/network-settings)
2018-02-22 14:58:04 +01:00
// in the Docker run reference. If you specify the awsvpc network mode, the
// task is allocated an Elastic Network Interface, and you must specify a NetworkConfiguration
// when you create a service or run a task with the task definition. For more
// information, see Task Networking (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation RegisterTaskDefinition for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RegisterTaskDefinition
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RegisterTaskDefinition ( input * RegisterTaskDefinitionInput ) ( * RegisterTaskDefinitionOutput , error ) {
req , out := c . RegisterTaskDefinitionRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// RegisterTaskDefinitionWithContext is the same as RegisterTaskDefinition with the addition of
// the ability to pass a context and additional request options.
//
// See RegisterTaskDefinition for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) RegisterTaskDefinitionWithContext ( ctx aws . Context , input * RegisterTaskDefinitionInput , opts ... request . Option ) ( * RegisterTaskDefinitionOutput , error ) {
req , out := c . RegisterTaskDefinitionRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opRunTask = "RunTask"
// RunTaskRequest generates a "aws/request.Request" representing the
// client's request for the RunTask operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See RunTask for more information on using the RunTask
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the RunTaskRequest method.
// req, resp := client.RunTaskRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RunTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RunTaskRequest ( input * RunTaskInput ) ( req * request . Request , output * RunTaskOutput ) {
op := & request . Operation {
Name : opRunTask ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & RunTaskInput { }
}
output = & RunTaskOutput { }
req = c . newRequest ( op , input , output )
return
}
// RunTask API operation for Amazon EC2 Container Service.
//
// Starts a new task using the specified task definition.
//
// You can allow Amazon ECS to place tasks for you, or you can customize how
// Amazon ECS places tasks using placement constraints and placement strategies.
// For more information, see Scheduling Tasks (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/scheduling_tasks.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Alternatively, you can use StartTask to use your own scheduler or place tasks
// manually on specific container instances.
//
2018-02-22 14:58:04 +01:00
// The Amazon ECS API follows an eventual consistency model, due to the distributed
// nature of the system supporting the API. This means that the result of an
// API command you run that affects your Amazon ECS resources might not be immediately
// visible to all subsequent commands you run. You should keep this in mind
// when you carry out an API command that immediately follows a previous API
// command.
//
// To manage eventual consistency, you can do the following:
//
// * Confirm the state of the resource before you run a command to modify
// it. Run the DescribeTasks command using an exponential backoff algorithm
// to ensure that you allow enough time for the previous command to propagate
// through the system. To do this, run the DescribeTasks command repeatedly,
// starting with a couple of seconds of wait time, and increasing gradually
// up to five minutes of wait time.
//
// * Add wait time between subsequent commands, even if the DescribeTasks
// command returns an accurate response. Apply an exponential backoff algorithm
// starting with a couple of seconds of wait time, and increase gradually
// up to about five minutes of wait time.
//
2017-02-07 22:33:23 +01:00
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation RunTask for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeUnsupportedFeatureException "UnsupportedFeatureException"
// The specified task is not supported in this region.
//
// * ErrCodePlatformUnknownException "PlatformUnknownException"
// The specified platform version does not exist.
//
// * ErrCodePlatformTaskDefinitionIncompatibilityException "PlatformTaskDefinitionIncompatibilityException"
// The specified platform version does not satisfy the task definition’ s required
// capabilities.
//
// * ErrCodeAccessDeniedException "AccessDeniedException"
// You do not have authorization to perform the requested action.
//
// * ErrCodeBlockedException "BlockedException"
2018-05-28 18:52:03 +02:00
// Your AWS account has been blocked. Contact AWS Support (http://aws.amazon.com/contact-us/)
2018-02-22 14:58:04 +01:00
// for more information.
//
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/RunTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) RunTask ( input * RunTaskInput ) ( * RunTaskOutput , error ) {
req , out := c . RunTaskRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// RunTaskWithContext is the same as RunTask with the addition of
// the ability to pass a context and additional request options.
//
// See RunTask for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) RunTaskWithContext ( ctx aws . Context , input * RunTaskInput , opts ... request . Option ) ( * RunTaskOutput , error ) {
req , out := c . RunTaskRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opStartTask = "StartTask"
// StartTaskRequest generates a "aws/request.Request" representing the
// client's request for the StartTask operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See StartTask for more information on using the StartTask
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the StartTaskRequest method.
// req, resp := client.StartTaskRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/StartTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) StartTaskRequest ( input * StartTaskInput ) ( req * request . Request , output * StartTaskOutput ) {
op := & request . Operation {
Name : opStartTask ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & StartTaskInput { }
}
output = & StartTaskOutput { }
req = c . newRequest ( op , input , output )
return
}
// StartTask API operation for Amazon EC2 Container Service.
//
// Starts a new task from the specified task definition on the specified container
// instance or instances.
//
// Alternatively, you can use RunTask to place tasks for you. For more information,
// see Scheduling Tasks (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/scheduling_tasks.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation StartTask for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/StartTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) StartTask ( input * StartTaskInput ) ( * StartTaskOutput , error ) {
req , out := c . StartTaskRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// StartTaskWithContext is the same as StartTask with the addition of
// the ability to pass a context and additional request options.
//
// See StartTask for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) StartTaskWithContext ( ctx aws . Context , input * StartTaskInput , opts ... request . Option ) ( * StartTaskOutput , error ) {
req , out := c . StartTaskRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opStopTask = "StopTask"
// StopTaskRequest generates a "aws/request.Request" representing the
// client's request for the StopTask operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See StopTask for more information on using the StopTask
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the StopTaskRequest method.
// req, resp := client.StopTaskRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/StopTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) StopTaskRequest ( input * StopTaskInput ) ( req * request . Request , output * StopTaskOutput ) {
op := & request . Operation {
Name : opStopTask ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & StopTaskInput { }
}
output = & StopTaskOutput { }
req = c . newRequest ( op , input , output )
return
}
// StopTask API operation for Amazon EC2 Container Service.
//
// Stops a running task.
//
// When StopTask is called on a task, the equivalent of docker stop is issued
2018-02-22 14:58:04 +01:00
// to the containers running in the task. This results in a SIGTERM and a default
// 30-second timeout, after which SIGKILL is sent and the containers are forcibly
// stopped. If the container handles the SIGTERM gracefully and exits within
// 30 seconds from receiving it, no SIGKILL is sent.
//
// The default 30-second timeout can be configured on the Amazon ECS container
// agent with the ECS_CONTAINER_STOP_TIMEOUT variable. For more information,
// see Amazon ECS Container Agent Configuration (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-agent-config.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation StopTask for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/StopTask
2017-02-07 22:33:23 +01:00
func ( c * ECS ) StopTask ( input * StopTaskInput ) ( * StopTaskOutput , error ) {
req , out := c . StopTaskRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// StopTaskWithContext is the same as StopTask with the addition of
// the ability to pass a context and additional request options.
//
// See StopTask for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) StopTaskWithContext ( ctx aws . Context , input * StopTaskInput , opts ... request . Option ) ( * StopTaskOutput , error ) {
req , out := c . StopTaskRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opSubmitContainerStateChange = "SubmitContainerStateChange"
// SubmitContainerStateChangeRequest generates a "aws/request.Request" representing the
// client's request for the SubmitContainerStateChange operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See SubmitContainerStateChange for more information on using the SubmitContainerStateChange
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the SubmitContainerStateChangeRequest method.
// req, resp := client.SubmitContainerStateChangeRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/SubmitContainerStateChange
2017-02-07 22:33:23 +01:00
func ( c * ECS ) SubmitContainerStateChangeRequest ( input * SubmitContainerStateChangeInput ) ( req * request . Request , output * SubmitContainerStateChangeOutput ) {
op := & request . Operation {
Name : opSubmitContainerStateChange ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & SubmitContainerStateChangeInput { }
}
output = & SubmitContainerStateChangeOutput { }
req = c . newRequest ( op , input , output )
return
}
// SubmitContainerStateChange API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// This action is only used by the Amazon ECS agent, and it is not intended
// for use outside of the agent.
2017-02-07 22:33:23 +01:00
//
// Sent to acknowledge that a container changed states.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation SubmitContainerStateChange for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeAccessDeniedException "AccessDeniedException"
// You do not have authorization to perform the requested action.
//
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/SubmitContainerStateChange
2017-02-07 22:33:23 +01:00
func ( c * ECS ) SubmitContainerStateChange ( input * SubmitContainerStateChangeInput ) ( * SubmitContainerStateChangeOutput , error ) {
req , out := c . SubmitContainerStateChangeRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// SubmitContainerStateChangeWithContext is the same as SubmitContainerStateChange with the addition of
// the ability to pass a context and additional request options.
//
// See SubmitContainerStateChange for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) SubmitContainerStateChangeWithContext ( ctx aws . Context , input * SubmitContainerStateChangeInput , opts ... request . Option ) ( * SubmitContainerStateChangeOutput , error ) {
req , out := c . SubmitContainerStateChangeRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opSubmitTaskStateChange = "SubmitTaskStateChange"
// SubmitTaskStateChangeRequest generates a "aws/request.Request" representing the
// client's request for the SubmitTaskStateChange operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See SubmitTaskStateChange for more information on using the SubmitTaskStateChange
// API call, and error handling.
//
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the SubmitTaskStateChangeRequest method.
// req, resp := client.SubmitTaskStateChangeRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/SubmitTaskStateChange
2017-02-07 22:33:23 +01:00
func ( c * ECS ) SubmitTaskStateChangeRequest ( input * SubmitTaskStateChangeInput ) ( req * request . Request , output * SubmitTaskStateChangeOutput ) {
op := & request . Operation {
Name : opSubmitTaskStateChange ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & SubmitTaskStateChangeInput { }
}
output = & SubmitTaskStateChangeOutput { }
req = c . newRequest ( op , input , output )
return
}
// SubmitTaskStateChange API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// This action is only used by the Amazon ECS agent, and it is not intended
// for use outside of the agent.
2017-02-07 22:33:23 +01:00
//
// Sent to acknowledge that a task changed states.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation SubmitTaskStateChange for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
//
// * ErrCodeAccessDeniedException "AccessDeniedException"
// You do not have authorization to perform the requested action.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/SubmitTaskStateChange
2017-02-07 22:33:23 +01:00
func ( c * ECS ) SubmitTaskStateChange ( input * SubmitTaskStateChangeInput ) ( * SubmitTaskStateChangeOutput , error ) {
req , out := c . SubmitTaskStateChangeRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// SubmitTaskStateChangeWithContext is the same as SubmitTaskStateChange with the addition of
// the ability to pass a context and additional request options.
//
// See SubmitTaskStateChange for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) SubmitTaskStateChangeWithContext ( ctx aws . Context , input * SubmitTaskStateChangeInput , opts ... request . Option ) ( * SubmitTaskStateChangeOutput , error ) {
req , out := c . SubmitTaskStateChangeRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opUpdateContainerAgent = "UpdateContainerAgent"
// UpdateContainerAgentRequest generates a "aws/request.Request" representing the
// client's request for the UpdateContainerAgent operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See UpdateContainerAgent for more information on using the UpdateContainerAgent
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the UpdateContainerAgentRequest method.
// req, resp := client.UpdateContainerAgentRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateContainerAgent
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateContainerAgentRequest ( input * UpdateContainerAgentInput ) ( req * request . Request , output * UpdateContainerAgentOutput ) {
op := & request . Operation {
Name : opUpdateContainerAgent ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & UpdateContainerAgentInput { }
}
output = & UpdateContainerAgentOutput { }
req = c . newRequest ( op , input , output )
return
}
// UpdateContainerAgent API operation for Amazon EC2 Container Service.
//
// Updates the Amazon ECS container agent on a specified container instance.
// Updating the Amazon ECS container agent does not interrupt running tasks
// or services on the container instance. The process for updating the agent
// differs depending on whether your container instance was launched with the
// Amazon ECS-optimized AMI or another operating system.
//
// UpdateContainerAgent requires the Amazon ECS-optimized AMI or Amazon Linux
// with the ecs-init service installed and running. For help updating the Amazon
// ECS container agent on other operating systems, see Manually Updating the
// Amazon ECS Container Agent (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-agent-update.html#manually_update_agent)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation UpdateContainerAgent for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeUpdateInProgressException "UpdateInProgressException"
2017-02-07 22:33:23 +01:00
// There is already a current Amazon ECS container agent update in progress
// on the specified container instance. If the container agent becomes disconnected
// while it is in a transitional stage, such as PENDING or STAGING, the update
// process can get stuck in that state. However, when the agent reconnects,
// it resumes where it stopped previously.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeNoUpdateAvailableException "NoUpdateAvailableException"
2017-02-07 22:33:23 +01:00
// There is no update available for this Amazon ECS container agent. This could
// be because the agent is already running the latest version, or it is so old
// that there is no update path to the current version.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeMissingVersionException "MissingVersionException"
2017-02-07 22:33:23 +01:00
// Amazon ECS is unable to determine the current version of the Amazon ECS container
// agent on the container instance and does not have enough information to proceed
// with an update. This could be because the agent running on the container
// instance is an older or custom version that does not use our version information.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateContainerAgent
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateContainerAgent ( input * UpdateContainerAgentInput ) ( * UpdateContainerAgentOutput , error ) {
req , out := c . UpdateContainerAgentRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// UpdateContainerAgentWithContext is the same as UpdateContainerAgent with the addition of
// the ability to pass a context and additional request options.
//
// See UpdateContainerAgent for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) UpdateContainerAgentWithContext ( ctx aws . Context , input * UpdateContainerAgentInput , opts ... request . Option ) ( * UpdateContainerAgentOutput , error ) {
req , out := c . UpdateContainerAgentRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opUpdateContainerInstancesState = "UpdateContainerInstancesState"
// UpdateContainerInstancesStateRequest generates a "aws/request.Request" representing the
// client's request for the UpdateContainerInstancesState operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See UpdateContainerInstancesState for more information on using the UpdateContainerInstancesState
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the UpdateContainerInstancesStateRequest method.
// req, resp := client.UpdateContainerInstancesStateRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateContainerInstancesState
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateContainerInstancesStateRequest ( input * UpdateContainerInstancesStateInput ) ( req * request . Request , output * UpdateContainerInstancesStateOutput ) {
op := & request . Operation {
Name : opUpdateContainerInstancesState ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & UpdateContainerInstancesStateInput { }
}
output = & UpdateContainerInstancesStateOutput { }
req = c . newRequest ( op , input , output )
return
}
// UpdateContainerInstancesState API operation for Amazon EC2 Container Service.
//
// Modifies the status of an Amazon ECS container instance.
//
// You can change the status of a container instance to DRAINING to manually
// remove an instance from a cluster, for example to perform system updates,
// update the Docker daemon, or scale down the cluster size.
//
// When you set a container instance to DRAINING, Amazon ECS prevents new tasks
// from being scheduled for placement on the container instance and replacement
// service tasks are started on other container instances in the cluster if
// the resources are available. Service tasks on the container instance that
// are in the PENDING state are stopped immediately.
//
// Service tasks on the container instance that are in the RUNNING state are
2018-02-22 14:58:04 +01:00
// stopped and replaced according to the service's deployment configuration
// parameters, minimumHealthyPercent and maximumPercent. You can change the
// deployment configuration of your service using UpdateService.
2017-02-07 22:33:23 +01:00
//
// * If minimumHealthyPercent is below 100%, the scheduler can ignore desiredCount
// temporarily during task replacement. For example, desiredCount is four
// tasks, a minimum of 50% allows the scheduler to stop two existing tasks
// before starting two new tasks. If the minimum is 100%, the service scheduler
// can't remove existing tasks until the replacement tasks are considered
// healthy. Tasks for services that do not use a load balancer are considered
// healthy if they are in the RUNNING state. Tasks for services that use
// a load balancer are considered healthy if they are in the RUNNING state
// and the container instance they are hosted on is reported as healthy by
// the load balancer.
//
// * The maximumPercent parameter represents an upper limit on the number
// of running tasks during task replacement, which enables you to define
// the replacement batch size. For example, if desiredCount of four tasks,
// a maximum of 200% starts four new tasks before stopping the four tasks
// to be drained (provided that the cluster resources required to do this
// are available). If the maximum is 100%, then replacement tasks can't start
// until the draining tasks have stopped.
//
// Any PENDING or RUNNING tasks that do not belong to a service are not affected;
// you must wait for them to finish or stop them manually.
//
// A container instance has completed draining when it has no more RUNNING tasks.
// You can verify this using ListTasks.
//
// When you set a container instance to ACTIVE, the Amazon ECS scheduler can
// begin scheduling tasks on the instance again.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation UpdateContainerInstancesState for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateContainerInstancesState
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateContainerInstancesState ( input * UpdateContainerInstancesStateInput ) ( * UpdateContainerInstancesStateOutput , error ) {
req , out := c . UpdateContainerInstancesStateRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
}
// UpdateContainerInstancesStateWithContext is the same as UpdateContainerInstancesState with the addition of
// the ability to pass a context and additional request options.
//
// See UpdateContainerInstancesState for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) UpdateContainerInstancesStateWithContext ( ctx aws . Context , input * UpdateContainerInstancesStateInput , opts ... request . Option ) ( * UpdateContainerInstancesStateOutput , error ) {
req , out := c . UpdateContainerInstancesStateRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
const opUpdateService = "UpdateService"
// UpdateServiceRequest generates a "aws/request.Request" representing the
// client's request for the UpdateService operation. The "output" return
2018-05-28 18:52:03 +02:00
// value will be populated with the request's response once the request completes
2018-02-22 14:58:04 +01:00
// successfuly.
//
// Use "Send" method on the returned Request to send the API call to the service.
// the "output" return value is not valid until after Send returns without error.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// See UpdateService for more information on using the UpdateService
// API call, and error handling.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// This method is useful when you want to inject custom logic or configuration
// into the SDK's request lifecycle. Such as custom headers, or retry logic.
2017-02-07 22:33:23 +01:00
//
//
// // Example sending a request using the UpdateServiceRequest method.
// req, resp := client.UpdateServiceRequest(params)
//
// err := req.Send()
// if err == nil { // resp is now filled
// fmt.Println(resp)
// }
//
2018-02-22 14:58:04 +01:00
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateServiceRequest ( input * UpdateServiceInput ) ( req * request . Request , output * UpdateServiceOutput ) {
op := & request . Operation {
Name : opUpdateService ,
HTTPMethod : "POST" ,
HTTPPath : "/" ,
}
if input == nil {
input = & UpdateServiceInput { }
}
output = & UpdateServiceOutput { }
req = c . newRequest ( op , input , output )
return
}
// UpdateService API operation for Amazon EC2 Container Service.
//
2018-02-22 14:58:04 +01:00
// Modifies the desired count, deployment configuration, network configuration,
// or task definition used in a service.
2017-02-07 22:33:23 +01:00
//
// You can add to or subtract from the number of instantiations of a task definition
// in a service by specifying the cluster that the service is running in and
// a new desiredCount parameter.
//
2018-05-28 18:52:03 +02:00
// If you have updated the Docker image of your application, you can create
// a new task definition with that image and deploy it to your service. The
// service scheduler uses the minimum healthy percent and maximum percent parameters
// (in the service's deployment configuration) to determine the deployment strategy.
//
// If your updated Docker image uses the same tag as what is in the existing
// task definition for your service (for example, my_image:latest), you do not
// need to create a new revision of your task definition. You can update the
// service using the forceNewDeployment option. The new tasks launched by the
// deployment pull the current image/tag combination from your repository when
// they start.
2017-02-07 22:33:23 +01:00
//
// You can also update the deployment configuration of a service. When a deployment
// is triggered by updating the task definition of a service, the service scheduler
// uses the deployment configuration parameters, minimumHealthyPercent and maximumPercent,
// to determine the deployment strategy.
//
// * If minimumHealthyPercent is below 100%, the scheduler can ignore desiredCount
// temporarily during a deployment. For example, if desiredCount is four
// tasks, a minimum of 50% allows the scheduler to stop two existing tasks
// before starting two new tasks. Tasks for services that do not use a load
// balancer are considered healthy if they are in the RUNNING state. Tasks
// for services that use a load balancer are considered healthy if they are
// in the RUNNING state and the container instance they are hosted on is
// reported as healthy by the load balancer.
//
// * The maximumPercent parameter represents an upper limit on the number
// of running tasks during a deployment, which enables you to define the
// deployment batch size. For example, if desiredCount is four tasks, a maximum
// of 200% starts four new tasks before stopping the four older tasks (provided
// that the cluster resources required to do this are available).
//
// When UpdateService stops a task during a deployment, the equivalent of docker
// stop is issued to the containers running in the task. This results in a SIGTERM
// and a 30-second timeout, after which SIGKILL is sent and the containers are
// forcibly stopped. If the container handles the SIGTERM gracefully and exits
// within 30 seconds from receiving it, no SIGKILL is sent.
//
// When the service scheduler launches new tasks, it determines task placement
// in your cluster with the following logic:
//
// * Determine which of the container instances in your cluster can support
// your service's task definition (for example, they have the required CPU,
// memory, ports, and container instance attributes).
//
// * By default, the service scheduler attempts to balance tasks across Availability
// Zones in this manner (although you can choose a different placement strategy):
//
// Sort the valid container instances by the fewest number of running tasks
// for this service in the same Availability Zone as the instance. For example,
// if zone A has one running service task and zones B and C each have zero,
// valid container instances in either zone B or C are considered optimal
// for placement.
//
// Place the new service task on a valid container instance in an optimal Availability
// Zone (based on the previous steps), favoring container instances with
// the fewest number of running tasks for this service.
//
// When the service scheduler stops running tasks, it attempts to maintain balance
// across the Availability Zones in your cluster using the following logic:
//
// * Sort the container instances by the largest number of running tasks
// for this service in the same Availability Zone as the instance. For example,
// if zone A has one running service task and zones B and C each have two,
// container instances in either zone B or C are considered optimal for termination.
//
// * Stop the task on a container instance in an optimal Availability Zone
// (based on the previous steps), favoring container instances with the largest
// number of running tasks for this service.
//
// Returns awserr.Error for service API and SDK errors. Use runtime type assertions
// with awserr.Error's Code and Message methods to get detailed information about
// the error.
//
// See the AWS API reference guide for Amazon EC2 Container Service's
// API operation UpdateService for usage and error information.
//
// Returned Error Codes:
2018-02-22 14:58:04 +01:00
// * ErrCodeServerException "ServerException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a server issue.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClientException "ClientException"
2017-02-07 22:33:23 +01:00
// These errors are usually caused by a client action, such as using an action
2018-02-22 14:58:04 +01:00
// or resource on behalf of a user that doesn't have permissions to use the
// action or resource, or specifying an identifier that is not valid.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodeInvalidParameterException "InvalidParameterException"
2017-02-07 22:33:23 +01:00
// The specified parameter is invalid. Review the available parameters for the
// API request.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeClusterNotFoundException "ClusterNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified cluster could not be found. You can view your available clusters
// with ListClusters. Amazon ECS clusters are region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeServiceNotFoundException "ServiceNotFoundException"
2017-02-07 22:33:23 +01:00
// The specified service could not be found. You can view your available services
// with ListServices. Amazon ECS services are cluster-specific and region-specific.
//
2018-02-22 14:58:04 +01:00
// * ErrCodeServiceNotActiveException "ServiceNotActiveException"
// The specified service is not active. You can't update a service that is inactive.
// If you have previously deleted a service, you can re-create it with CreateService.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// * ErrCodePlatformUnknownException "PlatformUnknownException"
// The specified platform version does not exist.
//
// * ErrCodePlatformTaskDefinitionIncompatibilityException "PlatformTaskDefinitionIncompatibilityException"
// The specified platform version does not satisfy the task definition’ s required
// capabilities.
//
// * ErrCodeAccessDeniedException "AccessDeniedException"
// You do not have authorization to perform the requested action.
//
// See also, https://docs.aws.amazon.com/goto/WebAPI/ecs-2014-11-13/UpdateService
2017-02-07 22:33:23 +01:00
func ( c * ECS ) UpdateService ( input * UpdateServiceInput ) ( * UpdateServiceOutput , error ) {
req , out := c . UpdateServiceRequest ( input )
2018-02-22 14:58:04 +01:00
return out , req . Send ( )
2017-02-07 22:33:23 +01:00
}
2018-02-22 14:58:04 +01:00
// UpdateServiceWithContext is the same as UpdateService with the addition of
// the ability to pass a context and additional request options.
//
// See UpdateService for details on how to use this API operation.
//
// The context must be non-nil and will be used for request cancellation. If
// the context is nil a panic will occur. In the future the SDK may create
// sub-contexts for http.Requests. See https://golang.org/pkg/context/
// for more information on using Contexts.
func ( c * ECS ) UpdateServiceWithContext ( ctx aws . Context , input * UpdateServiceInput , opts ... request . Option ) ( * UpdateServiceOutput , error ) {
req , out := c . UpdateServiceRequest ( input )
req . SetContext ( ctx )
req . ApplyOptions ( opts ... )
return out , req . Send ( )
}
// An object representing a container instance or task attachment.
type Attachment struct {
_ struct { } ` type:"structure" `
// Details of the attachment. For Elastic Network Interfaces, this includes
// the network interface ID, the MAC address, the subnet ID, and the private
// IPv4 address.
Details [ ] * KeyValuePair ` locationName:"details" type:"list" `
// The unique identifier for the attachment.
Id * string ` locationName:"id" type:"string" `
// The status of the attachment. Valid values are PRECREATED, CREATED, ATTACHING,
// ATTACHED, DETACHING, DETACHED, and DELETED.
Status * string ` locationName:"status" type:"string" `
2018-05-28 18:52:03 +02:00
// The type of the attachment, such as ElasticNetworkInterface.
2018-02-22 14:58:04 +01:00
Type * string ` locationName:"type" type:"string" `
}
// String returns the string representation
func ( s Attachment ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Attachment ) GoString ( ) string {
return s . String ( )
}
// SetDetails sets the Details field's value.
func ( s * Attachment ) SetDetails ( v [ ] * KeyValuePair ) * Attachment {
s . Details = v
return s
}
// SetId sets the Id field's value.
func ( s * Attachment ) SetId ( v string ) * Attachment {
s . Id = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * Attachment ) SetStatus ( v string ) * Attachment {
s . Status = & v
return s
}
// SetType sets the Type field's value.
func ( s * Attachment ) SetType ( v string ) * Attachment {
s . Type = & v
return s
}
// An object representing a change in state for a task attachment.
type AttachmentStateChange struct {
_ struct { } ` type:"structure" `
// The Amazon Resource Name (ARN) of the attachment.
//
// AttachmentArn is a required field
AttachmentArn * string ` locationName:"attachmentArn" type:"string" required:"true" `
// The status of the attachment.
//
// Status is a required field
Status * string ` locationName:"status" type:"string" required:"true" `
}
// String returns the string representation
func ( s AttachmentStateChange ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s AttachmentStateChange ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * AttachmentStateChange ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "AttachmentStateChange" }
if s . AttachmentArn == nil {
invalidParams . Add ( request . NewErrParamRequired ( "AttachmentArn" ) )
}
if s . Status == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Status" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttachmentArn sets the AttachmentArn field's value.
func ( s * AttachmentStateChange ) SetAttachmentArn ( v string ) * AttachmentStateChange {
s . AttachmentArn = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * AttachmentStateChange ) SetStatus ( v string ) * AttachmentStateChange {
s . Status = & v
return s
}
// An attribute is a name-value pair associated with an Amazon ECS object. Attributes
2017-02-07 22:33:23 +01:00
// enable you to extend the Amazon ECS data model by adding custom metadata
// to your resources. For more information, see Attributes (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html#attributes)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
type Attribute struct {
_ struct { } ` type:"structure" `
// The name of the attribute. Up to 128 letters (uppercase and lowercase), numbers,
// hyphens, underscores, and periods are allowed.
//
// Name is a required field
Name * string ` locationName:"name" type:"string" required:"true" `
// The ID of the target. You can specify the short form ID for a resource or
// the full Amazon Resource Name (ARN).
TargetId * string ` locationName:"targetId" type:"string" `
// The type of the target with which to attach the attribute. This parameter
// is required if you use the short form ID for a resource instead of the full
2018-02-22 14:58:04 +01:00
// ARN.
2017-02-07 22:33:23 +01:00
TargetType * string ` locationName:"targetType" type:"string" enum:"TargetType" `
// The value of the attribute. Up to 128 letters (uppercase and lowercase),
// numbers, hyphens, underscores, periods, at signs (@), forward slashes, colons,
// and spaces are allowed.
Value * string ` locationName:"value" type:"string" `
}
// String returns the string representation
func ( s Attribute ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Attribute ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * Attribute ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "Attribute" }
if s . Name == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Name" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetName sets the Name field's value.
func ( s * Attribute ) SetName ( v string ) * Attribute {
s . Name = & v
return s
}
// SetTargetId sets the TargetId field's value.
func ( s * Attribute ) SetTargetId ( v string ) * Attribute {
s . TargetId = & v
return s
}
// SetTargetType sets the TargetType field's value.
func ( s * Attribute ) SetTargetType ( v string ) * Attribute {
s . TargetType = & v
return s
}
// SetValue sets the Value field's value.
func ( s * Attribute ) SetValue ( v string ) * Attribute {
s . Value = & v
return s
}
2018-02-22 14:58:04 +01:00
// An object representing the networking details for a task or service.
type AwsVpcConfiguration struct {
_ struct { } ` type:"structure" `
2018-05-28 18:52:03 +02:00
// Whether the task's elastic network interface receives a public IP address.
2018-02-22 14:58:04 +01:00
AssignPublicIp * string ` locationName:"assignPublicIp" type:"string" enum:"AssignPublicIp" `
// The security groups associated with the task or service. If you do not specify
2018-05-28 18:52:03 +02:00
// a security group, the default security group for the VPC is used. There is
// a limit of 5 security groups able to be specified per AwsVpcConfiguration.
2018-02-22 14:58:04 +01:00
SecurityGroups [ ] * string ` locationName:"securityGroups" type:"list" `
2018-05-28 18:52:03 +02:00
// The subnets associated with the task or service. There is a limit of 10 subnets
// able to be specified per AwsVpcConfiguration.
2018-02-22 14:58:04 +01:00
//
// Subnets is a required field
Subnets [ ] * string ` locationName:"subnets" type:"list" required:"true" `
}
// String returns the string representation
func ( s AwsVpcConfiguration ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s AwsVpcConfiguration ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * AwsVpcConfiguration ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "AwsVpcConfiguration" }
if s . Subnets == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Subnets" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAssignPublicIp sets the AssignPublicIp field's value.
func ( s * AwsVpcConfiguration ) SetAssignPublicIp ( v string ) * AwsVpcConfiguration {
s . AssignPublicIp = & v
return s
}
// SetSecurityGroups sets the SecurityGroups field's value.
func ( s * AwsVpcConfiguration ) SetSecurityGroups ( v [ ] * string ) * AwsVpcConfiguration {
s . SecurityGroups = v
return s
}
// SetSubnets sets the Subnets field's value.
func ( s * AwsVpcConfiguration ) SetSubnets ( v [ ] * string ) * AwsVpcConfiguration {
s . Subnets = v
return s
}
2017-02-07 22:33:23 +01:00
// A regional grouping of one or more container instances on which you can run
// task requests. Each account receives a default cluster the first time you
// use the Amazon ECS service, but you may also create other clusters. Clusters
// may contain more than one instance type simultaneously.
type Cluster struct {
_ struct { } ` type:"structure" `
// The number of services that are running on the cluster in an ACTIVE state.
// You can view these services with ListServices.
ActiveServicesCount * int64 ` locationName:"activeServicesCount" type:"integer" `
// The Amazon Resource Name (ARN) that identifies the cluster. The ARN contains
// the arn:aws:ecs namespace, followed by the region of the cluster, the AWS
// account ID of the cluster owner, the cluster namespace, and then the cluster
// name. For example, arn:aws:ecs:region:012345678910:cluster/test..
ClusterArn * string ` locationName:"clusterArn" type:"string" `
// A user-generated string that you use to identify your cluster.
ClusterName * string ` locationName:"clusterName" type:"string" `
// The number of tasks in the cluster that are in the PENDING state.
PendingTasksCount * int64 ` locationName:"pendingTasksCount" type:"integer" `
// The number of container instances registered into the cluster.
RegisteredContainerInstancesCount * int64 ` locationName:"registeredContainerInstancesCount" type:"integer" `
// The number of tasks in the cluster that are in the RUNNING state.
RunningTasksCount * int64 ` locationName:"runningTasksCount" type:"integer" `
2018-02-22 14:58:04 +01:00
// Additional information about your clusters that are separated by launch type,
// including:
//
// * runningEC2TasksCount
//
// * RunningFargateTasksCount
//
// * pendingEC2TasksCount
//
// * pendingFargateTasksCount
//
// * activeEC2ServiceCount
//
// * activeFargateServiceCount
//
// * drainingEC2ServiceCount
//
// * drainingFargateServiceCount
Statistics [ ] * KeyValuePair ` locationName:"statistics" type:"list" `
2017-02-07 22:33:23 +01:00
// The status of the cluster. The valid values are ACTIVE or INACTIVE. ACTIVE
// indicates that you can register container instances with the cluster and
// the associated instances can accept tasks.
Status * string ` locationName:"status" type:"string" `
}
// String returns the string representation
func ( s Cluster ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Cluster ) GoString ( ) string {
return s . String ( )
}
// SetActiveServicesCount sets the ActiveServicesCount field's value.
func ( s * Cluster ) SetActiveServicesCount ( v int64 ) * Cluster {
s . ActiveServicesCount = & v
return s
}
// SetClusterArn sets the ClusterArn field's value.
func ( s * Cluster ) SetClusterArn ( v string ) * Cluster {
s . ClusterArn = & v
return s
}
// SetClusterName sets the ClusterName field's value.
func ( s * Cluster ) SetClusterName ( v string ) * Cluster {
s . ClusterName = & v
return s
}
// SetPendingTasksCount sets the PendingTasksCount field's value.
func ( s * Cluster ) SetPendingTasksCount ( v int64 ) * Cluster {
s . PendingTasksCount = & v
return s
}
// SetRegisteredContainerInstancesCount sets the RegisteredContainerInstancesCount field's value.
func ( s * Cluster ) SetRegisteredContainerInstancesCount ( v int64 ) * Cluster {
s . RegisteredContainerInstancesCount = & v
return s
}
// SetRunningTasksCount sets the RunningTasksCount field's value.
func ( s * Cluster ) SetRunningTasksCount ( v int64 ) * Cluster {
s . RunningTasksCount = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetStatistics sets the Statistics field's value.
func ( s * Cluster ) SetStatistics ( v [ ] * KeyValuePair ) * Cluster {
s . Statistics = v
return s
}
2017-02-07 22:33:23 +01:00
// SetStatus sets the Status field's value.
func ( s * Cluster ) SetStatus ( v string ) * Cluster {
s . Status = & v
return s
}
// A Docker container that is part of a task.
type Container struct {
_ struct { } ` type:"structure" `
// The Amazon Resource Name (ARN) of the container.
ContainerArn * string ` locationName:"containerArn" type:"string" `
// The exit code returned from the container.
ExitCode * int64 ` locationName:"exitCode" type:"integer" `
2018-05-28 18:52:03 +02:00
// The health status of the container. If health checks are not configured for
// this container in its task definition, then it reports health status as UNKNOWN.
HealthStatus * string ` locationName:"healthStatus" type:"string" enum:"HealthStatus" `
2017-02-07 22:33:23 +01:00
// The last known status of the container.
LastStatus * string ` locationName:"lastStatus" type:"string" `
// The name of the container.
Name * string ` locationName:"name" type:"string" `
// The network bindings associated with the container.
NetworkBindings [ ] * NetworkBinding ` locationName:"networkBindings" type:"list" `
2018-02-22 14:58:04 +01:00
// The network interfaces associated with the container.
NetworkInterfaces [ ] * NetworkInterface ` locationName:"networkInterfaces" type:"list" `
2017-02-07 22:33:23 +01:00
// A short (255 max characters) human-readable string to provide additional
// details about a running or stopped container.
Reason * string ` locationName:"reason" type:"string" `
2018-02-22 14:58:04 +01:00
// The ARN of the task.
2017-02-07 22:33:23 +01:00
TaskArn * string ` locationName:"taskArn" type:"string" `
}
// String returns the string representation
func ( s Container ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Container ) GoString ( ) string {
return s . String ( )
}
// SetContainerArn sets the ContainerArn field's value.
func ( s * Container ) SetContainerArn ( v string ) * Container {
s . ContainerArn = & v
return s
}
// SetExitCode sets the ExitCode field's value.
func ( s * Container ) SetExitCode ( v int64 ) * Container {
s . ExitCode = & v
return s
}
2018-05-28 18:52:03 +02:00
// SetHealthStatus sets the HealthStatus field's value.
func ( s * Container ) SetHealthStatus ( v string ) * Container {
s . HealthStatus = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetLastStatus sets the LastStatus field's value.
func ( s * Container ) SetLastStatus ( v string ) * Container {
s . LastStatus = & v
return s
}
// SetName sets the Name field's value.
func ( s * Container ) SetName ( v string ) * Container {
s . Name = & v
return s
}
// SetNetworkBindings sets the NetworkBindings field's value.
func ( s * Container ) SetNetworkBindings ( v [ ] * NetworkBinding ) * Container {
s . NetworkBindings = v
return s
}
2018-02-22 14:58:04 +01:00
// SetNetworkInterfaces sets the NetworkInterfaces field's value.
func ( s * Container ) SetNetworkInterfaces ( v [ ] * NetworkInterface ) * Container {
s . NetworkInterfaces = v
return s
}
2017-02-07 22:33:23 +01:00
// SetReason sets the Reason field's value.
func ( s * Container ) SetReason ( v string ) * Container {
s . Reason = & v
return s
}
// SetTaskArn sets the TaskArn field's value.
func ( s * Container ) SetTaskArn ( v string ) * Container {
s . TaskArn = & v
return s
}
// Container definitions are used in task definitions to describe the different
// containers that are launched as part of a task.
type ContainerDefinition struct {
_ struct { } ` type:"structure" `
// The command that is passed to the container. This parameter maps to Cmd in
2018-02-22 14:58:04 +01:00
// the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the COMMAND parameter to docker run (https://docs.docker.com/engine/reference/run/).
// For more information, see https://docs.docker.com/engine/reference/builder/#cmd
// (https://docs.docker.com/engine/reference/builder/#cmd).
Command [ ] * string ` locationName:"command" type:"list" `
2018-02-22 14:58:04 +01:00
// The number of cpu units reserved for the container. This parameter maps to
// CpuShares in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --cpu-shares option to docker run (https://docs.docker.com/engine/reference/run/).
//
2018-02-22 14:58:04 +01:00
// This field is optional for tasks using the Fargate launch type, and the only
// requirement is that the total amount of CPU reserved for all containers within
// a task be lower than the task-level cpu value.
//
2017-02-07 22:33:23 +01:00
// You can determine the number of CPU units that are available per EC2 instance
// type by multiplying the vCPUs listed for that instance type on the Amazon
// EC2 Instances (http://aws.amazon.com/ec2/instance-types/) detail page by
// 1,024.
//
// For example, if you run a single-container task on a single-core instance
// type with 512 CPU units specified for that container, and that is the only
// task running on the container instance, that container could use the full
// 1,024 CPU unit share at any given time. However, if you launched another
// copy of the same task on that container instance, each task would be guaranteed
// a minimum of 512 CPU units when needed, and each container could float to
// higher CPU usage if the other container was not using it, but if both tasks
// were 100% active all of the time, they would be limited to 512 CPU units.
//
2018-02-22 14:58:04 +01:00
// Linux containers share unallocated CPU units with other containers on the
// container instance with the same ratio as their allocated amount. For example,
// if you run a single-container task on a single-core instance type with 512
// CPU units specified for that container, and that is the only task running
// on the container instance, that container could use the full 1,024 CPU unit
// share at any given time. However, if you launched another copy of the same
// task on that container instance, each task would be guaranteed a minimum
// of 512 CPU units when needed, and each container could float to higher CPU
// usage if the other container was not using it, but if both tasks were 100%
// active all of the time, they would be limited to 512 CPU units.
//
// On Linux container instances, the Docker daemon on the container instance
// uses the CPU value to calculate the relative CPU share ratios for running
// containers. For more information, see CPU share constraint (https://docs.docker.com/engine/reference/run/#cpu-share-constraint)
2017-02-07 22:33:23 +01:00
// in the Docker documentation. The minimum valid CPU share value that the Linux
2018-05-28 18:52:03 +02:00
// kernel allows is 2; however, the CPU parameter is not required, and you can
// use CPU values below 2 in your container definitions. For CPU values below
// 2 (including null), the behavior varies based on your Amazon ECS container
2017-02-07 22:33:23 +01:00
// agent version:
//
// * Agent versions less than or equal to 1.1.0: Null and zero CPU values
// are passed to Docker as 0, which Docker then converts to 1,024 CPU shares.
// CPU values of 1 are passed to Docker as 1, which the Linux kernel converts
// to 2 CPU shares.
//
// * Agent versions greater than or equal to 1.2.0: Null, zero, and CPU values
// of 1 are passed to Docker as 2.
2018-02-22 14:58:04 +01:00
//
// On Windows container instances, the CPU limit is enforced as an absolute
// limit, or a quota. Windows containers only have access to the specified amount
// of CPU that is described in the task definition.
2017-02-07 22:33:23 +01:00
Cpu * int64 ` locationName:"cpu" type:"integer" `
// When this parameter is true, networking is disabled within the container.
2018-02-22 14:58:04 +01:00
// This parameter maps to NetworkDisabled in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/).
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
DisableNetworking * bool ` locationName:"disableNetworking" type:"boolean" `
// A list of DNS search domains that are presented to the container. This parameter
2018-02-22 14:58:04 +01:00
// maps to DnsSearch in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --dns-search option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
DnsSearchDomains [ ] * string ` locationName:"dnsSearchDomains" type:"list" `
// A list of DNS servers that are presented to the container. This parameter
2018-02-22 14:58:04 +01:00
// maps to Dns in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --dns option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
DnsServers [ ] * string ` locationName:"dnsServers" type:"list" `
// A key/value map of labels to add to the container. This parameter maps to
2018-02-22 14:58:04 +01:00
// Labels in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --label option to docker run (https://docs.docker.com/engine/reference/run/).
// This parameter requires version 1.18 of the Docker Remote API or greater
// on your container instance. To check the Docker Remote API version on your
2018-02-22 14:58:04 +01:00
// container instance, log in to your container instance and run the following
2017-02-07 22:33:23 +01:00
// command: sudo docker version | grep "Server API version"
DockerLabels map [ string ] * string ` locationName:"dockerLabels" type:"map" `
// A list of strings to provide custom labels for SELinux and AppArmor multi-level
2018-02-22 14:58:04 +01:00
// security systems. This field is not valid for containers in tasks using the
// Fargate launch type.
//
// This parameter maps to SecurityOpt in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --security-opt option to docker run (https://docs.docker.com/engine/reference/run/).
//
// The Amazon ECS container agent running on a container instance must register
// with the ECS_SELINUX_CAPABLE=true or ECS_APPARMOR_CAPABLE=true environment
// variables before containers placed on that instance can use these security
// options. For more information, see Amazon ECS Container Agent Configuration
// (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-agent-config.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
DockerSecurityOptions [ ] * string ` locationName:"dockerSecurityOptions" type:"list" `
// Early versions of the Amazon ECS container agent do not properly handle entryPoint
// parameters. If you have problems using entryPoint, update your container
// agent or enter your commands and arguments as command array items instead.
//
// The entry point that is passed to the container. This parameter maps to Entrypoint
2018-02-22 14:58:04 +01:00
// in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --entrypoint option to docker run (https://docs.docker.com/engine/reference/run/).
// For more information, see https://docs.docker.com/engine/reference/builder/#entrypoint
// (https://docs.docker.com/engine/reference/builder/#entrypoint).
EntryPoint [ ] * string ` locationName:"entryPoint" type:"list" `
// The environment variables to pass to a container. This parameter maps to
2018-02-22 14:58:04 +01:00
// Env in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --env option to docker run (https://docs.docker.com/engine/reference/run/).
//
2018-02-22 14:58:04 +01:00
// We do not recommend using plaintext environment variables for sensitive information,
// such as credential data.
2017-02-07 22:33:23 +01:00
Environment [ ] * KeyValuePair ` locationName:"environment" type:"list" `
// If the essential parameter of a container is marked as true, and that container
// fails or stops for any reason, all other containers that are part of the
// task are stopped. If the essential parameter of a container is marked as
// false, then its failure does not affect the rest of the containers in a task.
// If this parameter is omitted, a container is assumed to be essential.
//
// All tasks must have at least one essential container. If you have an application
// that is composed of multiple containers, you should group containers that
// are used for a common purpose into components, and separate the different
// components into multiple task definitions. For more information, see Application
// Architecture (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/application_architecture.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Essential * bool ` locationName:"essential" type:"boolean" `
// A list of hostnames and IP address mappings to append to the /etc/hosts file
2018-02-22 14:58:04 +01:00
// on the container. If using the Fargate launch type, this may be used to list
// non-Fargate hosts you want the container to talk to. This parameter maps
// to ExtraHosts in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --add-host option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
ExtraHosts [ ] * HostEntry ` locationName:"extraHosts" type:"list" `
2018-05-28 18:52:03 +02:00
// The health check command and associated configuration parameters for the
// container. This parameter maps to HealthCheck in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
// and the HEALTHCHECK parameter of docker run (https://docs.docker.com/engine/reference/run/).
HealthCheck * HealthCheck ` locationName:"healthCheck" type:"structure" `
2017-02-07 22:33:23 +01:00
// The hostname to use for your container. This parameter maps to Hostname in
2018-02-22 14:58:04 +01:00
// the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --hostname option to docker run (https://docs.docker.com/engine/reference/run/).
2018-05-28 18:52:03 +02:00
//
// The hostname parameter is not supported if using the awsvpc networkMode.
2017-02-07 22:33:23 +01:00
Hostname * string ` locationName:"hostname" type:"string" `
// The image used to start a container. This string is passed directly to the
// Docker daemon. Images in the Docker Hub registry are available by default.
2018-02-22 14:58:04 +01:00
// Other repositories are specified with either repository-url/image:tag or
// repository-url/image@digest. Up to 255 letters (uppercase and lowercase),
// numbers, hyphens, underscores, colons, periods, forward slashes, and number
// signs are allowed. This parameter maps to Image in the Create a container
// (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the IMAGE parameter of docker run (https://docs.docker.com/engine/reference/run/).
//
2018-05-28 18:52:03 +02:00
// * When a new task starts, the Amazon ECS container agent pulls the latest
// version of the specified image and tag for the container to use. However,
// subsequent updates to a repository image are not propagated to already
// running tasks.
//
2018-02-22 14:58:04 +01:00
// * Images in Amazon ECR repositories can be specified by either using the
// full registry/repository:tag or registry/repository@digest. For example,
// 012345678910.dkr.ecr.<region-name>.amazonaws.com/<repository-name>:latest
// or 012345678910.dkr.ecr.<region-name>.amazonaws.com/<repository-name>@sha256:94afd1f2e64d908bc90dbca0035a5b567EXAMPLE.
2017-02-07 22:33:23 +01:00
//
//
// * Images in official repositories on Docker Hub use a single name (for
// example, ubuntu or mongo).
//
// * Images in other repositories on Docker Hub are qualified with an organization
// name (for example, amazon/amazon-ecs-agent).
//
// * Images in other online repositories are qualified further by a domain
// name (for example, quay.io/assemblyline/ubuntu).
Image * string ` locationName:"image" type:"string" `
// The link parameter allows containers to communicate with each other without
2018-02-22 14:58:04 +01:00
// the need for port mappings. Only supported if the network mode of a task
// definition is set to bridge. The name:internalName construct is analogous
// to name:alias in Docker links. Up to 255 letters (uppercase and lowercase),
// numbers, hyphens, and underscores are allowed. For more information about
// linking Docker containers, go to https://docs.docker.com/engine/userguide/networking/default_network/dockerlinks/
2017-02-07 22:33:23 +01:00
// (https://docs.docker.com/engine/userguide/networking/default_network/dockerlinks/).
2018-02-22 14:58:04 +01:00
// This parameter maps to Links in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
// and the --link option to docker run (https://docs.docker.com/engine/reference/commandline/run/).
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
//
// Containers that are collocated on a single container instance may be able
// to communicate with each other without requiring links or host port mappings.
// Network isolation is achieved on the container instance using security groups
// and VPC settings.
Links [ ] * string ` locationName:"links" type:"list" `
2018-02-22 14:58:04 +01:00
// Linux-specific modifications that are applied to the container, such as Linux
// KernelCapabilities.
//
2018-05-28 18:52:03 +02:00
// This parameter is not supported for Windows containers.
2018-02-22 14:58:04 +01:00
LinuxParameters * LinuxParameters ` locationName:"linuxParameters" type:"structure" `
// The log configuration specification for the container.
//
// If using the Fargate launch type, the only supported value is awslogs.
//
// This parameter maps to LogConfig in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --log-driver option to docker run (https://docs.docker.com/engine/reference/run/).
// By default, containers use the same logging driver that the Docker daemon
// uses; however the container may use a different logging driver than the Docker
// daemon by specifying a log driver with this parameter in the container definition.
// To use a different logging driver for a container, the log system must be
// configured properly on the container instance (or on a different log server
// for remote logging options). For more information on the options for different
// supported log drivers, see Configure logging drivers (https://docs.docker.com/engine/admin/logging/overview/)
// in the Docker documentation.
//
// Amazon ECS currently supports a subset of the logging drivers available to
// the Docker daemon (shown in the LogConfiguration data type). Additional log
// drivers may be available in future releases of the Amazon ECS container agent.
//
// This parameter requires version 1.18 of the Docker Remote API or greater
// on your container instance. To check the Docker Remote API version on your
2018-02-22 14:58:04 +01:00
// container instance, log in to your container instance and run the following
2017-02-07 22:33:23 +01:00
// command: sudo docker version | grep "Server API version"
//
// The Amazon ECS container agent running on a container instance must register
// the logging drivers available on that instance with the ECS_AVAILABLE_LOGGING_DRIVERS
// environment variable before containers placed on that instance can use these
// log configuration options. For more information, see Amazon ECS Container
// Agent Configuration (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-agent-config.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
LogConfiguration * LogConfiguration ` locationName:"logConfiguration" type:"structure" `
// The hard limit (in MiB) of memory to present to the container. If your container
// attempts to exceed the memory specified here, the container is killed. This
2018-02-22 14:58:04 +01:00
// parameter maps to Memory in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --memory option to docker run (https://docs.docker.com/engine/reference/run/).
//
2018-05-28 18:52:03 +02:00
// If your containers are part of a task using the Fargate launch type, this
// field is optional and the only requirement is that the total amount of memory
// reserved for all containers within a task be lower than the task memory value.
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// For containers that are part of a task using the EC2 launch type, you must
// specify a non-zero integer for one or both of memory or memoryReservation
2017-02-07 22:33:23 +01:00
// in container definitions. If you specify both, memory must be greater than
// memoryReservation. If you specify memoryReservation, then that value is subtracted
// from the available memory resources for the container instance on which the
// container is placed; otherwise, the value of memory is used.
//
// The Docker daemon reserves a minimum of 4 MiB of memory for a container,
// so you should not specify fewer than 4 MiB of memory for your containers.
Memory * int64 ` locationName:"memory" type:"integer" `
// The soft limit (in MiB) of memory to reserve for the container. When system
// memory is under heavy contention, Docker attempts to keep the container memory
// to this soft limit; however, your container can consume more memory when
// it needs to, up to either the hard limit specified with the memory parameter
// (if applicable), or all of the available memory on the container instance,
// whichever comes first. This parameter maps to MemoryReservation in the Create
2018-02-22 14:58:04 +01:00
// a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --memory-reservation option to docker run (https://docs.docker.com/engine/reference/run/).
//
// You must specify a non-zero integer for one or both of memory or memoryReservation
// in container definitions. If you specify both, memory must be greater than
// memoryReservation. If you specify memoryReservation, then that value is subtracted
// from the available memory resources for the container instance on which the
// container is placed; otherwise, the value of memory is used.
//
// For example, if your container normally uses 128 MiB of memory, but occasionally
// bursts to 256 MiB of memory for short periods of time, you can set a memoryReservation
// of 128 MiB, and a memory hard limit of 300 MiB. This configuration would
// allow the container to only reserve 128 MiB of memory from the remaining
// resources on the container instance, but also allow the container to consume
// more memory resources when needed.
2018-02-22 14:58:04 +01:00
//
// The Docker daemon reserves a minimum of 4 MiB of memory for a container,
// so you should not specify fewer than 4 MiB of memory for your containers.
2017-02-07 22:33:23 +01:00
MemoryReservation * int64 ` locationName:"memoryReservation" type:"integer" `
2018-02-22 14:58:04 +01:00
// The mount points for data volumes in your container.
//
// This parameter maps to Volumes in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --volume option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// Windows containers can mount whole directories on the same drive as $env:ProgramData.
// Windows containers cannot mount directories on a different drive, and mount
// point cannot be across drives.
2017-02-07 22:33:23 +01:00
MountPoints [ ] * MountPoint ` locationName:"mountPoints" type:"list" `
// The name of a container. If you are linking multiple containers together
// in a task definition, the name of one container can be entered in the links
// of another container to connect the containers. Up to 255 letters (uppercase
// and lowercase), numbers, hyphens, and underscores are allowed. This parameter
2018-02-22 14:58:04 +01:00
// maps to name in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --name option to docker run (https://docs.docker.com/engine/reference/run/).
Name * string ` locationName:"name" type:"string" `
// The list of port mappings for the container. Port mappings allow containers
// to access ports on the host container instance to send or receive traffic.
2018-02-22 14:58:04 +01:00
//
// For task definitions that use the awsvpc network mode, you should only specify
// the containerPort. The hostPort can be left blank or it must be the same
// value as the containerPort.
//
// Port mappings on Windows use the NetNAT gateway address rather than localhost.
// There is no loopback for port mappings on Windows, so you cannot access a
// container's mapped port from the host itself.
//
// This parameter maps to PortBindings in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --publish option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
// If the network mode of a task definition is set to none, then you can't specify
// port mappings. If the network mode of a task definition is set to host, then
// host ports must either be undefined or they must match the container port
// in the port mapping.
2017-02-07 22:33:23 +01:00
//
// After a task reaches the RUNNING status, manual and automatic host and container
// port assignments are visible in the Network Bindings section of a container
2018-02-22 14:58:04 +01:00
// description for a selected task in the Amazon ECS console, or the networkBindings
2017-02-07 22:33:23 +01:00
// section DescribeTasks responses.
PortMappings [ ] * PortMapping ` locationName:"portMappings" type:"list" `
// When this parameter is true, the container is given elevated privileges on
// the host container instance (similar to the root user). This parameter maps
2018-02-22 14:58:04 +01:00
// to Privileged in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --privileged option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers or tasks using the
// Fargate launch type.
2017-02-07 22:33:23 +01:00
Privileged * bool ` locationName:"privileged" type:"boolean" `
// When this parameter is true, the container is given read-only access to its
// root file system. This parameter maps to ReadonlyRootfs in the Create a container
2018-02-22 14:58:04 +01:00
// (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --read-only option to docker run.
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
ReadonlyRootFilesystem * bool ` locationName:"readonlyRootFilesystem" type:"boolean" `
// A list of ulimits to set in the container. This parameter maps to Ulimits
2018-02-22 14:58:04 +01:00
// in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --ulimit option to docker run (https://docs.docker.com/engine/reference/run/).
// Valid naming values are displayed in the Ulimit data type. This parameter
// requires version 1.18 of the Docker Remote API or greater on your container
// instance. To check the Docker Remote API version on your container instance,
2018-02-22 14:58:04 +01:00
// log in to your container instance and run the following command: sudo docker
2017-02-07 22:33:23 +01:00
// version | grep "Server API version"
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
Ulimits [ ] * Ulimit ` locationName:"ulimits" type:"list" `
// The user name to use inside the container. This parameter maps to User in
2018-02-22 14:58:04 +01:00
// the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --user option to docker run (https://docs.docker.com/engine/reference/run/).
2018-02-22 14:58:04 +01:00
//
// This parameter is not supported for Windows containers.
2017-02-07 22:33:23 +01:00
User * string ` locationName:"user" type:"string" `
// Data volumes to mount from another container. This parameter maps to VolumesFrom
2018-02-22 14:58:04 +01:00
// in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --volumes-from option to docker run (https://docs.docker.com/engine/reference/run/).
VolumesFrom [ ] * VolumeFrom ` locationName:"volumesFrom" type:"list" `
// The working directory in which to run commands inside the container. This
2018-02-22 14:58:04 +01:00
// parameter maps to WorkingDir in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
2017-02-07 22:33:23 +01:00
// and the --workdir option to docker run (https://docs.docker.com/engine/reference/run/).
WorkingDirectory * string ` locationName:"workingDirectory" type:"string" `
}
// String returns the string representation
func ( s ContainerDefinition ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ContainerDefinition ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * ContainerDefinition ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "ContainerDefinition" }
if s . ExtraHosts != nil {
for i , v := range s . ExtraHosts {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "ExtraHosts" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
2018-05-28 18:52:03 +02:00
if s . HealthCheck != nil {
if err := s . HealthCheck . Validate ( ) ; err != nil {
invalidParams . AddNested ( "HealthCheck" , err . ( request . ErrInvalidParams ) )
}
}
2018-02-22 14:58:04 +01:00
if s . LinuxParameters != nil {
if err := s . LinuxParameters . Validate ( ) ; err != nil {
invalidParams . AddNested ( "LinuxParameters" , err . ( request . ErrInvalidParams ) )
}
}
2017-02-07 22:33:23 +01:00
if s . LogConfiguration != nil {
if err := s . LogConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "LogConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
if s . Ulimits != nil {
for i , v := range s . Ulimits {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Ulimits" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCommand sets the Command field's value.
func ( s * ContainerDefinition ) SetCommand ( v [ ] * string ) * ContainerDefinition {
s . Command = v
return s
}
// SetCpu sets the Cpu field's value.
func ( s * ContainerDefinition ) SetCpu ( v int64 ) * ContainerDefinition {
s . Cpu = & v
return s
}
// SetDisableNetworking sets the DisableNetworking field's value.
func ( s * ContainerDefinition ) SetDisableNetworking ( v bool ) * ContainerDefinition {
s . DisableNetworking = & v
return s
}
// SetDnsSearchDomains sets the DnsSearchDomains field's value.
func ( s * ContainerDefinition ) SetDnsSearchDomains ( v [ ] * string ) * ContainerDefinition {
s . DnsSearchDomains = v
return s
}
// SetDnsServers sets the DnsServers field's value.
func ( s * ContainerDefinition ) SetDnsServers ( v [ ] * string ) * ContainerDefinition {
s . DnsServers = v
return s
}
// SetDockerLabels sets the DockerLabels field's value.
func ( s * ContainerDefinition ) SetDockerLabels ( v map [ string ] * string ) * ContainerDefinition {
s . DockerLabels = v
return s
}
// SetDockerSecurityOptions sets the DockerSecurityOptions field's value.
func ( s * ContainerDefinition ) SetDockerSecurityOptions ( v [ ] * string ) * ContainerDefinition {
s . DockerSecurityOptions = v
return s
}
// SetEntryPoint sets the EntryPoint field's value.
func ( s * ContainerDefinition ) SetEntryPoint ( v [ ] * string ) * ContainerDefinition {
s . EntryPoint = v
return s
}
// SetEnvironment sets the Environment field's value.
func ( s * ContainerDefinition ) SetEnvironment ( v [ ] * KeyValuePair ) * ContainerDefinition {
s . Environment = v
return s
}
// SetEssential sets the Essential field's value.
func ( s * ContainerDefinition ) SetEssential ( v bool ) * ContainerDefinition {
s . Essential = & v
return s
}
// SetExtraHosts sets the ExtraHosts field's value.
func ( s * ContainerDefinition ) SetExtraHosts ( v [ ] * HostEntry ) * ContainerDefinition {
s . ExtraHosts = v
return s
}
2018-05-28 18:52:03 +02:00
// SetHealthCheck sets the HealthCheck field's value.
func ( s * ContainerDefinition ) SetHealthCheck ( v * HealthCheck ) * ContainerDefinition {
s . HealthCheck = v
return s
}
2017-02-07 22:33:23 +01:00
// SetHostname sets the Hostname field's value.
func ( s * ContainerDefinition ) SetHostname ( v string ) * ContainerDefinition {
s . Hostname = & v
return s
}
// SetImage sets the Image field's value.
func ( s * ContainerDefinition ) SetImage ( v string ) * ContainerDefinition {
s . Image = & v
return s
}
// SetLinks sets the Links field's value.
func ( s * ContainerDefinition ) SetLinks ( v [ ] * string ) * ContainerDefinition {
s . Links = v
return s
}
2018-02-22 14:58:04 +01:00
// SetLinuxParameters sets the LinuxParameters field's value.
func ( s * ContainerDefinition ) SetLinuxParameters ( v * LinuxParameters ) * ContainerDefinition {
s . LinuxParameters = v
return s
}
2017-02-07 22:33:23 +01:00
// SetLogConfiguration sets the LogConfiguration field's value.
func ( s * ContainerDefinition ) SetLogConfiguration ( v * LogConfiguration ) * ContainerDefinition {
s . LogConfiguration = v
return s
}
// SetMemory sets the Memory field's value.
func ( s * ContainerDefinition ) SetMemory ( v int64 ) * ContainerDefinition {
s . Memory = & v
return s
}
// SetMemoryReservation sets the MemoryReservation field's value.
func ( s * ContainerDefinition ) SetMemoryReservation ( v int64 ) * ContainerDefinition {
s . MemoryReservation = & v
return s
}
// SetMountPoints sets the MountPoints field's value.
func ( s * ContainerDefinition ) SetMountPoints ( v [ ] * MountPoint ) * ContainerDefinition {
s . MountPoints = v
return s
}
// SetName sets the Name field's value.
func ( s * ContainerDefinition ) SetName ( v string ) * ContainerDefinition {
s . Name = & v
return s
}
// SetPortMappings sets the PortMappings field's value.
func ( s * ContainerDefinition ) SetPortMappings ( v [ ] * PortMapping ) * ContainerDefinition {
s . PortMappings = v
return s
}
// SetPrivileged sets the Privileged field's value.
func ( s * ContainerDefinition ) SetPrivileged ( v bool ) * ContainerDefinition {
s . Privileged = & v
return s
}
// SetReadonlyRootFilesystem sets the ReadonlyRootFilesystem field's value.
func ( s * ContainerDefinition ) SetReadonlyRootFilesystem ( v bool ) * ContainerDefinition {
s . ReadonlyRootFilesystem = & v
return s
}
// SetUlimits sets the Ulimits field's value.
func ( s * ContainerDefinition ) SetUlimits ( v [ ] * Ulimit ) * ContainerDefinition {
s . Ulimits = v
return s
}
// SetUser sets the User field's value.
func ( s * ContainerDefinition ) SetUser ( v string ) * ContainerDefinition {
s . User = & v
return s
}
// SetVolumesFrom sets the VolumesFrom field's value.
func ( s * ContainerDefinition ) SetVolumesFrom ( v [ ] * VolumeFrom ) * ContainerDefinition {
s . VolumesFrom = v
return s
}
// SetWorkingDirectory sets the WorkingDirectory field's value.
func ( s * ContainerDefinition ) SetWorkingDirectory ( v string ) * ContainerDefinition {
s . WorkingDirectory = & v
return s
}
// An EC2 instance that is running the Amazon ECS agent and has been registered
// with a cluster.
type ContainerInstance struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// This parameter returns true if the agent is connected to Amazon ECS. Registered
// instances with an agent that may be unhealthy or stopped return false. Instances
// without a connected agent can't accept placement requests.
2017-02-07 22:33:23 +01:00
AgentConnected * bool ` locationName:"agentConnected" type:"boolean" `
// The status of the most recent agent update. If an update has never been requested,
// this value is NULL.
AgentUpdateStatus * string ` locationName:"agentUpdateStatus" type:"string" enum:"AgentUpdateStatus" `
2018-02-22 14:58:04 +01:00
// The Elastic Network Interfaces associated with the container instance.
Attachments [ ] * Attachment ` locationName:"attachments" type:"list" `
2017-02-07 22:33:23 +01:00
// The attributes set for the container instance, either by the Amazon ECS container
// agent at instance registration or manually with the PutAttributes operation.
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" `
// The Amazon Resource Name (ARN) of the container instance. The ARN contains
// the arn:aws:ecs namespace, followed by the region of the container instance,
// the AWS account ID of the container instance owner, the container-instance
// namespace, and then the container instance ID. For example, arn:aws:ecs:region:aws_account_id:container-instance/container_instance_ID.
ContainerInstanceArn * string ` locationName:"containerInstanceArn" type:"string" `
// The EC2 instance ID of the container instance.
Ec2InstanceId * string ` locationName:"ec2InstanceId" type:"string" `
// The number of tasks on the container instance that are in the PENDING status.
PendingTasksCount * int64 ` locationName:"pendingTasksCount" type:"integer" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the container instance was registered.
RegisteredAt * time . Time ` locationName:"registeredAt" type:"timestamp" timestampFormat:"unix" `
2018-05-28 18:52:03 +02:00
// For CPU and memory resource types, this parameter describes the amount of
// each resource that was available on the container instance when the container
// agent registered it with Amazon ECS; this value represents the total amount
// of CPU and memory that can be allocated on this container instance to tasks.
// For port resource types, this parameter describes the ports that were reserved
// by the Amazon ECS container agent when it registered the container instance
// with Amazon ECS.
2017-02-07 22:33:23 +01:00
RegisteredResources [ ] * Resource ` locationName:"registeredResources" type:"list" `
2018-05-28 18:52:03 +02:00
// For CPU and memory resource types, this parameter describes the remaining
// CPU and memory that has not already been allocated to tasks and is therefore
// available for new tasks. For port resource types, this parameter describes
// the ports that were reserved by the Amazon ECS container agent (at instance
// registration time) and any task containers that have reserved port mappings
// on the host (with the host or bridge network mode). Any port that is not
// specified here is available for new tasks.
2017-02-07 22:33:23 +01:00
RemainingResources [ ] * Resource ` locationName:"remainingResources" type:"list" `
// The number of tasks on the container instance that are in the RUNNING status.
RunningTasksCount * int64 ` locationName:"runningTasksCount" type:"integer" `
2018-02-22 14:58:04 +01:00
// The status of the container instance. The valid values are ACTIVE, INACTIVE,
// or DRAINING. ACTIVE indicates that the container instance can accept tasks.
// DRAINING indicates that new tasks are not placed on the container instance
// and any service tasks running on the container instance are removed if possible.
// For more information, see Container Instance Draining (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/container-instance-draining.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Status * string ` locationName:"status" type:"string" `
// The version counter for the container instance. Every time a container instance
// experiences a change that triggers a CloudWatch event, the version counter
// is incremented. If you are replicating your Amazon ECS container instance
2018-02-22 14:58:04 +01:00
// state with CloudWatch Events, you can compare the version of a container
2017-02-07 22:33:23 +01:00
// instance reported by the Amazon ECS APIs with the version reported in CloudWatch
2018-02-22 14:58:04 +01:00
// Events for the container instance (inside the detail object) to verify that
2017-02-07 22:33:23 +01:00
// the version in your event stream is current.
Version * int64 ` locationName:"version" type:"long" `
// The version information for the Amazon ECS container agent and Docker daemon
// running on the container instance.
VersionInfo * VersionInfo ` locationName:"versionInfo" type:"structure" `
}
// String returns the string representation
func ( s ContainerInstance ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ContainerInstance ) GoString ( ) string {
return s . String ( )
}
// SetAgentConnected sets the AgentConnected field's value.
func ( s * ContainerInstance ) SetAgentConnected ( v bool ) * ContainerInstance {
s . AgentConnected = & v
return s
}
// SetAgentUpdateStatus sets the AgentUpdateStatus field's value.
func ( s * ContainerInstance ) SetAgentUpdateStatus ( v string ) * ContainerInstance {
s . AgentUpdateStatus = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetAttachments sets the Attachments field's value.
func ( s * ContainerInstance ) SetAttachments ( v [ ] * Attachment ) * ContainerInstance {
s . Attachments = v
return s
}
2017-02-07 22:33:23 +01:00
// SetAttributes sets the Attributes field's value.
func ( s * ContainerInstance ) SetAttributes ( v [ ] * Attribute ) * ContainerInstance {
s . Attributes = v
return s
}
// SetContainerInstanceArn sets the ContainerInstanceArn field's value.
func ( s * ContainerInstance ) SetContainerInstanceArn ( v string ) * ContainerInstance {
s . ContainerInstanceArn = & v
return s
}
// SetEc2InstanceId sets the Ec2InstanceId field's value.
func ( s * ContainerInstance ) SetEc2InstanceId ( v string ) * ContainerInstance {
s . Ec2InstanceId = & v
return s
}
// SetPendingTasksCount sets the PendingTasksCount field's value.
func ( s * ContainerInstance ) SetPendingTasksCount ( v int64 ) * ContainerInstance {
s . PendingTasksCount = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetRegisteredAt sets the RegisteredAt field's value.
func ( s * ContainerInstance ) SetRegisteredAt ( v time . Time ) * ContainerInstance {
s . RegisteredAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetRegisteredResources sets the RegisteredResources field's value.
func ( s * ContainerInstance ) SetRegisteredResources ( v [ ] * Resource ) * ContainerInstance {
s . RegisteredResources = v
return s
}
// SetRemainingResources sets the RemainingResources field's value.
func ( s * ContainerInstance ) SetRemainingResources ( v [ ] * Resource ) * ContainerInstance {
s . RemainingResources = v
return s
}
// SetRunningTasksCount sets the RunningTasksCount field's value.
func ( s * ContainerInstance ) SetRunningTasksCount ( v int64 ) * ContainerInstance {
s . RunningTasksCount = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * ContainerInstance ) SetStatus ( v string ) * ContainerInstance {
s . Status = & v
return s
}
// SetVersion sets the Version field's value.
func ( s * ContainerInstance ) SetVersion ( v int64 ) * ContainerInstance {
s . Version = & v
return s
}
// SetVersionInfo sets the VersionInfo field's value.
func ( s * ContainerInstance ) SetVersionInfo ( v * VersionInfo ) * ContainerInstance {
s . VersionInfo = v
return s
}
// The overrides that should be sent to a container.
type ContainerOverride struct {
_ struct { } ` type:"structure" `
// The command to send to the container that overrides the default command from
2018-02-22 14:58:04 +01:00
// the Docker image or the task definition. You must also specify a container
// name.
2017-02-07 22:33:23 +01:00
Command [ ] * string ` locationName:"command" type:"list" `
2018-02-22 14:58:04 +01:00
// The number of cpu units reserved for the container, instead of the default
// value from the task definition. You must also specify a container name.
Cpu * int64 ` locationName:"cpu" type:"integer" `
2017-02-07 22:33:23 +01:00
// The environment variables to send to the container. You can add new environment
// variables, which are added to the container at launch, or you can override
// the existing environment variables from the Docker image or the task definition.
2018-02-22 14:58:04 +01:00
// You must also specify a container name.
2017-02-07 22:33:23 +01:00
Environment [ ] * KeyValuePair ` locationName:"environment" type:"list" `
2018-02-22 14:58:04 +01:00
// The hard limit (in MiB) of memory to present to the container, instead of
// the default value from the task definition. If your container attempts to
// exceed the memory specified here, the container is killed. You must also
// specify a container name.
Memory * int64 ` locationName:"memory" type:"integer" `
// The soft limit (in MiB) of memory to reserve for the container, instead of
// the default value from the task definition. You must also specify a container
// name.
MemoryReservation * int64 ` locationName:"memoryReservation" type:"integer" `
// The name of the container that receives the override. This parameter is required
// if any override is specified.
2017-02-07 22:33:23 +01:00
Name * string ` locationName:"name" type:"string" `
}
// String returns the string representation
func ( s ContainerOverride ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ContainerOverride ) GoString ( ) string {
return s . String ( )
}
// SetCommand sets the Command field's value.
func ( s * ContainerOverride ) SetCommand ( v [ ] * string ) * ContainerOverride {
s . Command = v
return s
}
2018-02-22 14:58:04 +01:00
// SetCpu sets the Cpu field's value.
func ( s * ContainerOverride ) SetCpu ( v int64 ) * ContainerOverride {
s . Cpu = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetEnvironment sets the Environment field's value.
func ( s * ContainerOverride ) SetEnvironment ( v [ ] * KeyValuePair ) * ContainerOverride {
s . Environment = v
return s
}
2018-02-22 14:58:04 +01:00
// SetMemory sets the Memory field's value.
func ( s * ContainerOverride ) SetMemory ( v int64 ) * ContainerOverride {
s . Memory = & v
return s
}
// SetMemoryReservation sets the MemoryReservation field's value.
func ( s * ContainerOverride ) SetMemoryReservation ( v int64 ) * ContainerOverride {
s . MemoryReservation = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetName sets the Name field's value.
func ( s * ContainerOverride ) SetName ( v string ) * ContainerOverride {
s . Name = & v
return s
}
2018-02-22 14:58:04 +01:00
// An object representing a change in state for a container.
type ContainerStateChange struct {
_ struct { } ` type:"structure" `
// The name of the container.
ContainerName * string ` locationName:"containerName" type:"string" `
// The exit code for the container, if the state change is a result of the container
// exiting.
ExitCode * int64 ` locationName:"exitCode" type:"integer" `
// Any network bindings associated with the container.
NetworkBindings [ ] * NetworkBinding ` locationName:"networkBindings" type:"list" `
// The reason for the state change.
Reason * string ` locationName:"reason" type:"string" `
// The status of the container.
Status * string ` locationName:"status" type:"string" `
}
// String returns the string representation
func ( s ContainerStateChange ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ContainerStateChange ) GoString ( ) string {
return s . String ( )
}
// SetContainerName sets the ContainerName field's value.
func ( s * ContainerStateChange ) SetContainerName ( v string ) * ContainerStateChange {
s . ContainerName = & v
return s
}
// SetExitCode sets the ExitCode field's value.
func ( s * ContainerStateChange ) SetExitCode ( v int64 ) * ContainerStateChange {
s . ExitCode = & v
return s
}
// SetNetworkBindings sets the NetworkBindings field's value.
func ( s * ContainerStateChange ) SetNetworkBindings ( v [ ] * NetworkBinding ) * ContainerStateChange {
s . NetworkBindings = v
return s
}
// SetReason sets the Reason field's value.
func ( s * ContainerStateChange ) SetReason ( v string ) * ContainerStateChange {
s . Reason = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * ContainerStateChange ) SetStatus ( v string ) * ContainerStateChange {
s . Status = & v
return s
}
2017-02-07 22:33:23 +01:00
type CreateClusterInput struct {
_ struct { } ` type:"structure" `
// The name of your cluster. If you do not specify a name for your cluster,
// you create a cluster named default. Up to 255 letters (uppercase and lowercase),
// numbers, hyphens, and underscores are allowed.
ClusterName * string ` locationName:"clusterName" type:"string" `
}
// String returns the string representation
func ( s CreateClusterInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s CreateClusterInput ) GoString ( ) string {
return s . String ( )
}
// SetClusterName sets the ClusterName field's value.
func ( s * CreateClusterInput ) SetClusterName ( v string ) * CreateClusterInput {
s . ClusterName = & v
return s
}
type CreateClusterOutput struct {
_ struct { } ` type:"structure" `
// The full description of your new cluster.
Cluster * Cluster ` locationName:"cluster" type:"structure" `
}
// String returns the string representation
func ( s CreateClusterOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s CreateClusterOutput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * CreateClusterOutput ) SetCluster ( v * Cluster ) * CreateClusterOutput {
s . Cluster = v
return s
}
type CreateServiceInput struct {
_ struct { } ` type:"structure" `
2018-05-28 18:52:03 +02:00
// Unique, case-sensitive identifier that you provide to ensure the idempotency
// of the request. Up to 32 ASCII characters are allowed.
2017-02-07 22:33:23 +01:00
ClientToken * string ` locationName:"clientToken" type:"string" `
// The short name or full Amazon Resource Name (ARN) of the cluster on which
// to run your service. If you do not specify a cluster, the default cluster
// is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// Optional deployment parameters that control how many tasks run during the
// deployment and the ordering of stopping and starting tasks.
DeploymentConfiguration * DeploymentConfiguration ` locationName:"deploymentConfiguration" type:"structure" `
// The number of instantiations of the specified task definition to place and
// keep running on your cluster.
//
// DesiredCount is a required field
DesiredCount * int64 ` locationName:"desiredCount" type:"integer" required:"true" `
2018-02-22 14:58:04 +01:00
// The period of time, in seconds, that the Amazon ECS service scheduler should
// ignore unhealthy Elastic Load Balancing target health checks after a task
// has first started. This is only valid if your service is configured to use
// a load balancer. If your service's tasks take a while to start and respond
2018-05-28 18:52:03 +02:00
// to Elastic Load Balancing health checks, you can specify a health check grace
// period of up to 1,800 seconds during which the ECS service scheduler ignores
// health check status. This grace period can prevent the ECS service scheduler
// from marking tasks as unhealthy and stopping them before they have time to
// come up.
2018-02-22 14:58:04 +01:00
HealthCheckGracePeriodSeconds * int64 ` locationName:"healthCheckGracePeriodSeconds" type:"integer" `
// The launch type on which to run your service.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
2017-02-07 22:33:23 +01:00
// A load balancer object representing the load balancer to use with your service.
// Currently, you are limited to one load balancer or target group per service.
// After you create a service, the load balancer name or target group ARN, container
// name, and container port specified in the service definition are immutable.
//
2018-02-22 14:58:04 +01:00
// For Classic Load Balancers, this object must contain the load balancer name,
// the container name (as it appears in a container definition), and the container
// port to access from the load balancer. When a task from this service is placed
// on a container instance, the container instance is registered with the load
// balancer specified here.
//
// For Application Load Balancers and Network Load Balancers, this object must
// contain the load balancer target group ARN, the container name (as it appears
// in a container definition), and the container port to access from the load
// balancer. When a task from this service is placed on a container instance,
// the container instance and port combination is registered as a target in
// the target group specified here.
2018-05-28 18:52:03 +02:00
//
// Services with tasks that use the awsvpc network mode (for example, those
// with the Fargate launch type) only support Application Load Balancers and
// Network Load Balancers; Classic Load Balancers are not supported. Also, when
// you create any target groups for these services, you must choose ip as the
// target type, not instance, because tasks that use the awsvpc network mode
// are associated with an elastic network interface, not an Amazon EC2 instance.
2017-02-07 22:33:23 +01:00
LoadBalancers [ ] * LoadBalancer ` locationName:"loadBalancers" type:"list" `
2018-02-22 14:58:04 +01:00
// The network configuration for the service. This parameter is required for
// task definitions that use the awsvpc network mode to receive their own Elastic
// Network Interface, and it is not supported for other network modes. For more
// information, see Task Networking (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
2017-02-07 22:33:23 +01:00
// An array of placement constraint objects to use for tasks in your service.
// You can specify a maximum of 10 constraints per task (this limit includes
// constraints in the task definition and those specified at run time).
PlacementConstraints [ ] * PlacementConstraint ` locationName:"placementConstraints" type:"list" `
// The placement strategy objects to use for tasks in your service. You can
2018-02-22 14:58:04 +01:00
// specify a maximum of five strategy rules per service.
2017-02-07 22:33:23 +01:00
PlacementStrategy [ ] * PlacementStrategy ` locationName:"placementStrategy" type:"list" `
2018-02-22 14:58:04 +01:00
// The platform version on which to run your service. If one is not specified,
// the latest version is used by default.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
2017-02-07 22:33:23 +01:00
// The name or full Amazon Resource Name (ARN) of the IAM role that allows Amazon
// ECS to make calls to your load balancer on your behalf. This parameter is
2018-02-22 14:58:04 +01:00
// only permitted if you are using a load balancer with your service and your
// task definition does not use the awsvpc network mode. If you specify the
// role parameter, you must also specify a load balancer object with the loadBalancers
// parameter.
//
// If your account has already created the Amazon ECS service-linked role, that
// role is used by default for your service unless you specify a role here.
// The service-linked role is required if your task definition uses the awsvpc
// network mode, in which case you should not specify a role here. For more
// information, see Using Service-Linked Roles for Amazon ECS (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/using-service-linked-roles.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// If your specified role has a path other than /, then you must either specify
// the full role ARN (this is recommended) or prefix the role name with the
// path. For example, if a role with the name bar has a path of /foo/ then you
// would specify /foo/bar as the role name. For more information, see Friendly
// Names and Paths (http://docs.aws.amazon.com/IAM/latest/UserGuide/reference_identifiers.html#identifiers-friendly-names)
// in the IAM User Guide.
Role * string ` locationName:"role" type:"string" `
// The name of your service. Up to 255 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed. Service names must be unique within
// a cluster, but you can have similarly named services in multiple clusters
// within a region or across multiple regions.
//
// ServiceName is a required field
ServiceName * string ` locationName:"serviceName" type:"string" required:"true" `
2018-05-28 18:52:03 +02:00
// The details of the service discovery registries you want to assign to this
// service. For more information, see Service Discovery (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/service-discovery.html).
//
// Service discovery is supported for Fargate tasks if using platform version
// v1.1.0 or later. For more information, see AWS Fargate Platform Versions
// (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html).
ServiceRegistries [ ] * ServiceRegistry ` locationName:"serviceRegistries" type:"list" `
2018-02-22 14:58:04 +01:00
// The family and revision (family:revision) or full ARN of the task definition
// to run in your service. If a revision is not specified, the latest ACTIVE
// revision is used.
2017-02-07 22:33:23 +01:00
//
// TaskDefinition is a required field
TaskDefinition * string ` locationName:"taskDefinition" type:"string" required:"true" `
}
// String returns the string representation
func ( s CreateServiceInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s CreateServiceInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * CreateServiceInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "CreateServiceInput" }
if s . DesiredCount == nil {
invalidParams . Add ( request . NewErrParamRequired ( "DesiredCount" ) )
}
if s . ServiceName == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ServiceName" ) )
}
if s . TaskDefinition == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TaskDefinition" ) )
}
2018-02-22 14:58:04 +01:00
if s . NetworkConfiguration != nil {
if err := s . NetworkConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "NetworkConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
2017-02-07 22:33:23 +01:00
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetClientToken sets the ClientToken field's value.
func ( s * CreateServiceInput ) SetClientToken ( v string ) * CreateServiceInput {
s . ClientToken = & v
return s
}
// SetCluster sets the Cluster field's value.
func ( s * CreateServiceInput ) SetCluster ( v string ) * CreateServiceInput {
s . Cluster = & v
return s
}
// SetDeploymentConfiguration sets the DeploymentConfiguration field's value.
func ( s * CreateServiceInput ) SetDeploymentConfiguration ( v * DeploymentConfiguration ) * CreateServiceInput {
s . DeploymentConfiguration = v
return s
}
// SetDesiredCount sets the DesiredCount field's value.
func ( s * CreateServiceInput ) SetDesiredCount ( v int64 ) * CreateServiceInput {
s . DesiredCount = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetHealthCheckGracePeriodSeconds sets the HealthCheckGracePeriodSeconds field's value.
func ( s * CreateServiceInput ) SetHealthCheckGracePeriodSeconds ( v int64 ) * CreateServiceInput {
s . HealthCheckGracePeriodSeconds = & v
return s
}
// SetLaunchType sets the LaunchType field's value.
func ( s * CreateServiceInput ) SetLaunchType ( v string ) * CreateServiceInput {
s . LaunchType = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetLoadBalancers sets the LoadBalancers field's value.
func ( s * CreateServiceInput ) SetLoadBalancers ( v [ ] * LoadBalancer ) * CreateServiceInput {
s . LoadBalancers = v
return s
}
2018-02-22 14:58:04 +01:00
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * CreateServiceInput ) SetNetworkConfiguration ( v * NetworkConfiguration ) * CreateServiceInput {
s . NetworkConfiguration = v
return s
}
2017-02-07 22:33:23 +01:00
// SetPlacementConstraints sets the PlacementConstraints field's value.
func ( s * CreateServiceInput ) SetPlacementConstraints ( v [ ] * PlacementConstraint ) * CreateServiceInput {
s . PlacementConstraints = v
return s
}
// SetPlacementStrategy sets the PlacementStrategy field's value.
func ( s * CreateServiceInput ) SetPlacementStrategy ( v [ ] * PlacementStrategy ) * CreateServiceInput {
s . PlacementStrategy = v
return s
}
2018-02-22 14:58:04 +01:00
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * CreateServiceInput ) SetPlatformVersion ( v string ) * CreateServiceInput {
s . PlatformVersion = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetRole sets the Role field's value.
func ( s * CreateServiceInput ) SetRole ( v string ) * CreateServiceInput {
s . Role = & v
return s
}
// SetServiceName sets the ServiceName field's value.
func ( s * CreateServiceInput ) SetServiceName ( v string ) * CreateServiceInput {
s . ServiceName = & v
return s
}
2018-05-28 18:52:03 +02:00
// SetServiceRegistries sets the ServiceRegistries field's value.
func ( s * CreateServiceInput ) SetServiceRegistries ( v [ ] * ServiceRegistry ) * CreateServiceInput {
s . ServiceRegistries = v
return s
}
2017-02-07 22:33:23 +01:00
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * CreateServiceInput ) SetTaskDefinition ( v string ) * CreateServiceInput {
s . TaskDefinition = & v
return s
}
type CreateServiceOutput struct {
_ struct { } ` type:"structure" `
// The full description of your service following the create call.
Service * Service ` locationName:"service" type:"structure" `
}
// String returns the string representation
func ( s CreateServiceOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s CreateServiceOutput ) GoString ( ) string {
return s . String ( )
}
// SetService sets the Service field's value.
func ( s * CreateServiceOutput ) SetService ( v * Service ) * CreateServiceOutput {
s . Service = v
return s
}
type DeleteAttributesInput struct {
_ struct { } ` type:"structure" `
// The attributes to delete from your resource. You can specify up to 10 attributes
// per request. For custom attributes, specify the attribute name and target
// ID, but do not specify the value. If you specify the target ID using the
// short form, you must also specify the target type.
//
// Attributes is a required field
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" required:"true" `
// The short name or full Amazon Resource Name (ARN) of the cluster that contains
2018-02-22 14:58:04 +01:00
// the resource to delete attributes. If you do not specify a cluster, the default
2017-02-07 22:33:23 +01:00
// cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
}
// String returns the string representation
func ( s DeleteAttributesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteAttributesInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DeleteAttributesInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DeleteAttributesInput" }
if s . Attributes == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Attributes" ) )
}
if s . Attributes != nil {
for i , v := range s . Attributes {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Attributes" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttributes sets the Attributes field's value.
func ( s * DeleteAttributesInput ) SetAttributes ( v [ ] * Attribute ) * DeleteAttributesInput {
s . Attributes = v
return s
}
// SetCluster sets the Cluster field's value.
func ( s * DeleteAttributesInput ) SetCluster ( v string ) * DeleteAttributesInput {
s . Cluster = & v
return s
}
type DeleteAttributesOutput struct {
_ struct { } ` type:"structure" `
// A list of attribute objects that were successfully deleted from your resource.
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" `
}
// String returns the string representation
func ( s DeleteAttributesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteAttributesOutput ) GoString ( ) string {
return s . String ( )
}
// SetAttributes sets the Attributes field's value.
func ( s * DeleteAttributesOutput ) SetAttributes ( v [ ] * Attribute ) * DeleteAttributesOutput {
s . Attributes = v
return s
}
type DeleteClusterInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster to delete.
//
// Cluster is a required field
Cluster * string ` locationName:"cluster" type:"string" required:"true" `
}
// String returns the string representation
func ( s DeleteClusterInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteClusterInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DeleteClusterInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DeleteClusterInput" }
if s . Cluster == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Cluster" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DeleteClusterInput ) SetCluster ( v string ) * DeleteClusterInput {
s . Cluster = & v
return s
}
type DeleteClusterOutput struct {
_ struct { } ` type:"structure" `
// The full description of the deleted cluster.
Cluster * Cluster ` locationName:"cluster" type:"structure" `
}
// String returns the string representation
func ( s DeleteClusterOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteClusterOutput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * DeleteClusterOutput ) SetCluster ( v * Cluster ) * DeleteClusterOutput {
s . Cluster = v
return s
}
type DeleteServiceInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the service to delete. If you do not specify a cluster, the default cluster
// is assumed.
2017-02-07 22:33:23 +01:00
Cluster * string ` locationName:"cluster" type:"string" `
// The name of the service to delete.
//
// Service is a required field
Service * string ` locationName:"service" type:"string" required:"true" `
}
// String returns the string representation
func ( s DeleteServiceInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteServiceInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DeleteServiceInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DeleteServiceInput" }
if s . Service == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Service" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DeleteServiceInput ) SetCluster ( v string ) * DeleteServiceInput {
s . Cluster = & v
return s
}
// SetService sets the Service field's value.
func ( s * DeleteServiceInput ) SetService ( v string ) * DeleteServiceInput {
s . Service = & v
return s
}
type DeleteServiceOutput struct {
_ struct { } ` type:"structure" `
// The full description of the deleted service.
Service * Service ` locationName:"service" type:"structure" `
}
// String returns the string representation
func ( s DeleteServiceOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeleteServiceOutput ) GoString ( ) string {
return s . String ( )
}
// SetService sets the Service field's value.
func ( s * DeleteServiceOutput ) SetService ( v * Service ) * DeleteServiceOutput {
s . Service = v
return s
}
// The details of an Amazon ECS service deployment.
type Deployment struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the service was created.
2017-02-07 22:33:23 +01:00
CreatedAt * time . Time ` locationName:"createdAt" type:"timestamp" timestampFormat:"unix" `
// The most recent desired count of tasks that was specified for the service
// to deploy or maintain.
DesiredCount * int64 ` locationName:"desiredCount" type:"integer" `
// The ID of the deployment.
Id * string ` locationName:"id" type:"string" `
2018-02-22 14:58:04 +01:00
// The launch type on which your service is running.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
// The VPC subnet and security group configuration for tasks that receive their
// own Elastic Network Interface by using the awsvpc networking mode.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
2017-02-07 22:33:23 +01:00
// The number of tasks in the deployment that are in the PENDING status.
PendingCount * int64 ` locationName:"pendingCount" type:"integer" `
2018-02-22 14:58:04 +01:00
// The platform version on which your service is running.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
2017-02-07 22:33:23 +01:00
// The number of tasks in the deployment that are in the RUNNING status.
RunningCount * int64 ` locationName:"runningCount" type:"integer" `
// The status of the deployment. Valid values are PRIMARY (for the most recent
// deployment), ACTIVE (for previous deployments that still have tasks running,
// but are being replaced with the PRIMARY deployment), and INACTIVE (for deployments
// that have been completely replaced).
Status * string ` locationName:"status" type:"string" `
// The most recent task definition that was specified for the service to use.
TaskDefinition * string ` locationName:"taskDefinition" type:"string" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the service was last updated.
2017-02-07 22:33:23 +01:00
UpdatedAt * time . Time ` locationName:"updatedAt" type:"timestamp" timestampFormat:"unix" `
}
// String returns the string representation
func ( s Deployment ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Deployment ) GoString ( ) string {
return s . String ( )
}
// SetCreatedAt sets the CreatedAt field's value.
func ( s * Deployment ) SetCreatedAt ( v time . Time ) * Deployment {
s . CreatedAt = & v
return s
}
// SetDesiredCount sets the DesiredCount field's value.
func ( s * Deployment ) SetDesiredCount ( v int64 ) * Deployment {
s . DesiredCount = & v
return s
}
// SetId sets the Id field's value.
func ( s * Deployment ) SetId ( v string ) * Deployment {
s . Id = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetLaunchType sets the LaunchType field's value.
func ( s * Deployment ) SetLaunchType ( v string ) * Deployment {
s . LaunchType = & v
return s
}
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * Deployment ) SetNetworkConfiguration ( v * NetworkConfiguration ) * Deployment {
s . NetworkConfiguration = v
return s
}
2017-02-07 22:33:23 +01:00
// SetPendingCount sets the PendingCount field's value.
func ( s * Deployment ) SetPendingCount ( v int64 ) * Deployment {
s . PendingCount = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * Deployment ) SetPlatformVersion ( v string ) * Deployment {
s . PlatformVersion = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetRunningCount sets the RunningCount field's value.
func ( s * Deployment ) SetRunningCount ( v int64 ) * Deployment {
s . RunningCount = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * Deployment ) SetStatus ( v string ) * Deployment {
s . Status = & v
return s
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * Deployment ) SetTaskDefinition ( v string ) * Deployment {
s . TaskDefinition = & v
return s
}
// SetUpdatedAt sets the UpdatedAt field's value.
func ( s * Deployment ) SetUpdatedAt ( v time . Time ) * Deployment {
s . UpdatedAt = & v
return s
}
// Optional deployment parameters that control how many tasks run during the
// deployment and the ordering of stopping and starting tasks.
type DeploymentConfiguration struct {
_ struct { } ` type:"structure" `
// The upper limit (as a percentage of the service's desiredCount) of the number
// of tasks that are allowed in the RUNNING or PENDING state in a service during
// a deployment. The maximum number of tasks during a deployment is the desiredCount
// multiplied by maximumPercent/100, rounded down to the nearest integer value.
MaximumPercent * int64 ` locationName:"maximumPercent" type:"integer" `
// The lower limit (as a percentage of the service's desiredCount) of the number
// of running tasks that must remain in the RUNNING state in a service during
2018-02-22 14:58:04 +01:00
// a deployment. The minimum number of healthy tasks during a deployment is
// the desiredCount multiplied by minimumHealthyPercent/100, rounded up to the
// nearest integer value.
2017-02-07 22:33:23 +01:00
MinimumHealthyPercent * int64 ` locationName:"minimumHealthyPercent" type:"integer" `
}
// String returns the string representation
func ( s DeploymentConfiguration ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeploymentConfiguration ) GoString ( ) string {
return s . String ( )
}
// SetMaximumPercent sets the MaximumPercent field's value.
func ( s * DeploymentConfiguration ) SetMaximumPercent ( v int64 ) * DeploymentConfiguration {
s . MaximumPercent = & v
return s
}
// SetMinimumHealthyPercent sets the MinimumHealthyPercent field's value.
func ( s * DeploymentConfiguration ) SetMinimumHealthyPercent ( v int64 ) * DeploymentConfiguration {
s . MinimumHealthyPercent = & v
return s
}
type DeregisterContainerInstanceInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the container instance to deregister. If you do not specify a cluster, the
// default cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The container instance ID or full ARN of the container instance to deregister.
// The ARN contains the arn:aws:ecs namespace, followed by the region of the
// container instance, the AWS account ID of the container instance owner, the
// container-instance namespace, and then the container instance ID. For example,
// arn:aws:ecs:region:aws_account_id:container-instance/container_instance_ID.
2017-02-07 22:33:23 +01:00
//
// ContainerInstance is a required field
ContainerInstance * string ` locationName:"containerInstance" type:"string" required:"true" `
// Forces the deregistration of the container instance. If you have tasks running
// on the container instance when you deregister it with the force option, these
// tasks remain running until you terminate the instance or the tasks stop through
// some other means, but they are orphaned (no longer monitored or accounted
// for by Amazon ECS). If an orphaned task on your container instance is part
// of an Amazon ECS service, then the service scheduler starts another copy
// of that task, on a different container instance if possible.
//
// Any containers in orphaned service tasks that are registered with a Classic
2018-02-22 14:58:04 +01:00
// Load Balancer or an Application Load Balancer target group are deregistered.
// They begin connection draining according to the settings on the load balancer
// or target group.
2017-02-07 22:33:23 +01:00
Force * bool ` locationName:"force" type:"boolean" `
}
// String returns the string representation
func ( s DeregisterContainerInstanceInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeregisterContainerInstanceInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DeregisterContainerInstanceInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DeregisterContainerInstanceInput" }
if s . ContainerInstance == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerInstance" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DeregisterContainerInstanceInput ) SetCluster ( v string ) * DeregisterContainerInstanceInput {
s . Cluster = & v
return s
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * DeregisterContainerInstanceInput ) SetContainerInstance ( v string ) * DeregisterContainerInstanceInput {
s . ContainerInstance = & v
return s
}
// SetForce sets the Force field's value.
func ( s * DeregisterContainerInstanceInput ) SetForce ( v bool ) * DeregisterContainerInstanceInput {
s . Force = & v
return s
}
type DeregisterContainerInstanceOutput struct {
_ struct { } ` type:"structure" `
// The container instance that was deregistered.
ContainerInstance * ContainerInstance ` locationName:"containerInstance" type:"structure" `
}
// String returns the string representation
func ( s DeregisterContainerInstanceOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeregisterContainerInstanceOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * DeregisterContainerInstanceOutput ) SetContainerInstance ( v * ContainerInstance ) * DeregisterContainerInstanceOutput {
s . ContainerInstance = v
return s
}
type DeregisterTaskDefinitionInput struct {
_ struct { } ` type:"structure" `
// The family and revision (family:revision) or full Amazon Resource Name (ARN)
// of the task definition to deregister. You must specify a revision.
//
// TaskDefinition is a required field
TaskDefinition * string ` locationName:"taskDefinition" type:"string" required:"true" `
}
// String returns the string representation
func ( s DeregisterTaskDefinitionInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeregisterTaskDefinitionInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DeregisterTaskDefinitionInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DeregisterTaskDefinitionInput" }
if s . TaskDefinition == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TaskDefinition" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * DeregisterTaskDefinitionInput ) SetTaskDefinition ( v string ) * DeregisterTaskDefinitionInput {
s . TaskDefinition = & v
return s
}
type DeregisterTaskDefinitionOutput struct {
_ struct { } ` type:"structure" `
// The full description of the deregistered task.
TaskDefinition * TaskDefinition ` locationName:"taskDefinition" type:"structure" `
}
// String returns the string representation
func ( s DeregisterTaskDefinitionOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DeregisterTaskDefinitionOutput ) GoString ( ) string {
return s . String ( )
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * DeregisterTaskDefinitionOutput ) SetTaskDefinition ( v * TaskDefinition ) * DeregisterTaskDefinitionOutput {
s . TaskDefinition = v
return s
}
type DescribeClustersInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// A list of up to 100 cluster names or full cluster Amazon Resource Name (ARN)
// entries. If you do not specify a cluster, the default cluster is assumed.
2017-02-07 22:33:23 +01:00
Clusters [ ] * string ` locationName:"clusters" type:"list" `
2018-02-22 14:58:04 +01:00
// Additional information about your clusters to be separated by launch type,
// including:
//
// * runningEC2TasksCount
//
// * runningFargateTasksCount
//
// * pendingEC2TasksCount
//
// * pendingFargateTasksCount
//
// * activeEC2ServiceCount
//
// * activeFargateServiceCount
//
// * drainingEC2ServiceCount
//
// * drainingFargateServiceCount
Include [ ] * string ` locationName:"include" type:"list" `
2017-02-07 22:33:23 +01:00
}
// String returns the string representation
func ( s DescribeClustersInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeClustersInput ) GoString ( ) string {
return s . String ( )
}
// SetClusters sets the Clusters field's value.
func ( s * DescribeClustersInput ) SetClusters ( v [ ] * string ) * DescribeClustersInput {
s . Clusters = v
return s
}
2018-02-22 14:58:04 +01:00
// SetInclude sets the Include field's value.
func ( s * DescribeClustersInput ) SetInclude ( v [ ] * string ) * DescribeClustersInput {
s . Include = v
return s
}
2017-02-07 22:33:23 +01:00
type DescribeClustersOutput struct {
_ struct { } ` type:"structure" `
// The list of clusters.
Clusters [ ] * Cluster ` locationName:"clusters" type:"list" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
}
// String returns the string representation
func ( s DescribeClustersOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeClustersOutput ) GoString ( ) string {
return s . String ( )
}
// SetClusters sets the Clusters field's value.
func ( s * DescribeClustersOutput ) SetClusters ( v [ ] * Cluster ) * DescribeClustersOutput {
s . Clusters = v
return s
}
// SetFailures sets the Failures field's value.
func ( s * DescribeClustersOutput ) SetFailures ( v [ ] * Failure ) * DescribeClustersOutput {
s . Failures = v
return s
}
type DescribeContainerInstancesInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the container instances to describe. If you do not specify a cluster, the
// default cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-05-28 18:52:03 +02:00
// A list of up to 100 container instance IDs or full Amazon Resource Name (ARN)
// entries.
2017-02-07 22:33:23 +01:00
//
// ContainerInstances is a required field
ContainerInstances [ ] * string ` locationName:"containerInstances" type:"list" required:"true" `
}
// String returns the string representation
func ( s DescribeContainerInstancesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeContainerInstancesInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DescribeContainerInstancesInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DescribeContainerInstancesInput" }
if s . ContainerInstances == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerInstances" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DescribeContainerInstancesInput ) SetCluster ( v string ) * DescribeContainerInstancesInput {
s . Cluster = & v
return s
}
// SetContainerInstances sets the ContainerInstances field's value.
func ( s * DescribeContainerInstancesInput ) SetContainerInstances ( v [ ] * string ) * DescribeContainerInstancesInput {
s . ContainerInstances = v
return s
}
type DescribeContainerInstancesOutput struct {
_ struct { } ` type:"structure" `
// The list of container instances.
ContainerInstances [ ] * ContainerInstance ` locationName:"containerInstances" type:"list" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
}
// String returns the string representation
func ( s DescribeContainerInstancesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeContainerInstancesOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstances sets the ContainerInstances field's value.
func ( s * DescribeContainerInstancesOutput ) SetContainerInstances ( v [ ] * ContainerInstance ) * DescribeContainerInstancesOutput {
s . ContainerInstances = v
return s
}
// SetFailures sets the Failures field's value.
func ( s * DescribeContainerInstancesOutput ) SetFailures ( v [ ] * Failure ) * DescribeContainerInstancesOutput {
s . Failures = v
return s
}
type DescribeServicesInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The short name or full Amazon Resource Name (ARN)the cluster that hosts the
// service to describe. If you do not specify a cluster, the default cluster
// is assumed.
2017-02-07 22:33:23 +01:00
Cluster * string ` locationName:"cluster" type:"string" `
// A list of services to describe. You may specify up to 10 services to describe
// in a single operation.
//
// Services is a required field
Services [ ] * string ` locationName:"services" type:"list" required:"true" `
}
// String returns the string representation
func ( s DescribeServicesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeServicesInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DescribeServicesInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DescribeServicesInput" }
if s . Services == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Services" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DescribeServicesInput ) SetCluster ( v string ) * DescribeServicesInput {
s . Cluster = & v
return s
}
// SetServices sets the Services field's value.
func ( s * DescribeServicesInput ) SetServices ( v [ ] * string ) * DescribeServicesInput {
s . Services = v
return s
}
type DescribeServicesOutput struct {
_ struct { } ` type:"structure" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
// The list of services described.
Services [ ] * Service ` locationName:"services" type:"list" `
}
// String returns the string representation
func ( s DescribeServicesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeServicesOutput ) GoString ( ) string {
return s . String ( )
}
// SetFailures sets the Failures field's value.
func ( s * DescribeServicesOutput ) SetFailures ( v [ ] * Failure ) * DescribeServicesOutput {
s . Failures = v
return s
}
// SetServices sets the Services field's value.
func ( s * DescribeServicesOutput ) SetServices ( v [ ] * Service ) * DescribeServicesOutput {
s . Services = v
return s
}
type DescribeTaskDefinitionInput struct {
_ struct { } ` type:"structure" `
// The family for the latest ACTIVE revision, family and revision (family:revision)
// for a specific revision in the family, or full Amazon Resource Name (ARN)
// of the task definition to describe.
//
// TaskDefinition is a required field
TaskDefinition * string ` locationName:"taskDefinition" type:"string" required:"true" `
}
// String returns the string representation
func ( s DescribeTaskDefinitionInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeTaskDefinitionInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DescribeTaskDefinitionInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DescribeTaskDefinitionInput" }
if s . TaskDefinition == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TaskDefinition" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * DescribeTaskDefinitionInput ) SetTaskDefinition ( v string ) * DescribeTaskDefinitionInput {
s . TaskDefinition = & v
return s
}
type DescribeTaskDefinitionOutput struct {
_ struct { } ` type:"structure" `
// The full task definition description.
TaskDefinition * TaskDefinition ` locationName:"taskDefinition" type:"structure" `
}
// String returns the string representation
func ( s DescribeTaskDefinitionOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeTaskDefinitionOutput ) GoString ( ) string {
return s . String ( )
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * DescribeTaskDefinitionOutput ) SetTaskDefinition ( v * TaskDefinition ) * DescribeTaskDefinitionOutput {
s . TaskDefinition = v
return s
}
type DescribeTasksInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the task to describe. If you do not specify a cluster, the default cluster
// is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// A list of up to 100 task IDs or full ARN entries.
2017-02-07 22:33:23 +01:00
//
// Tasks is a required field
Tasks [ ] * string ` locationName:"tasks" type:"list" required:"true" `
}
// String returns the string representation
func ( s DescribeTasksInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeTasksInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * DescribeTasksInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "DescribeTasksInput" }
if s . Tasks == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Tasks" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * DescribeTasksInput ) SetCluster ( v string ) * DescribeTasksInput {
s . Cluster = & v
return s
}
// SetTasks sets the Tasks field's value.
func ( s * DescribeTasksInput ) SetTasks ( v [ ] * string ) * DescribeTasksInput {
s . Tasks = v
return s
}
type DescribeTasksOutput struct {
_ struct { } ` type:"structure" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
// The list of tasks.
Tasks [ ] * Task ` locationName:"tasks" type:"list" `
}
// String returns the string representation
func ( s DescribeTasksOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DescribeTasksOutput ) GoString ( ) string {
return s . String ( )
}
// SetFailures sets the Failures field's value.
func ( s * DescribeTasksOutput ) SetFailures ( v [ ] * Failure ) * DescribeTasksOutput {
s . Failures = v
return s
}
// SetTasks sets the Tasks field's value.
func ( s * DescribeTasksOutput ) SetTasks ( v [ ] * Task ) * DescribeTasksOutput {
s . Tasks = v
return s
}
2018-02-22 14:58:04 +01:00
// An object representing a container instance host device.
type Device struct {
_ struct { } ` type:"structure" `
// The path inside the container at which to expose the host device.
ContainerPath * string ` locationName:"containerPath" type:"string" `
// The path for the device on the host container instance.
//
// HostPath is a required field
HostPath * string ` locationName:"hostPath" type:"string" required:"true" `
// The explicit permissions to provide to the container for the device. By default,
// the container has permissions for read, write, and mknod for the device.
Permissions [ ] * string ` locationName:"permissions" type:"list" `
}
// String returns the string representation
func ( s Device ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Device ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * Device ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "Device" }
if s . HostPath == nil {
invalidParams . Add ( request . NewErrParamRequired ( "HostPath" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetContainerPath sets the ContainerPath field's value.
func ( s * Device ) SetContainerPath ( v string ) * Device {
s . ContainerPath = & v
return s
}
// SetHostPath sets the HostPath field's value.
func ( s * Device ) SetHostPath ( v string ) * Device {
s . HostPath = & v
return s
}
// SetPermissions sets the Permissions field's value.
func ( s * Device ) SetPermissions ( v [ ] * string ) * Device {
s . Permissions = v
return s
}
2017-02-07 22:33:23 +01:00
type DiscoverPollEndpointInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The short name or full Amazon Resource Name (ARN) of the cluster that the
// container instance belongs to.
2017-02-07 22:33:23 +01:00
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The container instance ID or full ARN of the container instance. The ARN
// contains the arn:aws:ecs namespace, followed by the region of the container
// instance, the AWS account ID of the container instance owner, the container-instance
// namespace, and then the container instance ID. For example, arn:aws:ecs:region:aws_account_id:container-instance/container_instance_ID.
2017-02-07 22:33:23 +01:00
ContainerInstance * string ` locationName:"containerInstance" type:"string" `
}
// String returns the string representation
func ( s DiscoverPollEndpointInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DiscoverPollEndpointInput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * DiscoverPollEndpointInput ) SetCluster ( v string ) * DiscoverPollEndpointInput {
s . Cluster = & v
return s
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * DiscoverPollEndpointInput ) SetContainerInstance ( v string ) * DiscoverPollEndpointInput {
s . ContainerInstance = & v
return s
}
type DiscoverPollEndpointOutput struct {
_ struct { } ` type:"structure" `
// The endpoint for the Amazon ECS agent to poll.
Endpoint * string ` locationName:"endpoint" type:"string" `
// The telemetry endpoint for the Amazon ECS agent.
TelemetryEndpoint * string ` locationName:"telemetryEndpoint" type:"string" `
}
// String returns the string representation
func ( s DiscoverPollEndpointOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s DiscoverPollEndpointOutput ) GoString ( ) string {
return s . String ( )
}
// SetEndpoint sets the Endpoint field's value.
func ( s * DiscoverPollEndpointOutput ) SetEndpoint ( v string ) * DiscoverPollEndpointOutput {
s . Endpoint = & v
return s
}
// SetTelemetryEndpoint sets the TelemetryEndpoint field's value.
func ( s * DiscoverPollEndpointOutput ) SetTelemetryEndpoint ( v string ) * DiscoverPollEndpointOutput {
s . TelemetryEndpoint = & v
return s
}
// A failed resource.
type Failure struct {
_ struct { } ` type:"structure" `
// The Amazon Resource Name (ARN) of the failed resource.
Arn * string ` locationName:"arn" type:"string" `
// The reason for the failure.
Reason * string ` locationName:"reason" type:"string" `
}
// String returns the string representation
func ( s Failure ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Failure ) GoString ( ) string {
return s . String ( )
}
// SetArn sets the Arn field's value.
func ( s * Failure ) SetArn ( v string ) * Failure {
s . Arn = & v
return s
}
// SetReason sets the Reason field's value.
func ( s * Failure ) SetReason ( v string ) * Failure {
s . Reason = & v
return s
}
2018-05-28 18:52:03 +02:00
// An object representing a container health check. Health check parameters
// that are specified in a container definition override any Docker health checks
// that exist in the container image (such as those specified in a parent image
// or from the image's Dockerfile).
type HealthCheck struct {
_ struct { } ` type:"structure" `
// A string array representing the command that the container runs to determine
// if it is healthy. The string array must start with CMD to execute the command
// arguments directly, or CMD-SHELL to run the command with the container's
// default shell. For example:
//
// [ "CMD-SHELL", "curl -f http://localhost/ || exit 1" ]
//
// An exit code of 0 indicates success, and non-zero exit code indicates failure.
// For more information, see HealthCheck in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/).
//
// Command is a required field
Command [ ] * string ` locationName:"command" type:"list" required:"true" `
// The time period in seconds between each health check execution. You may specify
// between 5 and 300 seconds. The default value is 30 seconds.
Interval * int64 ` locationName:"interval" type:"integer" `
// The number of times to retry a failed health check before the container is
// considered unhealthy. You may specify between 1 and 10 retries. The default
// value is 3 retries.
Retries * int64 ` locationName:"retries" type:"integer" `
// The optional grace period within which to provide containers time to bootstrap
// before failed health checks count towards the maximum number of retries.
// You may specify between 0 and 300 seconds. The startPeriod is disabled by
// default.
//
// If a health check succeeds within the startPeriod, then the container is
// considered healthy and any subsequent failures count toward the maximum number
// of retries.
StartPeriod * int64 ` locationName:"startPeriod" type:"integer" `
// The time period in seconds to wait for a health check to succeed before it
// is considered a failure. You may specify between 2 and 60 seconds. The default
// value is 5 seconds.
Timeout * int64 ` locationName:"timeout" type:"integer" `
}
// String returns the string representation
func ( s HealthCheck ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s HealthCheck ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * HealthCheck ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "HealthCheck" }
if s . Command == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Command" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCommand sets the Command field's value.
func ( s * HealthCheck ) SetCommand ( v [ ] * string ) * HealthCheck {
s . Command = v
return s
}
// SetInterval sets the Interval field's value.
func ( s * HealthCheck ) SetInterval ( v int64 ) * HealthCheck {
s . Interval = & v
return s
}
// SetRetries sets the Retries field's value.
func ( s * HealthCheck ) SetRetries ( v int64 ) * HealthCheck {
s . Retries = & v
return s
}
// SetStartPeriod sets the StartPeriod field's value.
func ( s * HealthCheck ) SetStartPeriod ( v int64 ) * HealthCheck {
s . StartPeriod = & v
return s
}
// SetTimeout sets the Timeout field's value.
func ( s * HealthCheck ) SetTimeout ( v int64 ) * HealthCheck {
s . Timeout = & v
return s
}
2017-02-07 22:33:23 +01:00
// Hostnames and IP address entries that are added to the /etc/hosts file of
// a container via the extraHosts parameter of its ContainerDefinition.
type HostEntry struct {
_ struct { } ` type:"structure" `
// The hostname to use in the /etc/hosts entry.
//
// Hostname is a required field
Hostname * string ` locationName:"hostname" type:"string" required:"true" `
// The IP address to use in the /etc/hosts entry.
//
// IpAddress is a required field
IpAddress * string ` locationName:"ipAddress" type:"string" required:"true" `
}
// String returns the string representation
func ( s HostEntry ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s HostEntry ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * HostEntry ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "HostEntry" }
if s . Hostname == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Hostname" ) )
}
if s . IpAddress == nil {
invalidParams . Add ( request . NewErrParamRequired ( "IpAddress" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetHostname sets the Hostname field's value.
func ( s * HostEntry ) SetHostname ( v string ) * HostEntry {
s . Hostname = & v
return s
}
// SetIpAddress sets the IpAddress field's value.
func ( s * HostEntry ) SetIpAddress ( v string ) * HostEntry {
s . IpAddress = & v
return s
}
// Details on a container instance host volume.
type HostVolumeProperties struct {
_ struct { } ` type:"structure" `
// The path on the host container instance that is presented to the container.
// If this parameter is empty, then the Docker daemon has assigned a host path
// for you. If the host parameter contains a sourcePath file location, then
// the data volume persists at the specified location on the host container
// instance until you delete it manually. If the sourcePath value does not exist
// on the host container instance, the Docker daemon creates it. If the location
// does exist, the contents of the source path folder are exported.
2018-02-22 14:58:04 +01:00
//
// If you are using the Fargate launch type, the sourcePath parameter is not
// supported.
2017-02-07 22:33:23 +01:00
SourcePath * string ` locationName:"sourcePath" type:"string" `
}
// String returns the string representation
func ( s HostVolumeProperties ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s HostVolumeProperties ) GoString ( ) string {
return s . String ( )
}
// SetSourcePath sets the SourcePath field's value.
func ( s * HostVolumeProperties ) SetSourcePath ( v string ) * HostVolumeProperties {
s . SourcePath = & v
return s
}
2018-02-22 14:58:04 +01:00
// The Linux capabilities for the container that are added to or dropped from
// the default configuration provided by Docker. For more information on the
// default capabilities and the non-default available capabilities, see Runtime
// privilege and Linux capabilities (https://docs.docker.com/engine/reference/run/#runtime-privilege-and-linux-capabilities)
// in the Docker run reference. For more detailed information on these Linux
// capabilities, see the capabilities(7) (http://man7.org/linux/man-pages/man7/capabilities.7.html)
// Linux manual page.
type KernelCapabilities struct {
_ struct { } ` type:"structure" `
// The Linux capabilities for the container that have been added to the default
// configuration provided by Docker. This parameter maps to CapAdd in the Create
// a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
// and the --cap-add option to docker run (https://docs.docker.com/engine/reference/run/).
//
2018-05-28 18:52:03 +02:00
// If you are using tasks that use the Fargate launch type, the add parameter
// is not supported.
//
2018-02-22 14:58:04 +01:00
// Valid values: "ALL" | "AUDIT_CONTROL" | "AUDIT_WRITE" | "BLOCK_SUSPEND" |
// "CHOWN" | "DAC_OVERRIDE" | "DAC_READ_SEARCH" | "FOWNER" | "FSETID" | "IPC_LOCK"
// | "IPC_OWNER" | "KILL" | "LEASE" | "LINUX_IMMUTABLE" | "MAC_ADMIN" | "MAC_OVERRIDE"
// | "MKNOD" | "NET_ADMIN" | "NET_BIND_SERVICE" | "NET_BROADCAST" | "NET_RAW"
// | "SETFCAP" | "SETGID" | "SETPCAP" | "SETUID" | "SYS_ADMIN" | "SYS_BOOT"
// | "SYS_CHROOT" | "SYS_MODULE" | "SYS_NICE" | "SYS_PACCT" | "SYS_PTRACE" |
// "SYS_RAWIO" | "SYS_RESOURCE" | "SYS_TIME" | "SYS_TTY_CONFIG" | "SYSLOG" |
// "WAKE_ALARM"
Add [ ] * string ` locationName:"add" type:"list" `
// The Linux capabilities for the container that have been removed from the
// default configuration provided by Docker. This parameter maps to CapDrop
// in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
// and the --cap-drop option to docker run (https://docs.docker.com/engine/reference/run/).
//
// Valid values: "ALL" | "AUDIT_CONTROL" | "AUDIT_WRITE" | "BLOCK_SUSPEND" |
// "CHOWN" | "DAC_OVERRIDE" | "DAC_READ_SEARCH" | "FOWNER" | "FSETID" | "IPC_LOCK"
// | "IPC_OWNER" | "KILL" | "LEASE" | "LINUX_IMMUTABLE" | "MAC_ADMIN" | "MAC_OVERRIDE"
// | "MKNOD" | "NET_ADMIN" | "NET_BIND_SERVICE" | "NET_BROADCAST" | "NET_RAW"
// | "SETFCAP" | "SETGID" | "SETPCAP" | "SETUID" | "SYS_ADMIN" | "SYS_BOOT"
// | "SYS_CHROOT" | "SYS_MODULE" | "SYS_NICE" | "SYS_PACCT" | "SYS_PTRACE" |
// "SYS_RAWIO" | "SYS_RESOURCE" | "SYS_TIME" | "SYS_TTY_CONFIG" | "SYSLOG" |
// "WAKE_ALARM"
Drop [ ] * string ` locationName:"drop" type:"list" `
}
// String returns the string representation
func ( s KernelCapabilities ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s KernelCapabilities ) GoString ( ) string {
return s . String ( )
}
// SetAdd sets the Add field's value.
func ( s * KernelCapabilities ) SetAdd ( v [ ] * string ) * KernelCapabilities {
s . Add = v
return s
}
// SetDrop sets the Drop field's value.
func ( s * KernelCapabilities ) SetDrop ( v [ ] * string ) * KernelCapabilities {
s . Drop = v
return s
}
2017-02-07 22:33:23 +01:00
// A key and value pair object.
type KeyValuePair struct {
_ struct { } ` type:"structure" `
// The name of the key value pair. For environment variables, this is the name
// of the environment variable.
Name * string ` locationName:"name" type:"string" `
// The value of the key value pair. For environment variables, this is the value
// of the environment variable.
Value * string ` locationName:"value" type:"string" `
}
// String returns the string representation
func ( s KeyValuePair ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s KeyValuePair ) GoString ( ) string {
return s . String ( )
}
// SetName sets the Name field's value.
func ( s * KeyValuePair ) SetName ( v string ) * KeyValuePair {
s . Name = & v
return s
}
// SetValue sets the Value field's value.
func ( s * KeyValuePair ) SetValue ( v string ) * KeyValuePair {
s . Value = & v
return s
}
2018-02-22 14:58:04 +01:00
// Linux-specific options that are applied to the container, such as Linux KernelCapabilities.
type LinuxParameters struct {
_ struct { } ` type:"structure" `
// The Linux capabilities for the container that are added to or dropped from
// the default configuration provided by Docker.
2018-05-28 18:52:03 +02:00
//
// If you are using tasks that use the Fargate launch type, capabilities is
// supported but the add parameter is not supported.
2018-02-22 14:58:04 +01:00
Capabilities * KernelCapabilities ` locationName:"capabilities" type:"structure" `
// Any host devices to expose to the container. This parameter maps to Devices
// in the Create a container (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/#create-a-container)
// section of the Docker Remote API (https://docs.docker.com/engine/reference/api/docker_remote_api_v1.27/)
// and the --device option to docker run (https://docs.docker.com/engine/reference/run/).
2018-05-28 18:52:03 +02:00
//
// If you are using tasks that use the Fargate launch type, the devices parameter
// is not supported.
2018-02-22 14:58:04 +01:00
Devices [ ] * Device ` locationName:"devices" type:"list" `
// Run an init process inside the container that forwards signals and reaps
// processes. This parameter maps to the --init option to docker run (https://docs.docker.com/engine/reference/run/).
// This parameter requires version 1.25 of the Docker Remote API or greater
// on your container instance. To check the Docker Remote API version on your
// container instance, log in to your container instance and run the following
// command: sudo docker version | grep "Server API version"
InitProcessEnabled * bool ` locationName:"initProcessEnabled" type:"boolean" `
2018-05-28 18:52:03 +02:00
// The value for the size (in MiB) of the /dev/shm volume. This parameter maps
// to the --shm-size option to docker run (https://docs.docker.com/engine/reference/run/).
//
// If you are using tasks that use the Fargate launch type, the sharedMemorySize
// parameter is not supported.
SharedMemorySize * int64 ` locationName:"sharedMemorySize" type:"integer" `
// The container path, mount options, and size (in MiB) of the tmpfs mount.
// This parameter maps to the --tmpfs option to docker run (https://docs.docker.com/engine/reference/run/).
//
// If you are using tasks that use the Fargate launch type, the tmpfs parameter
// is not supported.
Tmpfs [ ] * Tmpfs ` locationName:"tmpfs" type:"list" `
2018-02-22 14:58:04 +01:00
}
// String returns the string representation
func ( s LinuxParameters ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s LinuxParameters ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * LinuxParameters ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "LinuxParameters" }
if s . Devices != nil {
for i , v := range s . Devices {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Devices" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
2018-05-28 18:52:03 +02:00
if s . Tmpfs != nil {
for i , v := range s . Tmpfs {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Tmpfs" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
2018-02-22 14:58:04 +01:00
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCapabilities sets the Capabilities field's value.
func ( s * LinuxParameters ) SetCapabilities ( v * KernelCapabilities ) * LinuxParameters {
s . Capabilities = v
return s
}
// SetDevices sets the Devices field's value.
func ( s * LinuxParameters ) SetDevices ( v [ ] * Device ) * LinuxParameters {
s . Devices = v
return s
}
// SetInitProcessEnabled sets the InitProcessEnabled field's value.
func ( s * LinuxParameters ) SetInitProcessEnabled ( v bool ) * LinuxParameters {
s . InitProcessEnabled = & v
return s
}
2018-05-28 18:52:03 +02:00
// SetSharedMemorySize sets the SharedMemorySize field's value.
func ( s * LinuxParameters ) SetSharedMemorySize ( v int64 ) * LinuxParameters {
s . SharedMemorySize = & v
return s
}
// SetTmpfs sets the Tmpfs field's value.
func ( s * LinuxParameters ) SetTmpfs ( v [ ] * Tmpfs ) * LinuxParameters {
s . Tmpfs = v
return s
}
2017-02-07 22:33:23 +01:00
type ListAttributesInput struct {
_ struct { } ` type:"structure" `
// The name of the attribute with which to filter the results.
AttributeName * string ` locationName:"attributeName" type:"string" `
// The value of the attribute with which to filter results. You must also specify
// an attribute name to use this parameter.
AttributeValue * string ` locationName:"attributeValue" type:"string" `
// The short name or full Amazon Resource Name (ARN) of the cluster to list
// attributes. If you do not specify a cluster, the default cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// The maximum number of cluster results returned by ListAttributes in paginated
// output. When this parameter is used, ListAttributes only returns maxResults
// results in a single page along with a nextToken response element. The remaining
// results of the initial request can be seen by sending another ListAttributes
// request with the returned nextToken value. This value can be between 1 and
// 100. If this parameter is not used, then ListAttributes returns up to 100
// results and a nextToken value if applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListAttributes request
// where maxResults was used and the results exceeded the value of that parameter.
// Pagination continues from the end of the previous results that returned the
2018-02-22 14:58:04 +01:00
// nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
// The type of the target with which to list attributes.
//
// TargetType is a required field
TargetType * string ` locationName:"targetType" type:"string" required:"true" enum:"TargetType" `
}
// String returns the string representation
func ( s ListAttributesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListAttributesInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * ListAttributesInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "ListAttributesInput" }
if s . TargetType == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TargetType" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttributeName sets the AttributeName field's value.
func ( s * ListAttributesInput ) SetAttributeName ( v string ) * ListAttributesInput {
s . AttributeName = & v
return s
}
// SetAttributeValue sets the AttributeValue field's value.
func ( s * ListAttributesInput ) SetAttributeValue ( v string ) * ListAttributesInput {
s . AttributeValue = & v
return s
}
// SetCluster sets the Cluster field's value.
func ( s * ListAttributesInput ) SetCluster ( v string ) * ListAttributesInput {
s . Cluster = & v
return s
}
// SetMaxResults sets the MaxResults field's value.
func ( s * ListAttributesInput ) SetMaxResults ( v int64 ) * ListAttributesInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListAttributesInput ) SetNextToken ( v string ) * ListAttributesInput {
s . NextToken = & v
return s
}
// SetTargetType sets the TargetType field's value.
func ( s * ListAttributesInput ) SetTargetType ( v string ) * ListAttributesInput {
s . TargetType = & v
return s
}
type ListAttributesOutput struct {
_ struct { } ` type:"structure" `
// A list of attribute objects that meet the criteria of the request.
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" `
// The nextToken value to include in a future ListAttributes request. When the
// results of a ListAttributes request exceed maxResults, this value can be
// used to retrieve the next page of results. This value is null when there
// are no more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListAttributesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListAttributesOutput ) GoString ( ) string {
return s . String ( )
}
// SetAttributes sets the Attributes field's value.
func ( s * ListAttributesOutput ) SetAttributes ( v [ ] * Attribute ) * ListAttributesOutput {
s . Attributes = v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListAttributesOutput ) SetNextToken ( v string ) * ListAttributesOutput {
s . NextToken = & v
return s
}
type ListClustersInput struct {
_ struct { } ` type:"structure" `
// The maximum number of cluster results returned by ListClusters in paginated
// output. When this parameter is used, ListClusters only returns maxResults
// results in a single page along with a nextToken response element. The remaining
// results of the initial request can be seen by sending another ListClusters
// request with the returned nextToken value. This value can be between 1 and
// 100. If this parameter is not used, then ListClusters returns up to 100 results
// and a nextToken value if applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListClusters request
// where maxResults was used and the results exceeded the value of that parameter.
// Pagination continues from the end of the previous results that returned the
2018-02-22 14:58:04 +01:00
// nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListClustersInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListClustersInput ) GoString ( ) string {
return s . String ( )
}
// SetMaxResults sets the MaxResults field's value.
func ( s * ListClustersInput ) SetMaxResults ( v int64 ) * ListClustersInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListClustersInput ) SetNextToken ( v string ) * ListClustersInput {
s . NextToken = & v
return s
}
type ListClustersOutput struct {
_ struct { } ` type:"structure" `
// The list of full Amazon Resource Name (ARN) entries for each cluster associated
// with your account.
ClusterArns [ ] * string ` locationName:"clusterArns" type:"list" `
// The nextToken value to include in a future ListClusters request. When the
// results of a ListClusters request exceed maxResults, this value can be used
// to retrieve the next page of results. This value is null when there are no
// more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListClustersOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListClustersOutput ) GoString ( ) string {
return s . String ( )
}
// SetClusterArns sets the ClusterArns field's value.
func ( s * ListClustersOutput ) SetClusterArns ( v [ ] * string ) * ListClustersOutput {
s . ClusterArns = v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListClustersOutput ) SetNextToken ( v string ) * ListClustersOutput {
s . NextToken = & v
return s
}
type ListContainerInstancesInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the container instances to list. If you do not specify a cluster, the default
// cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// You can filter the results of a ListContainerInstances operation with cluster
// query language statements. For more information, see Cluster Query Language
// (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/cluster-query-language.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Filter * string ` locationName:"filter" type:"string" `
// The maximum number of container instance results returned by ListContainerInstances
// in paginated output. When this parameter is used, ListContainerInstances
// only returns maxResults results in a single page along with a nextToken response
// element. The remaining results of the initial request can be seen by sending
// another ListContainerInstances request with the returned nextToken value.
// This value can be between 1 and 100. If this parameter is not used, then
// ListContainerInstances returns up to 100 results and a nextToken value if
// applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListContainerInstances
// request where maxResults was used and the results exceeded the value of that
// parameter. Pagination continues from the end of the previous results that
2018-02-22 14:58:04 +01:00
// returned the nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
2018-02-22 14:58:04 +01:00
// Filters the container instances by status. For example, if you specify the
// DRAINING status, the results include only container instances that have been
// set to DRAINING using UpdateContainerInstancesState. If you do not specify
// this parameter, the default is to include container instances set to ACTIVE
// and DRAINING.
2017-02-07 22:33:23 +01:00
Status * string ` locationName:"status" type:"string" enum:"ContainerInstanceStatus" `
}
// String returns the string representation
func ( s ListContainerInstancesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListContainerInstancesInput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * ListContainerInstancesInput ) SetCluster ( v string ) * ListContainerInstancesInput {
s . Cluster = & v
return s
}
// SetFilter sets the Filter field's value.
func ( s * ListContainerInstancesInput ) SetFilter ( v string ) * ListContainerInstancesInput {
s . Filter = & v
return s
}
// SetMaxResults sets the MaxResults field's value.
func ( s * ListContainerInstancesInput ) SetMaxResults ( v int64 ) * ListContainerInstancesInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListContainerInstancesInput ) SetNextToken ( v string ) * ListContainerInstancesInput {
s . NextToken = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * ListContainerInstancesInput ) SetStatus ( v string ) * ListContainerInstancesInput {
s . Status = & v
return s
}
type ListContainerInstancesOutput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The list of container instances with full ARN entries for each container
// instance associated with the specified cluster.
2017-02-07 22:33:23 +01:00
ContainerInstanceArns [ ] * string ` locationName:"containerInstanceArns" type:"list" `
// The nextToken value to include in a future ListContainerInstances request.
// When the results of a ListContainerInstances request exceed maxResults, this
// value can be used to retrieve the next page of results. This value is null
// when there are no more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListContainerInstancesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListContainerInstancesOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstanceArns sets the ContainerInstanceArns field's value.
func ( s * ListContainerInstancesOutput ) SetContainerInstanceArns ( v [ ] * string ) * ListContainerInstancesOutput {
s . ContainerInstanceArns = v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListContainerInstancesOutput ) SetNextToken ( v string ) * ListContainerInstancesOutput {
s . NextToken = & v
return s
}
type ListServicesInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the services to list. If you do not specify a cluster, the default cluster
// is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The launch type for services you want to list.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
// The maximum number of service results returned by ListServices in paginated
// output. When this parameter is used, ListServices only returns maxResults
// results in a single page along with a nextToken response element. The remaining
// results of the initial request can be seen by sending another ListServices
// request with the returned nextToken value. This value can be between 1 and
// 10. If this parameter is not used, then ListServices returns up to 10 results
// and a nextToken value if applicable.
2017-02-07 22:33:23 +01:00
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListServices request
// where maxResults was used and the results exceeded the value of that parameter.
// Pagination continues from the end of the previous results that returned the
2018-02-22 14:58:04 +01:00
// nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListServicesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListServicesInput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * ListServicesInput ) SetCluster ( v string ) * ListServicesInput {
s . Cluster = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetLaunchType sets the LaunchType field's value.
func ( s * ListServicesInput ) SetLaunchType ( v string ) * ListServicesInput {
s . LaunchType = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetMaxResults sets the MaxResults field's value.
func ( s * ListServicesInput ) SetMaxResults ( v int64 ) * ListServicesInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListServicesInput ) SetNextToken ( v string ) * ListServicesInput {
s . NextToken = & v
return s
}
type ListServicesOutput struct {
_ struct { } ` type:"structure" `
// The nextToken value to include in a future ListServices request. When the
// results of a ListServices request exceed maxResults, this value can be used
// to retrieve the next page of results. This value is null when there are no
// more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
2018-02-22 14:58:04 +01:00
// The list of full ARN entries for each service associated with the specified
// cluster.
2017-02-07 22:33:23 +01:00
ServiceArns [ ] * string ` locationName:"serviceArns" type:"list" `
}
// String returns the string representation
func ( s ListServicesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListServicesOutput ) GoString ( ) string {
return s . String ( )
}
// SetNextToken sets the NextToken field's value.
func ( s * ListServicesOutput ) SetNextToken ( v string ) * ListServicesOutput {
s . NextToken = & v
return s
}
// SetServiceArns sets the ServiceArns field's value.
func ( s * ListServicesOutput ) SetServiceArns ( v [ ] * string ) * ListServicesOutput {
s . ServiceArns = v
return s
}
type ListTaskDefinitionFamiliesInput struct {
_ struct { } ` type:"structure" `
// The familyPrefix is a string that is used to filter the results of ListTaskDefinitionFamilies.
// If you specify a familyPrefix, only task definition family names that begin
// with the familyPrefix string are returned.
FamilyPrefix * string ` locationName:"familyPrefix" type:"string" `
// The maximum number of task definition family results returned by ListTaskDefinitionFamilies
// in paginated output. When this parameter is used, ListTaskDefinitions only
// returns maxResults results in a single page along with a nextToken response
// element. The remaining results of the initial request can be seen by sending
// another ListTaskDefinitionFamilies request with the returned nextToken value.
// This value can be between 1 and 100. If this parameter is not used, then
// ListTaskDefinitionFamilies returns up to 100 results and a nextToken value
// if applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListTaskDefinitionFamilies
// request where maxResults was used and the results exceeded the value of that
// parameter. Pagination continues from the end of the previous results that
2018-02-22 14:58:04 +01:00
// returned the nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
// The task definition family status with which to filter the ListTaskDefinitionFamilies
// results. By default, both ACTIVE and INACTIVE task definition families are
// listed. If this parameter is set to ACTIVE, only task definition families
// that have an ACTIVE task definition revision are returned. If this parameter
// is set to INACTIVE, only task definition families that do not have any ACTIVE
// task definition revisions are returned. If you paginate the resulting output,
// be sure to keep the status value constant in each subsequent request.
Status * string ` locationName:"status" type:"string" enum:"TaskDefinitionFamilyStatus" `
}
// String returns the string representation
func ( s ListTaskDefinitionFamiliesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTaskDefinitionFamiliesInput ) GoString ( ) string {
return s . String ( )
}
// SetFamilyPrefix sets the FamilyPrefix field's value.
func ( s * ListTaskDefinitionFamiliesInput ) SetFamilyPrefix ( v string ) * ListTaskDefinitionFamiliesInput {
s . FamilyPrefix = & v
return s
}
// SetMaxResults sets the MaxResults field's value.
func ( s * ListTaskDefinitionFamiliesInput ) SetMaxResults ( v int64 ) * ListTaskDefinitionFamiliesInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTaskDefinitionFamiliesInput ) SetNextToken ( v string ) * ListTaskDefinitionFamiliesInput {
s . NextToken = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * ListTaskDefinitionFamiliesInput ) SetStatus ( v string ) * ListTaskDefinitionFamiliesInput {
s . Status = & v
return s
}
type ListTaskDefinitionFamiliesOutput struct {
_ struct { } ` type:"structure" `
// The list of task definition family names that match the ListTaskDefinitionFamilies
// request.
Families [ ] * string ` locationName:"families" type:"list" `
// The nextToken value to include in a future ListTaskDefinitionFamilies request.
// When the results of a ListTaskDefinitionFamilies request exceed maxResults,
// this value can be used to retrieve the next page of results. This value is
// null when there are no more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
}
// String returns the string representation
func ( s ListTaskDefinitionFamiliesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTaskDefinitionFamiliesOutput ) GoString ( ) string {
return s . String ( )
}
// SetFamilies sets the Families field's value.
func ( s * ListTaskDefinitionFamiliesOutput ) SetFamilies ( v [ ] * string ) * ListTaskDefinitionFamiliesOutput {
s . Families = v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTaskDefinitionFamiliesOutput ) SetNextToken ( v string ) * ListTaskDefinitionFamiliesOutput {
s . NextToken = & v
return s
}
type ListTaskDefinitionsInput struct {
_ struct { } ` type:"structure" `
// The full family name with which to filter the ListTaskDefinitions results.
// Specifying a familyPrefix limits the listed task definitions to task definition
// revisions that belong to that family.
FamilyPrefix * string ` locationName:"familyPrefix" type:"string" `
// The maximum number of task definition results returned by ListTaskDefinitions
// in paginated output. When this parameter is used, ListTaskDefinitions only
// returns maxResults results in a single page along with a nextToken response
// element. The remaining results of the initial request can be seen by sending
// another ListTaskDefinitions request with the returned nextToken value. This
// value can be between 1 and 100. If this parameter is not used, then ListTaskDefinitions
// returns up to 100 results and a nextToken value if applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListTaskDefinitions
// request where maxResults was used and the results exceeded the value of that
// parameter. Pagination continues from the end of the previous results that
2018-02-22 14:58:04 +01:00
// returned the nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
// The order in which to sort the results. Valid values are ASC and DESC. By
// default (ASC), task definitions are listed lexicographically by family name
// and in ascending numerical order by revision so that the newest task definitions
// in a family are listed last. Setting this parameter to DESC reverses the
// sort order on family name and revision so that the newest task definitions
// in a family are listed first.
Sort * string ` locationName:"sort" type:"string" enum:"SortOrder" `
// The task definition status with which to filter the ListTaskDefinitions results.
// By default, only ACTIVE task definitions are listed. By setting this parameter
// to INACTIVE, you can view task definitions that are INACTIVE as long as an
// active task or service still references them. If you paginate the resulting
// output, be sure to keep the status value constant in each subsequent request.
Status * string ` locationName:"status" type:"string" enum:"TaskDefinitionStatus" `
}
// String returns the string representation
func ( s ListTaskDefinitionsInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTaskDefinitionsInput ) GoString ( ) string {
return s . String ( )
}
// SetFamilyPrefix sets the FamilyPrefix field's value.
func ( s * ListTaskDefinitionsInput ) SetFamilyPrefix ( v string ) * ListTaskDefinitionsInput {
s . FamilyPrefix = & v
return s
}
// SetMaxResults sets the MaxResults field's value.
func ( s * ListTaskDefinitionsInput ) SetMaxResults ( v int64 ) * ListTaskDefinitionsInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTaskDefinitionsInput ) SetNextToken ( v string ) * ListTaskDefinitionsInput {
s . NextToken = & v
return s
}
// SetSort sets the Sort field's value.
func ( s * ListTaskDefinitionsInput ) SetSort ( v string ) * ListTaskDefinitionsInput {
s . Sort = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * ListTaskDefinitionsInput ) SetStatus ( v string ) * ListTaskDefinitionsInput {
s . Status = & v
return s
}
type ListTaskDefinitionsOutput struct {
_ struct { } ` type:"structure" `
// The nextToken value to include in a future ListTaskDefinitions request. When
// the results of a ListTaskDefinitions request exceed maxResults, this value
// can be used to retrieve the next page of results. This value is null when
// there are no more results to return.
NextToken * string ` locationName:"nextToken" type:"string" `
// The list of task definition Amazon Resource Name (ARN) entries for the ListTaskDefinitions
// request.
TaskDefinitionArns [ ] * string ` locationName:"taskDefinitionArns" type:"list" `
}
// String returns the string representation
func ( s ListTaskDefinitionsOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTaskDefinitionsOutput ) GoString ( ) string {
return s . String ( )
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTaskDefinitionsOutput ) SetNextToken ( v string ) * ListTaskDefinitionsOutput {
s . NextToken = & v
return s
}
// SetTaskDefinitionArns sets the TaskDefinitionArns field's value.
func ( s * ListTaskDefinitionsOutput ) SetTaskDefinitionArns ( v [ ] * string ) * ListTaskDefinitionsOutput {
s . TaskDefinitionArns = v
return s
}
type ListTasksInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the tasks to list. If you do not specify a cluster, the default cluster is
// assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The container instance ID or full ARN of the container instance with which
// to filter the ListTasks results. Specifying a containerInstance limits the
// results to tasks that belong to that container instance.
2017-02-07 22:33:23 +01:00
ContainerInstance * string ` locationName:"containerInstance" type:"string" `
// The task desired status with which to filter the ListTasks results. Specifying
2018-02-22 14:58:04 +01:00
// a desiredStatus of STOPPED limits the results to tasks that Amazon ECS has
// set the desired status to STOPPED, which can be useful for debugging tasks
// that are not starting properly or have died or finished. The default status
// filter is RUNNING, which shows tasks that Amazon ECS has set the desired
// status to RUNNING.
2017-02-07 22:33:23 +01:00
//
// Although you can filter results based on a desired status of PENDING, this
2018-02-22 14:58:04 +01:00
// does not return any results because Amazon ECS never sets the desired status
// of a task to that value (only a task's lastStatus may have a value of PENDING).
2017-02-07 22:33:23 +01:00
DesiredStatus * string ` locationName:"desiredStatus" type:"string" enum:"DesiredStatus" `
// The name of the family with which to filter the ListTasks results. Specifying
// a family limits the results to tasks that belong to that family.
Family * string ` locationName:"family" type:"string" `
2018-02-22 14:58:04 +01:00
// The launch type for services you want to list.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
2017-02-07 22:33:23 +01:00
// The maximum number of task results returned by ListTasks in paginated output.
// When this parameter is used, ListTasks only returns maxResults results in
// a single page along with a nextToken response element. The remaining results
// of the initial request can be seen by sending another ListTasks request with
// the returned nextToken value. This value can be between 1 and 100. If this
// parameter is not used, then ListTasks returns up to 100 results and a nextToken
// value if applicable.
MaxResults * int64 ` locationName:"maxResults" type:"integer" `
// The nextToken value returned from a previous paginated ListTasks request
// where maxResults was used and the results exceeded the value of that parameter.
// Pagination continues from the end of the previous results that returned the
2018-02-22 14:58:04 +01:00
// nextToken value.
2017-02-07 22:33:23 +01:00
//
// This token should be treated as an opaque identifier that is only used to
// retrieve the next items in a list and not for other programmatic purposes.
NextToken * string ` locationName:"nextToken" type:"string" `
// The name of the service with which to filter the ListTasks results. Specifying
// a serviceName limits the results to tasks that belong to that service.
ServiceName * string ` locationName:"serviceName" type:"string" `
// The startedBy value with which to filter the task results. Specifying a startedBy
// value limits the results to tasks that were started with that value.
StartedBy * string ` locationName:"startedBy" type:"string" `
}
// String returns the string representation
func ( s ListTasksInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTasksInput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * ListTasksInput ) SetCluster ( v string ) * ListTasksInput {
s . Cluster = & v
return s
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * ListTasksInput ) SetContainerInstance ( v string ) * ListTasksInput {
s . ContainerInstance = & v
return s
}
// SetDesiredStatus sets the DesiredStatus field's value.
func ( s * ListTasksInput ) SetDesiredStatus ( v string ) * ListTasksInput {
s . DesiredStatus = & v
return s
}
// SetFamily sets the Family field's value.
func ( s * ListTasksInput ) SetFamily ( v string ) * ListTasksInput {
s . Family = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetLaunchType sets the LaunchType field's value.
func ( s * ListTasksInput ) SetLaunchType ( v string ) * ListTasksInput {
s . LaunchType = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetMaxResults sets the MaxResults field's value.
func ( s * ListTasksInput ) SetMaxResults ( v int64 ) * ListTasksInput {
s . MaxResults = & v
return s
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTasksInput ) SetNextToken ( v string ) * ListTasksInput {
s . NextToken = & v
return s
}
// SetServiceName sets the ServiceName field's value.
func ( s * ListTasksInput ) SetServiceName ( v string ) * ListTasksInput {
s . ServiceName = & v
return s
}
// SetStartedBy sets the StartedBy field's value.
func ( s * ListTasksInput ) SetStartedBy ( v string ) * ListTasksInput {
s . StartedBy = & v
return s
}
type ListTasksOutput struct {
_ struct { } ` type:"structure" `
// The nextToken value to include in a future ListTasks request. When the results
// of a ListTasks request exceed maxResults, this value can be used to retrieve
// the next page of results. This value is null when there are no more results
// to return.
NextToken * string ` locationName:"nextToken" type:"string" `
2018-02-22 14:58:04 +01:00
// The list of task ARN entries for the ListTasks request.
2017-02-07 22:33:23 +01:00
TaskArns [ ] * string ` locationName:"taskArns" type:"list" `
}
// String returns the string representation
func ( s ListTasksOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ListTasksOutput ) GoString ( ) string {
return s . String ( )
}
// SetNextToken sets the NextToken field's value.
func ( s * ListTasksOutput ) SetNextToken ( v string ) * ListTasksOutput {
s . NextToken = & v
return s
}
// SetTaskArns sets the TaskArns field's value.
func ( s * ListTasksOutput ) SetTaskArns ( v [ ] * string ) * ListTasksOutput {
s . TaskArns = v
return s
}
// Details on a load balancer that is used with a service.
2018-05-28 18:52:03 +02:00
//
// Services with tasks that use the awsvpc network mode (for example, those
// with the Fargate launch type) only support Application Load Balancers and
// Network Load Balancers; Classic Load Balancers are not supported. Also, when
// you create any target groups for these services, you must choose ip as the
// target type, not instance, because tasks that use the awsvpc network mode
// are associated with an elastic network interface, not an Amazon EC2 instance.
2017-02-07 22:33:23 +01:00
type LoadBalancer struct {
_ struct { } ` type:"structure" `
// The name of the container (as it appears in a container definition) to associate
// with the load balancer.
ContainerName * string ` locationName:"containerName" type:"string" `
// The port on the container to associate with the load balancer. This port
// must correspond to a containerPort in the service's task definition. Your
// container instances must allow ingress traffic on the hostPort of the port
// mapping.
ContainerPort * int64 ` locationName:"containerPort" type:"integer" `
2018-02-22 14:58:04 +01:00
// The name of a load balancer.
2017-02-07 22:33:23 +01:00
LoadBalancerName * string ` locationName:"loadBalancerName" type:"string" `
// The full Amazon Resource Name (ARN) of the Elastic Load Balancing target
// group associated with a service.
2018-05-28 18:52:03 +02:00
//
// If your service's task definition uses the awsvpc network mode (which is
// required for the Fargate launch type), you must choose ip as the target type,
// not instance, because tasks that use the awsvpc network mode are associated
// with an elastic network interface, not an Amazon EC2 instance.
2017-02-07 22:33:23 +01:00
TargetGroupArn * string ` locationName:"targetGroupArn" type:"string" `
}
// String returns the string representation
func ( s LoadBalancer ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s LoadBalancer ) GoString ( ) string {
return s . String ( )
}
// SetContainerName sets the ContainerName field's value.
func ( s * LoadBalancer ) SetContainerName ( v string ) * LoadBalancer {
s . ContainerName = & v
return s
}
// SetContainerPort sets the ContainerPort field's value.
func ( s * LoadBalancer ) SetContainerPort ( v int64 ) * LoadBalancer {
s . ContainerPort = & v
return s
}
// SetLoadBalancerName sets the LoadBalancerName field's value.
func ( s * LoadBalancer ) SetLoadBalancerName ( v string ) * LoadBalancer {
s . LoadBalancerName = & v
return s
}
// SetTargetGroupArn sets the TargetGroupArn field's value.
func ( s * LoadBalancer ) SetTargetGroupArn ( v string ) * LoadBalancer {
s . TargetGroupArn = & v
return s
}
// Log configuration options to send to a custom log driver for the container.
type LogConfiguration struct {
_ struct { } ` type:"structure" `
// The log driver to use for the container. The valid values listed for this
// parameter are log drivers that the Amazon ECS container agent can communicate
2018-02-22 14:58:04 +01:00
// with by default. If using the Fargate launch type, the only supported value
// is awslogs. For more information about using the awslogs driver, see Using
// the awslogs Log Driver (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/using_awslogs.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
//
// If you have a custom driver that is not listed above that you would like
// to work with the Amazon ECS container agent, you can fork the Amazon ECS
// container agent project that is available on GitHub (https://github.com/aws/amazon-ecs-agent)
// and customize it to work with that driver. We encourage you to submit pull
// requests for changes that you would like to have included. However, Amazon
2018-02-22 14:58:04 +01:00
// Web Services does not currently support running modified copies of this software.
2017-02-07 22:33:23 +01:00
//
// This parameter requires version 1.18 of the Docker Remote API or greater
// on your container instance. To check the Docker Remote API version on your
2018-02-22 14:58:04 +01:00
// container instance, log in to your container instance and run the following
2017-02-07 22:33:23 +01:00
// command: sudo docker version | grep "Server API version"
//
// LogDriver is a required field
LogDriver * string ` locationName:"logDriver" type:"string" required:"true" enum:"LogDriver" `
// The configuration options to send to the log driver. This parameter requires
// version 1.19 of the Docker Remote API or greater on your container instance.
2018-02-22 14:58:04 +01:00
// To check the Docker Remote API version on your container instance, log in
// to your container instance and run the following command: sudo docker version
2017-02-07 22:33:23 +01:00
// | grep "Server API version"
Options map [ string ] * string ` locationName:"options" type:"map" `
}
// String returns the string representation
func ( s LogConfiguration ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s LogConfiguration ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * LogConfiguration ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "LogConfiguration" }
if s . LogDriver == nil {
invalidParams . Add ( request . NewErrParamRequired ( "LogDriver" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetLogDriver sets the LogDriver field's value.
func ( s * LogConfiguration ) SetLogDriver ( v string ) * LogConfiguration {
s . LogDriver = & v
return s
}
// SetOptions sets the Options field's value.
func ( s * LogConfiguration ) SetOptions ( v map [ string ] * string ) * LogConfiguration {
s . Options = v
return s
}
// Details on a volume mount point that is used in a container definition.
type MountPoint struct {
_ struct { } ` type:"structure" `
// The path on the container to mount the host volume at.
ContainerPath * string ` locationName:"containerPath" type:"string" `
// If this value is true, the container has read-only access to the volume.
// If this value is false, then the container can write to the volume. The default
// value is false.
ReadOnly * bool ` locationName:"readOnly" type:"boolean" `
// The name of the volume to mount.
SourceVolume * string ` locationName:"sourceVolume" type:"string" `
}
// String returns the string representation
func ( s MountPoint ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s MountPoint ) GoString ( ) string {
return s . String ( )
}
// SetContainerPath sets the ContainerPath field's value.
func ( s * MountPoint ) SetContainerPath ( v string ) * MountPoint {
s . ContainerPath = & v
return s
}
// SetReadOnly sets the ReadOnly field's value.
func ( s * MountPoint ) SetReadOnly ( v bool ) * MountPoint {
s . ReadOnly = & v
return s
}
// SetSourceVolume sets the SourceVolume field's value.
func ( s * MountPoint ) SetSourceVolume ( v string ) * MountPoint {
s . SourceVolume = & v
return s
}
// Details on the network bindings between a container and its host container
// instance. After a task reaches the RUNNING status, manual and automatic host
// and container port assignments are visible in the networkBindings section
// of DescribeTasks API responses.
type NetworkBinding struct {
_ struct { } ` type:"structure" `
// The IP address that the container is bound to on the container instance.
BindIP * string ` locationName:"bindIP" type:"string" `
2018-02-22 14:58:04 +01:00
// The port number on the container that is used with the network binding.
2017-02-07 22:33:23 +01:00
ContainerPort * int64 ` locationName:"containerPort" type:"integer" `
// The port number on the host that is used with the network binding.
HostPort * int64 ` locationName:"hostPort" type:"integer" `
// The protocol used for the network binding.
Protocol * string ` locationName:"protocol" type:"string" enum:"TransportProtocol" `
}
// String returns the string representation
func ( s NetworkBinding ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s NetworkBinding ) GoString ( ) string {
return s . String ( )
}
// SetBindIP sets the BindIP field's value.
func ( s * NetworkBinding ) SetBindIP ( v string ) * NetworkBinding {
s . BindIP = & v
return s
}
// SetContainerPort sets the ContainerPort field's value.
func ( s * NetworkBinding ) SetContainerPort ( v int64 ) * NetworkBinding {
s . ContainerPort = & v
return s
}
// SetHostPort sets the HostPort field's value.
func ( s * NetworkBinding ) SetHostPort ( v int64 ) * NetworkBinding {
s . HostPort = & v
return s
}
// SetProtocol sets the Protocol field's value.
func ( s * NetworkBinding ) SetProtocol ( v string ) * NetworkBinding {
s . Protocol = & v
return s
}
2018-02-22 14:58:04 +01:00
// An object representing the network configuration for a task or service.
type NetworkConfiguration struct {
_ struct { } ` type:"structure" `
// The VPC subnets and security groups associated with a task.
AwsvpcConfiguration * AwsVpcConfiguration ` locationName:"awsvpcConfiguration" type:"structure" `
}
// String returns the string representation
func ( s NetworkConfiguration ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s NetworkConfiguration ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * NetworkConfiguration ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "NetworkConfiguration" }
if s . AwsvpcConfiguration != nil {
if err := s . AwsvpcConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "AwsvpcConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAwsvpcConfiguration sets the AwsvpcConfiguration field's value.
func ( s * NetworkConfiguration ) SetAwsvpcConfiguration ( v * AwsVpcConfiguration ) * NetworkConfiguration {
s . AwsvpcConfiguration = v
return s
}
// An object representing the Elastic Network Interface for tasks that use the
// awsvpc network mode.
type NetworkInterface struct {
_ struct { } ` type:"structure" `
// The attachment ID for the network interface.
AttachmentId * string ` locationName:"attachmentId" type:"string" `
// The private IPv6 address for the network interface.
Ipv6Address * string ` locationName:"ipv6Address" type:"string" `
// The private IPv4 address for the network interface.
PrivateIpv4Address * string ` locationName:"privateIpv4Address" type:"string" `
}
// String returns the string representation
func ( s NetworkInterface ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s NetworkInterface ) GoString ( ) string {
return s . String ( )
}
// SetAttachmentId sets the AttachmentId field's value.
func ( s * NetworkInterface ) SetAttachmentId ( v string ) * NetworkInterface {
s . AttachmentId = & v
return s
}
// SetIpv6Address sets the Ipv6Address field's value.
func ( s * NetworkInterface ) SetIpv6Address ( v string ) * NetworkInterface {
s . Ipv6Address = & v
return s
}
// SetPrivateIpv4Address sets the PrivateIpv4Address field's value.
func ( s * NetworkInterface ) SetPrivateIpv4Address ( v string ) * NetworkInterface {
s . PrivateIpv4Address = & v
return s
}
2017-02-07 22:33:23 +01:00
// An object representing a constraint on task placement. For more information,
// see Task Placement Constraints (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
type PlacementConstraint struct {
_ struct { } ` type:"structure" `
// A cluster query language expression to apply to the constraint. Note you
// cannot specify an expression if the constraint type is distinctInstance.
// For more information, see Cluster Query Language (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/cluster-query-language.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Expression * string ` locationName:"expression" type:"string" `
// The type of constraint. Use distinctInstance to ensure that each task in
// a particular group is running on a different container instance. Use memberOf
2018-02-22 14:58:04 +01:00
// to restrict the selection to a group of valid candidates. The value distinctInstance
2017-02-07 22:33:23 +01:00
// is not supported in task definitions.
Type * string ` locationName:"type" type:"string" enum:"PlacementConstraintType" `
}
// String returns the string representation
func ( s PlacementConstraint ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s PlacementConstraint ) GoString ( ) string {
return s . String ( )
}
// SetExpression sets the Expression field's value.
func ( s * PlacementConstraint ) SetExpression ( v string ) * PlacementConstraint {
s . Expression = & v
return s
}
// SetType sets the Type field's value.
func ( s * PlacementConstraint ) SetType ( v string ) * PlacementConstraint {
s . Type = & v
return s
}
// The task placement strategy for a task or service. For more information,
// see Task Placement Strategies (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-strategies.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
type PlacementStrategy struct {
_ struct { } ` type:"structure" `
// The field to apply the placement strategy against. For the spread placement
// strategy, valid values are instanceId (or host, which has the same effect),
// or any platform or custom attribute that is applied to a container instance,
// such as attribute:ecs.availability-zone. For the binpack placement strategy,
// valid values are cpu and memory. For the random placement strategy, this
// field is not used.
Field * string ` locationName:"field" type:"string" `
// The type of placement strategy. The random placement strategy randomly places
// tasks on available candidates. The spread placement strategy spreads placement
// across available candidates evenly based on the field parameter. The binpack
// strategy places tasks on available candidates that have the least available
// amount of the resource that is specified with the field parameter. For example,
// if you binpack on memory, a task is placed on the instance with the least
// amount of remaining memory (but still enough to run the task).
Type * string ` locationName:"type" type:"string" enum:"PlacementStrategyType" `
}
// String returns the string representation
func ( s PlacementStrategy ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s PlacementStrategy ) GoString ( ) string {
return s . String ( )
}
// SetField sets the Field field's value.
func ( s * PlacementStrategy ) SetField ( v string ) * PlacementStrategy {
s . Field = & v
return s
}
// SetType sets the Type field's value.
func ( s * PlacementStrategy ) SetType ( v string ) * PlacementStrategy {
s . Type = & v
return s
}
// Port mappings allow containers to access ports on the host container instance
// to send or receive traffic. Port mappings are specified as part of the container
2018-02-22 14:58:04 +01:00
// definition.
//
// If using containers in a task with the awsvpc or host network mode, exposed
// ports should be specified using containerPort. The hostPort can be left blank
// or it must be the same value as the containerPort.
//
// After a task reaches the RUNNING status, manual and automatic host and container
// port assignments are visible in the networkBindings section of DescribeTasks
// API responses.
2017-02-07 22:33:23 +01:00
type PortMapping struct {
_ struct { } ` type:"structure" `
// The port number on the container that is bound to the user-specified or automatically
2018-02-22 14:58:04 +01:00
// assigned host port.
//
// If using containers in a task with the awsvpc or host network mode, exposed
// ports should be specified using containerPort.
//
// If using containers in a task with the bridge network mode and you specify
// a container port and not a host port, your container automatically receives
// a host port in the ephemeral port range (for more information, see hostPort).
// Port mappings that are automatically assigned in this way do not count toward
// the 100 reserved ports limit of a container instance.
2017-02-07 22:33:23 +01:00
ContainerPort * int64 ` locationName:"containerPort" type:"integer" `
// The port number on the container instance to reserve for your container.
2018-02-22 14:58:04 +01:00
//
// If using containers in a task with the awsvpc or host network mode, the hostPort
2018-05-28 18:52:03 +02:00
// can either be left blank or set to the same value as the containerPort.
2018-02-22 14:58:04 +01:00
//
// If using containers in a task with the bridge network mode, you can specify
// a non-reserved host port for your container port mapping, or you can omit
// the hostPort (or set it to 0) while specifying a containerPort and your container
// automatically receives a port in the ephemeral port range for your container
// instance operating system and Docker version.
//
// The default ephemeral port range for Docker version 1.6.0 and later is listed
// on the instance under /proc/sys/net/ipv4/ip_local_port_range; if this kernel
// parameter is unavailable, the default ephemeral port range from 49153 through
// 65535 is used. You should not attempt to specify a host port in the ephemeral
// port range as these are reserved for automatic assignment. In general, ports
2017-02-07 22:33:23 +01:00
// below 32768 are outside of the ephemeral port range.
//
2018-02-22 14:58:04 +01:00
// The default ephemeral port range from 49153 through 65535 is always used
// for Docker versions before 1.6.0.
//
2017-02-07 22:33:23 +01:00
// The default reserved ports are 22 for SSH, the Docker ports 2375 and 2376,
// and the Amazon ECS container agent ports 51678 and 51679. Any host port that
// was previously specified in a running task is also reserved while the task
2018-02-22 14:58:04 +01:00
// is running (after a task stops, the host port is released). The current reserved
2017-02-07 22:33:23 +01:00
// ports are displayed in the remainingResources of DescribeContainerInstances
// output, and a container instance may have up to 100 reserved ports at a time,
// including the default reserved ports (automatically assigned ports do not
// count toward the 100 reserved ports limit).
HostPort * int64 ` locationName:"hostPort" type:"integer" `
// The protocol used for the port mapping. Valid values are tcp and udp. The
// default is tcp.
Protocol * string ` locationName:"protocol" type:"string" enum:"TransportProtocol" `
}
// String returns the string representation
func ( s PortMapping ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s PortMapping ) GoString ( ) string {
return s . String ( )
}
// SetContainerPort sets the ContainerPort field's value.
func ( s * PortMapping ) SetContainerPort ( v int64 ) * PortMapping {
s . ContainerPort = & v
return s
}
// SetHostPort sets the HostPort field's value.
func ( s * PortMapping ) SetHostPort ( v int64 ) * PortMapping {
s . HostPort = & v
return s
}
// SetProtocol sets the Protocol field's value.
func ( s * PortMapping ) SetProtocol ( v string ) * PortMapping {
s . Protocol = & v
return s
}
type PutAttributesInput struct {
_ struct { } ` type:"structure" `
// The attributes to apply to your resource. You can specify up to 10 custom
// attributes per resource. You can specify up to 10 attributes in a single
// call.
//
// Attributes is a required field
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" required:"true" `
// The short name or full Amazon Resource Name (ARN) of the cluster that contains
// the resource to apply attributes. If you do not specify a cluster, the default
// cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
}
// String returns the string representation
func ( s PutAttributesInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s PutAttributesInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * PutAttributesInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "PutAttributesInput" }
if s . Attributes == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Attributes" ) )
}
if s . Attributes != nil {
for i , v := range s . Attributes {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Attributes" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttributes sets the Attributes field's value.
func ( s * PutAttributesInput ) SetAttributes ( v [ ] * Attribute ) * PutAttributesInput {
s . Attributes = v
return s
}
// SetCluster sets the Cluster field's value.
func ( s * PutAttributesInput ) SetCluster ( v string ) * PutAttributesInput {
s . Cluster = & v
return s
}
type PutAttributesOutput struct {
_ struct { } ` type:"structure" `
// The attributes applied to your resource.
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" `
}
// String returns the string representation
func ( s PutAttributesOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s PutAttributesOutput ) GoString ( ) string {
return s . String ( )
}
// SetAttributes sets the Attributes field's value.
func ( s * PutAttributesOutput ) SetAttributes ( v [ ] * Attribute ) * PutAttributesOutput {
s . Attributes = v
return s
}
type RegisterContainerInstanceInput struct {
_ struct { } ` type:"structure" `
// The container instance attributes that this container instance supports.
Attributes [ ] * Attribute ` locationName:"attributes" type:"list" `
// The short name or full Amazon Resource Name (ARN) of the cluster with which
// to register your container instance. If you do not specify a cluster, the
// default cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The ARN of the container instance (if it was previously registered).
2017-02-07 22:33:23 +01:00
ContainerInstanceArn * string ` locationName:"containerInstanceArn" type:"string" `
// The instance identity document for the EC2 instance to register. This document
// can be found by running the following command from the instance: curl http://169.254.169.254/latest/dynamic/instance-identity/document/
InstanceIdentityDocument * string ` locationName:"instanceIdentityDocument" type:"string" `
// The instance identity document signature for the EC2 instance to register.
// This signature can be found by running the following command from the instance:
// curl http://169.254.169.254/latest/dynamic/instance-identity/signature/
InstanceIdentityDocumentSignature * string ` locationName:"instanceIdentityDocumentSignature" type:"string" `
// The resources available on the instance.
TotalResources [ ] * Resource ` locationName:"totalResources" type:"list" `
// The version information for the Amazon ECS container agent and Docker daemon
// running on the container instance.
VersionInfo * VersionInfo ` locationName:"versionInfo" type:"structure" `
}
// String returns the string representation
func ( s RegisterContainerInstanceInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RegisterContainerInstanceInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * RegisterContainerInstanceInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "RegisterContainerInstanceInput" }
if s . Attributes != nil {
for i , v := range s . Attributes {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Attributes" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttributes sets the Attributes field's value.
func ( s * RegisterContainerInstanceInput ) SetAttributes ( v [ ] * Attribute ) * RegisterContainerInstanceInput {
s . Attributes = v
return s
}
// SetCluster sets the Cluster field's value.
func ( s * RegisterContainerInstanceInput ) SetCluster ( v string ) * RegisterContainerInstanceInput {
s . Cluster = & v
return s
}
// SetContainerInstanceArn sets the ContainerInstanceArn field's value.
func ( s * RegisterContainerInstanceInput ) SetContainerInstanceArn ( v string ) * RegisterContainerInstanceInput {
s . ContainerInstanceArn = & v
return s
}
// SetInstanceIdentityDocument sets the InstanceIdentityDocument field's value.
func ( s * RegisterContainerInstanceInput ) SetInstanceIdentityDocument ( v string ) * RegisterContainerInstanceInput {
s . InstanceIdentityDocument = & v
return s
}
// SetInstanceIdentityDocumentSignature sets the InstanceIdentityDocumentSignature field's value.
func ( s * RegisterContainerInstanceInput ) SetInstanceIdentityDocumentSignature ( v string ) * RegisterContainerInstanceInput {
s . InstanceIdentityDocumentSignature = & v
return s
}
// SetTotalResources sets the TotalResources field's value.
func ( s * RegisterContainerInstanceInput ) SetTotalResources ( v [ ] * Resource ) * RegisterContainerInstanceInput {
s . TotalResources = v
return s
}
// SetVersionInfo sets the VersionInfo field's value.
func ( s * RegisterContainerInstanceInput ) SetVersionInfo ( v * VersionInfo ) * RegisterContainerInstanceInput {
s . VersionInfo = v
return s
}
type RegisterContainerInstanceOutput struct {
_ struct { } ` type:"structure" `
// The container instance that was registered.
ContainerInstance * ContainerInstance ` locationName:"containerInstance" type:"structure" `
}
// String returns the string representation
func ( s RegisterContainerInstanceOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RegisterContainerInstanceOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * RegisterContainerInstanceOutput ) SetContainerInstance ( v * ContainerInstance ) * RegisterContainerInstanceOutput {
s . ContainerInstance = v
return s
}
type RegisterTaskDefinitionInput struct {
_ struct { } ` type:"structure" `
// A list of container definitions in JSON format that describe the different
// containers that make up your task.
//
// ContainerDefinitions is a required field
ContainerDefinitions [ ] * ContainerDefinition ` locationName:"containerDefinitions" type:"list" required:"true" `
2018-05-28 18:52:03 +02:00
// The number of CPU units used by the task. It can be expressed as an integer
// using CPU units, for example 1024, or as a string using vCPUs, for example
// 1 vCPU or 1 vcpu, in a task definition but will be converted to an integer
// indicating the CPU units when the task definition is registered.
2018-02-22 14:58:04 +01:00
//
// Task-level CPU and memory parameters are ignored for Windows containers.
// We recommend specifying container-level resources for Windows containers.
//
2018-05-28 18:52:03 +02:00
// If using the EC2 launch type, this field is optional. Supported values are
// between 128 CPU units (0.125 vCPUs) and 10240 CPU units (10 vCPUs).
//
// If using the Fargate launch type, this field is required and you must use
// one of the following values, which determines your range of supported values
// for the memory parameter:
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB),
// 2048 (2 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072
// (3 GB), 4096 (4 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096
// (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384
// (16 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720
// (30 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
Cpu * string ` locationName:"cpu" type:"string" `
// The Amazon Resource Name (ARN) of the task execution role that the Amazon
// ECS container agent and the Docker daemon can assume.
ExecutionRoleArn * string ` locationName:"executionRoleArn" type:"string" `
2017-02-07 22:33:23 +01:00
// You must specify a family for a task definition, which allows you to track
// multiple versions of the same task definition. The family is used as a name
// for your task definition. Up to 255 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed.
//
2018-02-22 14:58:04 +01:00
// Family is a required field
Family * string ` locationName:"family" type:"string" required:"true" `
2018-05-28 18:52:03 +02:00
// The amount of memory (in MiB) used by the task. It can be expressed as an
// integer using MiB, for example 1024, or as a string using GB, for example
// 1GB or 1 GB, in a task definition but will be converted to an integer indicating
// the MiB when the task definition is registered.
2018-02-22 14:58:04 +01:00
//
// Task-level CPU and memory parameters are ignored for Windows containers.
// We recommend specifying container-level resources for Windows containers.
//
2018-05-28 18:52:03 +02:00
// If using the EC2 launch type, this field is optional.
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// If using the Fargate launch type, this field is required and you must use
// one of the following values, which determines your range of supported values
// for the cpu parameter:
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25
// vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values:
// 512 (.5 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168
// (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) -
// Available cpu values: 2048 (2 vCPU)
//
// * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) -
// Available cpu values: 4096 (4 vCPU)
2018-02-22 14:58:04 +01:00
Memory * string ` locationName:"memory" type:"string" `
2017-02-07 22:33:23 +01:00
// The Docker networking mode to use for the containers in the task. The valid
2018-02-22 14:58:04 +01:00
// values are none, bridge, awsvpc, and host. The default Docker network mode
// is bridge. If using the Fargate launch type, the awsvpc network mode is required.
// If using the EC2 launch type, any network mode can be used. If the network
// mode is set to none, you can't specify port mappings in your container definitions,
// and the task's containers do not have external connectivity. The host and
// awsvpc network modes offer the highest networking performance for containers
// because they use the EC2 network stack instead of the virtualized network
// stack provided by the bridge mode.
//
// With the host and awsvpc network modes, exposed container ports are mapped
// directly to the corresponding host port (for the host network mode) or the
// attached elastic network interface port (for the awsvpc network mode), so
// you cannot take advantage of dynamic host port mappings.
//
// If the network mode is awsvpc, the task is allocated an Elastic Network Interface,
// and you must specify a NetworkConfiguration when you create a service or
// run a task with the task definition. For more information, see Task Networking
// (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
//
// If the network mode is host, you can't run multiple instantiations of the
// same task on a single container instance when port mappings are used.
//
// Docker for Windows uses different network modes than Docker for Linux. When
// you register a task definition with Windows containers, you must not specify
// a network mode.
2017-02-07 22:33:23 +01:00
//
// For more information, see Network settings (https://docs.docker.com/engine/reference/run/#network-settings)
// in the Docker run reference.
NetworkMode * string ` locationName:"networkMode" type:"string" enum:"NetworkMode" `
// An array of placement constraint objects to use for the task. You can specify
// a maximum of 10 constraints per task (this limit includes constraints in
// the task definition and those specified at run time).
PlacementConstraints [ ] * TaskDefinitionPlacementConstraint ` locationName:"placementConstraints" type:"list" `
2018-02-22 14:58:04 +01:00
// The launch type required by the task. If no value is specified, it defaults
// to EC2.
RequiresCompatibilities [ ] * string ` locationName:"requiresCompatibilities" type:"list" `
2017-02-07 22:33:23 +01:00
// The short name or full Amazon Resource Name (ARN) of the IAM role that containers
// in this task can assume. All containers in this task are granted the permissions
// that are specified in this role. For more information, see IAM Roles for
// Tasks (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
TaskRoleArn * string ` locationName:"taskRoleArn" type:"string" `
// A list of volume definitions in JSON format that containers in your task
// may use.
Volumes [ ] * Volume ` locationName:"volumes" type:"list" `
}
// String returns the string representation
func ( s RegisterTaskDefinitionInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RegisterTaskDefinitionInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * RegisterTaskDefinitionInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "RegisterTaskDefinitionInput" }
if s . ContainerDefinitions == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerDefinitions" ) )
}
if s . Family == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Family" ) )
}
if s . ContainerDefinitions != nil {
for i , v := range s . ContainerDefinitions {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "ContainerDefinitions" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetContainerDefinitions sets the ContainerDefinitions field's value.
func ( s * RegisterTaskDefinitionInput ) SetContainerDefinitions ( v [ ] * ContainerDefinition ) * RegisterTaskDefinitionInput {
s . ContainerDefinitions = v
return s
}
2018-02-22 14:58:04 +01:00
// SetCpu sets the Cpu field's value.
func ( s * RegisterTaskDefinitionInput ) SetCpu ( v string ) * RegisterTaskDefinitionInput {
s . Cpu = & v
return s
}
// SetExecutionRoleArn sets the ExecutionRoleArn field's value.
func ( s * RegisterTaskDefinitionInput ) SetExecutionRoleArn ( v string ) * RegisterTaskDefinitionInput {
s . ExecutionRoleArn = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetFamily sets the Family field's value.
func ( s * RegisterTaskDefinitionInput ) SetFamily ( v string ) * RegisterTaskDefinitionInput {
s . Family = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetMemory sets the Memory field's value.
func ( s * RegisterTaskDefinitionInput ) SetMemory ( v string ) * RegisterTaskDefinitionInput {
s . Memory = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetNetworkMode sets the NetworkMode field's value.
func ( s * RegisterTaskDefinitionInput ) SetNetworkMode ( v string ) * RegisterTaskDefinitionInput {
s . NetworkMode = & v
return s
}
// SetPlacementConstraints sets the PlacementConstraints field's value.
func ( s * RegisterTaskDefinitionInput ) SetPlacementConstraints ( v [ ] * TaskDefinitionPlacementConstraint ) * RegisterTaskDefinitionInput {
s . PlacementConstraints = v
return s
}
2018-02-22 14:58:04 +01:00
// SetRequiresCompatibilities sets the RequiresCompatibilities field's value.
func ( s * RegisterTaskDefinitionInput ) SetRequiresCompatibilities ( v [ ] * string ) * RegisterTaskDefinitionInput {
s . RequiresCompatibilities = v
return s
}
2017-02-07 22:33:23 +01:00
// SetTaskRoleArn sets the TaskRoleArn field's value.
func ( s * RegisterTaskDefinitionInput ) SetTaskRoleArn ( v string ) * RegisterTaskDefinitionInput {
s . TaskRoleArn = & v
return s
}
// SetVolumes sets the Volumes field's value.
func ( s * RegisterTaskDefinitionInput ) SetVolumes ( v [ ] * Volume ) * RegisterTaskDefinitionInput {
s . Volumes = v
return s
}
type RegisterTaskDefinitionOutput struct {
_ struct { } ` type:"structure" `
// The full description of the registered task definition.
TaskDefinition * TaskDefinition ` locationName:"taskDefinition" type:"structure" `
}
// String returns the string representation
func ( s RegisterTaskDefinitionOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RegisterTaskDefinitionOutput ) GoString ( ) string {
return s . String ( )
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * RegisterTaskDefinitionOutput ) SetTaskDefinition ( v * TaskDefinition ) * RegisterTaskDefinitionOutput {
s . TaskDefinition = v
return s
}
// Describes the resources available for a container instance.
type Resource struct {
_ struct { } ` type:"structure" `
// When the doubleValue type is set, the value of the resource must be a double
// precision floating-point type.
DoubleValue * float64 ` locationName:"doubleValue" type:"double" `
// When the integerValue type is set, the value of the resource must be an integer.
IntegerValue * int64 ` locationName:"integerValue" type:"integer" `
// When the longValue type is set, the value of the resource must be an extended
// precision floating-point type.
LongValue * int64 ` locationName:"longValue" type:"long" `
2018-05-28 18:52:03 +02:00
// The name of the resource, such as CPU, MEMORY, PORTS, PORTS_UDP, or a user-defined
// resource.
2017-02-07 22:33:23 +01:00
Name * string ` locationName:"name" type:"string" `
// When the stringSetValue type is set, the value of the resource must be a
// string type.
StringSetValue [ ] * string ` locationName:"stringSetValue" type:"list" `
// The type of the resource, such as INTEGER, DOUBLE, LONG, or STRINGSET.
Type * string ` locationName:"type" type:"string" `
}
// String returns the string representation
func ( s Resource ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Resource ) GoString ( ) string {
return s . String ( )
}
// SetDoubleValue sets the DoubleValue field's value.
func ( s * Resource ) SetDoubleValue ( v float64 ) * Resource {
s . DoubleValue = & v
return s
}
// SetIntegerValue sets the IntegerValue field's value.
func ( s * Resource ) SetIntegerValue ( v int64 ) * Resource {
s . IntegerValue = & v
return s
}
// SetLongValue sets the LongValue field's value.
func ( s * Resource ) SetLongValue ( v int64 ) * Resource {
s . LongValue = & v
return s
}
// SetName sets the Name field's value.
func ( s * Resource ) SetName ( v string ) * Resource {
s . Name = & v
return s
}
// SetStringSetValue sets the StringSetValue field's value.
func ( s * Resource ) SetStringSetValue ( v [ ] * string ) * Resource {
s . StringSetValue = v
return s
}
// SetType sets the Type field's value.
func ( s * Resource ) SetType ( v string ) * Resource {
s . Type = & v
return s
}
type RunTaskInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster on which
// to run your task. If you do not specify a cluster, the default cluster is
// assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// The number of instantiations of the specified task to place on your cluster.
// You can specify up to 10 tasks per call.
Count * int64 ` locationName:"count" type:"integer" `
// The name of the task group to associate with the task. The default value
// is the family name of the task definition (for example, family:my-family-name).
Group * string ` locationName:"group" type:"string" `
2018-02-22 14:58:04 +01:00
// The launch type on which to run your task.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
// The network configuration for the task. This parameter is required for task
// definitions that use the awsvpc network mode to receive their own Elastic
// Network Interface, and it is not supported for other network modes. For more
// information, see Task Networking (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
2017-02-07 22:33:23 +01:00
// A list of container overrides in JSON format that specify the name of a container
// in the specified task definition and the overrides it should receive. You
// can override the default command for a container (that is specified in the
// task definition or Docker image) with a command override. You can also override
// existing environment variables (that are specified in the task definition
// or Docker image) on a container or add new environment variables to it with
// an environment override.
//
// A total of 8192 characters are allowed for overrides. This limit includes
// the JSON formatting characters of the override structure.
Overrides * TaskOverride ` locationName:"overrides" type:"structure" `
// An array of placement constraint objects to use for the task. You can specify
// up to 10 constraints per task (including constraints in the task definition
// and those specified at run time).
PlacementConstraints [ ] * PlacementConstraint ` locationName:"placementConstraints" type:"list" `
// The placement strategy objects to use for the task. You can specify a maximum
2018-02-22 14:58:04 +01:00
// of five strategy rules per task.
2017-02-07 22:33:23 +01:00
PlacementStrategy [ ] * PlacementStrategy ` locationName:"placementStrategy" type:"list" `
2018-02-22 14:58:04 +01:00
// The platform version on which to run your task. If one is not specified,
// the latest version is used by default.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
2017-02-07 22:33:23 +01:00
// An optional tag specified when a task is started. For example if you automatically
// trigger a task to run a batch process job, you could apply a unique identifier
// for that job to your task with the startedBy parameter. You can then identify
// which tasks belong to that job by filtering the results of a ListTasks call
// with the startedBy value. Up to 36 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed.
//
// If a task is started by an Amazon ECS service, then the startedBy parameter
// contains the deployment ID of the service that starts it.
StartedBy * string ` locationName:"startedBy" type:"string" `
2018-02-22 14:58:04 +01:00
// The family and revision (family:revision) or full ARN of the task definition
// to run. If a revision is not specified, the latest ACTIVE revision is used.
2017-02-07 22:33:23 +01:00
//
// TaskDefinition is a required field
TaskDefinition * string ` locationName:"taskDefinition" type:"string" required:"true" `
}
// String returns the string representation
func ( s RunTaskInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RunTaskInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * RunTaskInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "RunTaskInput" }
if s . TaskDefinition == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TaskDefinition" ) )
}
2018-02-22 14:58:04 +01:00
if s . NetworkConfiguration != nil {
if err := s . NetworkConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "NetworkConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
2017-02-07 22:33:23 +01:00
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * RunTaskInput ) SetCluster ( v string ) * RunTaskInput {
s . Cluster = & v
return s
}
// SetCount sets the Count field's value.
func ( s * RunTaskInput ) SetCount ( v int64 ) * RunTaskInput {
s . Count = & v
return s
}
// SetGroup sets the Group field's value.
func ( s * RunTaskInput ) SetGroup ( v string ) * RunTaskInput {
s . Group = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetLaunchType sets the LaunchType field's value.
func ( s * RunTaskInput ) SetLaunchType ( v string ) * RunTaskInput {
s . LaunchType = & v
return s
}
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * RunTaskInput ) SetNetworkConfiguration ( v * NetworkConfiguration ) * RunTaskInput {
s . NetworkConfiguration = v
return s
}
2017-02-07 22:33:23 +01:00
// SetOverrides sets the Overrides field's value.
func ( s * RunTaskInput ) SetOverrides ( v * TaskOverride ) * RunTaskInput {
s . Overrides = v
return s
}
// SetPlacementConstraints sets the PlacementConstraints field's value.
func ( s * RunTaskInput ) SetPlacementConstraints ( v [ ] * PlacementConstraint ) * RunTaskInput {
s . PlacementConstraints = v
return s
}
// SetPlacementStrategy sets the PlacementStrategy field's value.
func ( s * RunTaskInput ) SetPlacementStrategy ( v [ ] * PlacementStrategy ) * RunTaskInput {
s . PlacementStrategy = v
return s
}
2018-02-22 14:58:04 +01:00
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * RunTaskInput ) SetPlatformVersion ( v string ) * RunTaskInput {
s . PlatformVersion = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetStartedBy sets the StartedBy field's value.
func ( s * RunTaskInput ) SetStartedBy ( v string ) * RunTaskInput {
s . StartedBy = & v
return s
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * RunTaskInput ) SetTaskDefinition ( v string ) * RunTaskInput {
s . TaskDefinition = & v
return s
}
type RunTaskOutput struct {
_ struct { } ` type:"structure" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
2018-02-22 14:58:04 +01:00
// A full description of the tasks that were run. The tasks that were successfully
2017-02-07 22:33:23 +01:00
// placed on your cluster are described here.
Tasks [ ] * Task ` locationName:"tasks" type:"list" `
}
// String returns the string representation
func ( s RunTaskOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s RunTaskOutput ) GoString ( ) string {
return s . String ( )
}
// SetFailures sets the Failures field's value.
func ( s * RunTaskOutput ) SetFailures ( v [ ] * Failure ) * RunTaskOutput {
s . Failures = v
return s
}
// SetTasks sets the Tasks field's value.
func ( s * RunTaskOutput ) SetTasks ( v [ ] * Task ) * RunTaskOutput {
s . Tasks = v
return s
}
// Details on a service within a cluster
type Service struct {
_ struct { } ` type:"structure" `
// The Amazon Resource Name (ARN) of the cluster that hosts the service.
ClusterArn * string ` locationName:"clusterArn" type:"string" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the service was created.
2017-02-07 22:33:23 +01:00
CreatedAt * time . Time ` locationName:"createdAt" type:"timestamp" timestampFormat:"unix" `
// Optional deployment parameters that control how many tasks run during the
// deployment and the ordering of stopping and starting tasks.
DeploymentConfiguration * DeploymentConfiguration ` locationName:"deploymentConfiguration" type:"structure" `
// The current state of deployments for the service.
Deployments [ ] * Deployment ` locationName:"deployments" type:"list" `
// The desired number of instantiations of the task definition to keep running
// on the service. This value is specified when the service is created with
// CreateService, and it can be modified with UpdateService.
DesiredCount * int64 ` locationName:"desiredCount" type:"integer" `
// The event stream for your service. A maximum of 100 of the latest events
// are displayed.
Events [ ] * ServiceEvent ` locationName:"events" type:"list" `
2018-02-22 14:58:04 +01:00
// The period of time, in seconds, that the Amazon ECS service scheduler ignores
// unhealthy Elastic Load Balancing target health checks after a task has first
// started.
HealthCheckGracePeriodSeconds * int64 ` locationName:"healthCheckGracePeriodSeconds" type:"integer" `
// The launch type on which your service is running.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
2017-02-07 22:33:23 +01:00
// A list of Elastic Load Balancing load balancer objects, containing the load
// balancer name, the container name (as it appears in a container definition),
// and the container port to access from the load balancer.
2018-05-28 18:52:03 +02:00
//
// Services with tasks that use the awsvpc network mode (for example, those
// with the Fargate launch type) only support Application Load Balancers and
// Network Load Balancers; Classic Load Balancers are not supported. Also, when
// you create any target groups for these services, you must choose ip as the
// target type, not instance, because tasks that use the awsvpc network mode
// are associated with an elastic network interface, not an Amazon EC2 instance.
2017-02-07 22:33:23 +01:00
LoadBalancers [ ] * LoadBalancer ` locationName:"loadBalancers" type:"list" `
2018-02-22 14:58:04 +01:00
// The VPC subnet and security group configuration for tasks that receive their
// own Elastic Network Interface by using the awsvpc networking mode.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
2017-02-07 22:33:23 +01:00
// The number of tasks in the cluster that are in the PENDING state.
PendingCount * int64 ` locationName:"pendingCount" type:"integer" `
// The placement constraints for the tasks in the service.
PlacementConstraints [ ] * PlacementConstraint ` locationName:"placementConstraints" type:"list" `
// The placement strategy that determines how tasks for the service are placed.
PlacementStrategy [ ] * PlacementStrategy ` locationName:"placementStrategy" type:"list" `
2018-02-22 14:58:04 +01:00
// The platform version on which your task is running. For more information,
// see AWS Fargate Platform Versions (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html)
// in the Amazon Elastic Container Service Developer Guide.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
// The ARN of the IAM role associated with the service that allows the Amazon
// ECS container agent to register container instances with an Elastic Load
// Balancing load balancer.
2017-02-07 22:33:23 +01:00
RoleArn * string ` locationName:"roleArn" type:"string" `
// The number of tasks in the cluster that are in the RUNNING state.
RunningCount * int64 ` locationName:"runningCount" type:"integer" `
2018-02-22 14:58:04 +01:00
// The ARN that identifies the service. The ARN contains the arn:aws:ecs namespace,
// followed by the region of the service, the AWS account ID of the service
// owner, the service namespace, and then the service name. For example, arn:aws:ecs:region:012345678910:service/my-service.
2017-02-07 22:33:23 +01:00
ServiceArn * string ` locationName:"serviceArn" type:"string" `
// The name of your service. Up to 255 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed. Service names must be unique within
// a cluster, but you can have similarly named services in multiple clusters
// within a region or across multiple regions.
ServiceName * string ` locationName:"serviceName" type:"string" `
2018-05-28 18:52:03 +02:00
ServiceRegistries [ ] * ServiceRegistry ` locationName:"serviceRegistries" type:"list" `
2017-02-07 22:33:23 +01:00
// The status of the service. The valid values are ACTIVE, DRAINING, or INACTIVE.
Status * string ` locationName:"status" type:"string" `
// The task definition to use for tasks in the service. This value is specified
// when the service is created with CreateService, and it can be modified with
// UpdateService.
TaskDefinition * string ` locationName:"taskDefinition" type:"string" `
}
// String returns the string representation
func ( s Service ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Service ) GoString ( ) string {
return s . String ( )
}
// SetClusterArn sets the ClusterArn field's value.
func ( s * Service ) SetClusterArn ( v string ) * Service {
s . ClusterArn = & v
return s
}
// SetCreatedAt sets the CreatedAt field's value.
func ( s * Service ) SetCreatedAt ( v time . Time ) * Service {
s . CreatedAt = & v
return s
}
// SetDeploymentConfiguration sets the DeploymentConfiguration field's value.
func ( s * Service ) SetDeploymentConfiguration ( v * DeploymentConfiguration ) * Service {
s . DeploymentConfiguration = v
return s
}
// SetDeployments sets the Deployments field's value.
func ( s * Service ) SetDeployments ( v [ ] * Deployment ) * Service {
s . Deployments = v
return s
}
// SetDesiredCount sets the DesiredCount field's value.
func ( s * Service ) SetDesiredCount ( v int64 ) * Service {
s . DesiredCount = & v
return s
}
// SetEvents sets the Events field's value.
func ( s * Service ) SetEvents ( v [ ] * ServiceEvent ) * Service {
s . Events = v
return s
}
2018-02-22 14:58:04 +01:00
// SetHealthCheckGracePeriodSeconds sets the HealthCheckGracePeriodSeconds field's value.
func ( s * Service ) SetHealthCheckGracePeriodSeconds ( v int64 ) * Service {
s . HealthCheckGracePeriodSeconds = & v
return s
}
// SetLaunchType sets the LaunchType field's value.
func ( s * Service ) SetLaunchType ( v string ) * Service {
s . LaunchType = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetLoadBalancers sets the LoadBalancers field's value.
func ( s * Service ) SetLoadBalancers ( v [ ] * LoadBalancer ) * Service {
s . LoadBalancers = v
return s
}
2018-02-22 14:58:04 +01:00
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * Service ) SetNetworkConfiguration ( v * NetworkConfiguration ) * Service {
s . NetworkConfiguration = v
return s
}
2017-02-07 22:33:23 +01:00
// SetPendingCount sets the PendingCount field's value.
func ( s * Service ) SetPendingCount ( v int64 ) * Service {
s . PendingCount = & v
return s
}
// SetPlacementConstraints sets the PlacementConstraints field's value.
func ( s * Service ) SetPlacementConstraints ( v [ ] * PlacementConstraint ) * Service {
s . PlacementConstraints = v
return s
}
// SetPlacementStrategy sets the PlacementStrategy field's value.
func ( s * Service ) SetPlacementStrategy ( v [ ] * PlacementStrategy ) * Service {
s . PlacementStrategy = v
return s
}
2018-02-22 14:58:04 +01:00
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * Service ) SetPlatformVersion ( v string ) * Service {
s . PlatformVersion = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetRoleArn sets the RoleArn field's value.
func ( s * Service ) SetRoleArn ( v string ) * Service {
s . RoleArn = & v
return s
}
// SetRunningCount sets the RunningCount field's value.
func ( s * Service ) SetRunningCount ( v int64 ) * Service {
s . RunningCount = & v
return s
}
// SetServiceArn sets the ServiceArn field's value.
func ( s * Service ) SetServiceArn ( v string ) * Service {
s . ServiceArn = & v
return s
}
// SetServiceName sets the ServiceName field's value.
func ( s * Service ) SetServiceName ( v string ) * Service {
s . ServiceName = & v
return s
}
2018-05-28 18:52:03 +02:00
// SetServiceRegistries sets the ServiceRegistries field's value.
func ( s * Service ) SetServiceRegistries ( v [ ] * ServiceRegistry ) * Service {
s . ServiceRegistries = v
return s
}
2017-02-07 22:33:23 +01:00
// SetStatus sets the Status field's value.
func ( s * Service ) SetStatus ( v string ) * Service {
s . Status = & v
return s
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * Service ) SetTaskDefinition ( v string ) * Service {
s . TaskDefinition = & v
return s
}
// Details on an event associated with a service.
type ServiceEvent struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the event was triggered.
2017-02-07 22:33:23 +01:00
CreatedAt * time . Time ` locationName:"createdAt" type:"timestamp" timestampFormat:"unix" `
// The ID string of the event.
Id * string ` locationName:"id" type:"string" `
// The event message.
Message * string ` locationName:"message" type:"string" `
}
// String returns the string representation
func ( s ServiceEvent ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ServiceEvent ) GoString ( ) string {
return s . String ( )
}
// SetCreatedAt sets the CreatedAt field's value.
func ( s * ServiceEvent ) SetCreatedAt ( v time . Time ) * ServiceEvent {
s . CreatedAt = & v
return s
}
// SetId sets the Id field's value.
func ( s * ServiceEvent ) SetId ( v string ) * ServiceEvent {
s . Id = & v
return s
}
// SetMessage sets the Message field's value.
func ( s * ServiceEvent ) SetMessage ( v string ) * ServiceEvent {
s . Message = & v
return s
}
2018-05-28 18:52:03 +02:00
// Details of the service registry.
type ServiceRegistry struct {
_ struct { } ` type:"structure" `
// The container name value, already specified in the task definition, to be
// used for your service discovery service. If the task definition that your
// service task specifies uses the bridge or host network mode, you must specify
// a containerName and containerPort combination from the task definition. If
// the task definition that your service task specifies uses the awsvpc network
// mode and a type SRV DNS record is used, you must specify either a containerName
// and containerPort combination or a port value, but not both.
ContainerName * string ` locationName:"containerName" type:"string" `
// The port value, already specified in the task definition, to be used for
// your service discovery service. If the task definition your service task
// specifies uses the bridge or host network mode, you must specify a containerName
// and containerPort combination from the task definition. If the task definition
// your service task specifies uses the awsvpc network mode and a type SRV DNS
// record is used, you must specify either a containerName and containerPort
// combination or a port value, but not both.
ContainerPort * int64 ` locationName:"containerPort" type:"integer" `
// The port value used if your service discovery service specified an SRV record.
// This field is required if both the awsvpc network mode and SRV records are
// used.
Port * int64 ` locationName:"port" type:"integer" `
// The Amazon Resource Name (ARN) of the service registry. The currently supported
// service registry is Amazon Route 53 Auto Naming. For more information, see
// Service (https://docs.aws.amazon.com/Route53/latest/APIReference/API_autonaming_Service.html).
RegistryArn * string ` locationName:"registryArn" type:"string" `
}
// String returns the string representation
func ( s ServiceRegistry ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s ServiceRegistry ) GoString ( ) string {
return s . String ( )
}
// SetContainerName sets the ContainerName field's value.
func ( s * ServiceRegistry ) SetContainerName ( v string ) * ServiceRegistry {
s . ContainerName = & v
return s
}
// SetContainerPort sets the ContainerPort field's value.
func ( s * ServiceRegistry ) SetContainerPort ( v int64 ) * ServiceRegistry {
s . ContainerPort = & v
return s
}
// SetPort sets the Port field's value.
func ( s * ServiceRegistry ) SetPort ( v int64 ) * ServiceRegistry {
s . Port = & v
return s
}
// SetRegistryArn sets the RegistryArn field's value.
func ( s * ServiceRegistry ) SetRegistryArn ( v string ) * ServiceRegistry {
s . RegistryArn = & v
return s
}
2017-02-07 22:33:23 +01:00
type StartTaskInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster on which
// to start your task. If you do not specify a cluster, the default cluster
// is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The container instance IDs or full ARN entries for the container instances
// on which you would like to place your task. You can specify up to 10 container
// instances.
2017-02-07 22:33:23 +01:00
//
// ContainerInstances is a required field
ContainerInstances [ ] * string ` locationName:"containerInstances" type:"list" required:"true" `
// The name of the task group to associate with the task. The default value
// is the family name of the task definition (for example, family:my-family-name).
Group * string ` locationName:"group" type:"string" `
2018-02-22 14:58:04 +01:00
// The VPC subnet and security group configuration for tasks that receive their
// own Elastic Network Interface by using the awsvpc networking mode.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
2017-02-07 22:33:23 +01:00
// A list of container overrides in JSON format that specify the name of a container
// in the specified task definition and the overrides it should receive. You
// can override the default command for a container (that is specified in the
// task definition or Docker image) with a command override. You can also override
// existing environment variables (that are specified in the task definition
// or Docker image) on a container or add new environment variables to it with
// an environment override.
//
// A total of 8192 characters are allowed for overrides. This limit includes
// the JSON formatting characters of the override structure.
Overrides * TaskOverride ` locationName:"overrides" type:"structure" `
// An optional tag specified when a task is started. For example if you automatically
// trigger a task to run a batch process job, you could apply a unique identifier
// for that job to your task with the startedBy parameter. You can then identify
// which tasks belong to that job by filtering the results of a ListTasks call
// with the startedBy value. Up to 36 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed.
//
// If a task is started by an Amazon ECS service, then the startedBy parameter
// contains the deployment ID of the service that starts it.
StartedBy * string ` locationName:"startedBy" type:"string" `
2018-02-22 14:58:04 +01:00
// The family and revision (family:revision) or full ARN of the task definition
// to start. If a revision is not specified, the latest ACTIVE revision is used.
2017-02-07 22:33:23 +01:00
//
// TaskDefinition is a required field
TaskDefinition * string ` locationName:"taskDefinition" type:"string" required:"true" `
}
// String returns the string representation
func ( s StartTaskInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s StartTaskInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * StartTaskInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "StartTaskInput" }
if s . ContainerInstances == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerInstances" ) )
}
if s . TaskDefinition == nil {
invalidParams . Add ( request . NewErrParamRequired ( "TaskDefinition" ) )
}
2018-02-22 14:58:04 +01:00
if s . NetworkConfiguration != nil {
if err := s . NetworkConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "NetworkConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
2017-02-07 22:33:23 +01:00
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * StartTaskInput ) SetCluster ( v string ) * StartTaskInput {
s . Cluster = & v
return s
}
// SetContainerInstances sets the ContainerInstances field's value.
func ( s * StartTaskInput ) SetContainerInstances ( v [ ] * string ) * StartTaskInput {
s . ContainerInstances = v
return s
}
// SetGroup sets the Group field's value.
func ( s * StartTaskInput ) SetGroup ( v string ) * StartTaskInput {
s . Group = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * StartTaskInput ) SetNetworkConfiguration ( v * NetworkConfiguration ) * StartTaskInput {
s . NetworkConfiguration = v
return s
}
2017-02-07 22:33:23 +01:00
// SetOverrides sets the Overrides field's value.
func ( s * StartTaskInput ) SetOverrides ( v * TaskOverride ) * StartTaskInput {
s . Overrides = v
return s
}
// SetStartedBy sets the StartedBy field's value.
func ( s * StartTaskInput ) SetStartedBy ( v string ) * StartTaskInput {
s . StartedBy = & v
return s
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * StartTaskInput ) SetTaskDefinition ( v string ) * StartTaskInput {
s . TaskDefinition = & v
return s
}
type StartTaskOutput struct {
_ struct { } ` type:"structure" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
// A full description of the tasks that were started. Each task that was successfully
2018-02-22 14:58:04 +01:00
// placed on your container instances is described.
2017-02-07 22:33:23 +01:00
Tasks [ ] * Task ` locationName:"tasks" type:"list" `
}
// String returns the string representation
func ( s StartTaskOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s StartTaskOutput ) GoString ( ) string {
return s . String ( )
}
// SetFailures sets the Failures field's value.
func ( s * StartTaskOutput ) SetFailures ( v [ ] * Failure ) * StartTaskOutput {
s . Failures = v
return s
}
// SetTasks sets the Tasks field's value.
func ( s * StartTaskOutput ) SetTasks ( v [ ] * Task ) * StartTaskOutput {
s . Tasks = v
return s
}
type StopTaskInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the task to stop. If you do not specify a cluster, the default cluster is
// assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// An optional message specified when a task is stopped. For example, if you
// are using a custom scheduler, you can use this parameter to specify the reason
2018-02-22 14:58:04 +01:00
// for stopping the task here, and the message appears in subsequent DescribeTasks
2017-02-07 22:33:23 +01:00
// API operations on this task. Up to 255 characters are allowed in this message.
Reason * string ` locationName:"reason" type:"string" `
2018-02-22 14:58:04 +01:00
// The task ID or full ARN entry of the task to stop.
2017-02-07 22:33:23 +01:00
//
// Task is a required field
Task * string ` locationName:"task" type:"string" required:"true" `
}
// String returns the string representation
func ( s StopTaskInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s StopTaskInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * StopTaskInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "StopTaskInput" }
if s . Task == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Task" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * StopTaskInput ) SetCluster ( v string ) * StopTaskInput {
s . Cluster = & v
return s
}
// SetReason sets the Reason field's value.
func ( s * StopTaskInput ) SetReason ( v string ) * StopTaskInput {
s . Reason = & v
return s
}
// SetTask sets the Task field's value.
func ( s * StopTaskInput ) SetTask ( v string ) * StopTaskInput {
s . Task = & v
return s
}
type StopTaskOutput struct {
_ struct { } ` type:"structure" `
// The task that was stopped.
Task * Task ` locationName:"task" type:"structure" `
}
// String returns the string representation
func ( s StopTaskOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s StopTaskOutput ) GoString ( ) string {
return s . String ( )
}
// SetTask sets the Task field's value.
func ( s * StopTaskOutput ) SetTask ( v * Task ) * StopTaskOutput {
s . Task = v
return s
}
type SubmitContainerStateChangeInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The short name or full ARN of the cluster that hosts the container.
2017-02-07 22:33:23 +01:00
Cluster * string ` locationName:"cluster" type:"string" `
// The name of the container.
ContainerName * string ` locationName:"containerName" type:"string" `
// The exit code returned for the state change request.
ExitCode * int64 ` locationName:"exitCode" type:"integer" `
// The network bindings of the container.
NetworkBindings [ ] * NetworkBinding ` locationName:"networkBindings" type:"list" `
// The reason for the state change request.
Reason * string ` locationName:"reason" type:"string" `
// The status of the state change request.
Status * string ` locationName:"status" type:"string" `
// The task ID or full Amazon Resource Name (ARN) of the task that hosts the
// container.
Task * string ` locationName:"task" type:"string" `
}
// String returns the string representation
func ( s SubmitContainerStateChangeInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s SubmitContainerStateChangeInput ) GoString ( ) string {
return s . String ( )
}
// SetCluster sets the Cluster field's value.
func ( s * SubmitContainerStateChangeInput ) SetCluster ( v string ) * SubmitContainerStateChangeInput {
s . Cluster = & v
return s
}
// SetContainerName sets the ContainerName field's value.
func ( s * SubmitContainerStateChangeInput ) SetContainerName ( v string ) * SubmitContainerStateChangeInput {
s . ContainerName = & v
return s
}
// SetExitCode sets the ExitCode field's value.
func ( s * SubmitContainerStateChangeInput ) SetExitCode ( v int64 ) * SubmitContainerStateChangeInput {
s . ExitCode = & v
return s
}
// SetNetworkBindings sets the NetworkBindings field's value.
func ( s * SubmitContainerStateChangeInput ) SetNetworkBindings ( v [ ] * NetworkBinding ) * SubmitContainerStateChangeInput {
s . NetworkBindings = v
return s
}
// SetReason sets the Reason field's value.
func ( s * SubmitContainerStateChangeInput ) SetReason ( v string ) * SubmitContainerStateChangeInput {
s . Reason = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * SubmitContainerStateChangeInput ) SetStatus ( v string ) * SubmitContainerStateChangeInput {
s . Status = & v
return s
}
// SetTask sets the Task field's value.
func ( s * SubmitContainerStateChangeInput ) SetTask ( v string ) * SubmitContainerStateChangeInput {
s . Task = & v
return s
}
type SubmitContainerStateChangeOutput struct {
_ struct { } ` type:"structure" `
// Acknowledgement of the state change.
Acknowledgment * string ` locationName:"acknowledgment" type:"string" `
}
// String returns the string representation
func ( s SubmitContainerStateChangeOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s SubmitContainerStateChangeOutput ) GoString ( ) string {
return s . String ( )
}
// SetAcknowledgment sets the Acknowledgment field's value.
func ( s * SubmitContainerStateChangeOutput ) SetAcknowledgment ( v string ) * SubmitContainerStateChangeOutput {
s . Acknowledgment = & v
return s
}
type SubmitTaskStateChangeInput struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// Any attachments associated with the state change request.
Attachments [ ] * AttachmentStateChange ` locationName:"attachments" type:"list" `
2017-02-07 22:33:23 +01:00
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the task.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// Any containers associated with the state change request.
Containers [ ] * ContainerStateChange ` locationName:"containers" type:"list" `
2018-05-28 18:52:03 +02:00
// The Unix time stamp for when the task execution stopped.
2018-02-22 14:58:04 +01:00
ExecutionStoppedAt * time . Time ` locationName:"executionStoppedAt" type:"timestamp" timestampFormat:"unix" `
// The Unix time stamp for when the container image pull began.
PullStartedAt * time . Time ` locationName:"pullStartedAt" type:"timestamp" timestampFormat:"unix" `
// The Unix time stamp for when the container image pull completed.
PullStoppedAt * time . Time ` locationName:"pullStoppedAt" type:"timestamp" timestampFormat:"unix" `
2017-02-07 22:33:23 +01:00
// The reason for the state change request.
Reason * string ` locationName:"reason" type:"string" `
// The status of the state change request.
Status * string ` locationName:"status" type:"string" `
2018-02-22 14:58:04 +01:00
// The task ID or full ARN of the task in the state change request.
2017-02-07 22:33:23 +01:00
Task * string ` locationName:"task" type:"string" `
}
// String returns the string representation
func ( s SubmitTaskStateChangeInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s SubmitTaskStateChangeInput ) GoString ( ) string {
return s . String ( )
}
2018-02-22 14:58:04 +01:00
// Validate inspects the fields of the type to determine if they are valid.
func ( s * SubmitTaskStateChangeInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "SubmitTaskStateChangeInput" }
if s . Attachments != nil {
for i , v := range s . Attachments {
if v == nil {
continue
}
if err := v . Validate ( ) ; err != nil {
invalidParams . AddNested ( fmt . Sprintf ( "%s[%v]" , "Attachments" , i ) , err . ( request . ErrInvalidParams ) )
}
}
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetAttachments sets the Attachments field's value.
func ( s * SubmitTaskStateChangeInput ) SetAttachments ( v [ ] * AttachmentStateChange ) * SubmitTaskStateChangeInput {
s . Attachments = v
return s
}
2017-02-07 22:33:23 +01:00
// SetCluster sets the Cluster field's value.
func ( s * SubmitTaskStateChangeInput ) SetCluster ( v string ) * SubmitTaskStateChangeInput {
s . Cluster = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetContainers sets the Containers field's value.
func ( s * SubmitTaskStateChangeInput ) SetContainers ( v [ ] * ContainerStateChange ) * SubmitTaskStateChangeInput {
s . Containers = v
return s
}
// SetExecutionStoppedAt sets the ExecutionStoppedAt field's value.
func ( s * SubmitTaskStateChangeInput ) SetExecutionStoppedAt ( v time . Time ) * SubmitTaskStateChangeInput {
s . ExecutionStoppedAt = & v
return s
}
// SetPullStartedAt sets the PullStartedAt field's value.
func ( s * SubmitTaskStateChangeInput ) SetPullStartedAt ( v time . Time ) * SubmitTaskStateChangeInput {
s . PullStartedAt = & v
return s
}
// SetPullStoppedAt sets the PullStoppedAt field's value.
func ( s * SubmitTaskStateChangeInput ) SetPullStoppedAt ( v time . Time ) * SubmitTaskStateChangeInput {
s . PullStoppedAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetReason sets the Reason field's value.
func ( s * SubmitTaskStateChangeInput ) SetReason ( v string ) * SubmitTaskStateChangeInput {
s . Reason = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * SubmitTaskStateChangeInput ) SetStatus ( v string ) * SubmitTaskStateChangeInput {
s . Status = & v
return s
}
// SetTask sets the Task field's value.
func ( s * SubmitTaskStateChangeInput ) SetTask ( v string ) * SubmitTaskStateChangeInput {
s . Task = & v
return s
}
type SubmitTaskStateChangeOutput struct {
_ struct { } ` type:"structure" `
// Acknowledgement of the state change.
Acknowledgment * string ` locationName:"acknowledgment" type:"string" `
}
// String returns the string representation
func ( s SubmitTaskStateChangeOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s SubmitTaskStateChangeOutput ) GoString ( ) string {
return s . String ( )
}
// SetAcknowledgment sets the Acknowledgment field's value.
func ( s * SubmitTaskStateChangeOutput ) SetAcknowledgment ( v string ) * SubmitTaskStateChangeOutput {
s . Acknowledgment = & v
return s
}
// Details on a task in a cluster.
type Task struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The Elastic Network Adapter associated with the task if the task uses the
// awsvpc network mode.
Attachments [ ] * Attachment ` locationName:"attachments" type:"list" `
// The ARN of the cluster that hosts the task.
2017-02-07 22:33:23 +01:00
ClusterArn * string ` locationName:"clusterArn" type:"string" `
2018-02-22 14:58:04 +01:00
// The connectivity status of a task.
Connectivity * string ` locationName:"connectivity" type:"string" enum:"Connectivity" `
// The Unix time stamp for when the task last went into CONNECTED status.
ConnectivityAt * time . Time ` locationName:"connectivityAt" type:"timestamp" timestampFormat:"unix" `
// The ARN of the container instances that host the task.
2017-02-07 22:33:23 +01:00
ContainerInstanceArn * string ` locationName:"containerInstanceArn" type:"string" `
// The containers associated with the task.
Containers [ ] * Container ` locationName:"containers" type:"list" `
2018-05-28 18:52:03 +02:00
// The number of CPU units used by the task. It can be expressed as an integer
// using CPU units, for example 1024, or as a string using vCPUs, for example
// 1 vCPU or 1 vcpu, in a task definition but is converted to an integer indicating
// the CPU units when the task definition is registered.
//
// If using the EC2 launch type, this field is optional. Supported values are
// between 128 CPU units (0.125 vCPUs) and 10240 CPU units (10 vCPUs).
//
// If using the Fargate launch type, this field is required and you must use
// one of the following values, which determines your range of supported values
// for the memory parameter:
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB),
// 2048 (2 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072
// (3 GB), 4096 (4 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096
// (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384
// (16 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720
// (30 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
Cpu * string ` locationName:"cpu" type:"string" `
// The Unix time stamp for when the task was created (the task entered the PENDING
2017-02-07 22:33:23 +01:00
// state).
CreatedAt * time . Time ` locationName:"createdAt" type:"timestamp" timestampFormat:"unix" `
// The desired status of the task.
DesiredStatus * string ` locationName:"desiredStatus" type:"string" `
2018-05-28 18:52:03 +02:00
// The Unix time stamp for when the task execution stopped.
2018-02-22 14:58:04 +01:00
ExecutionStoppedAt * time . Time ` locationName:"executionStoppedAt" type:"timestamp" timestampFormat:"unix" `
2017-02-07 22:33:23 +01:00
// The name of the task group associated with the task.
Group * string ` locationName:"group" type:"string" `
2018-05-28 18:52:03 +02:00
// The health status for the task, which is determined by the health of the
// essential containers in the task. If all essential containers in the task
// are reporting as HEALTHY, then the task status also reports as HEALTHY. If
// any essential containers in the task are reporting as UNHEALTHY or UNKNOWN,
// then the task status also reports as UNHEALTHY or UNKNOWN, accordingly.
//
// The Amazon ECS container agent does not monitor or report on Docker health
// checks that are embedded in a container image (such as those specified in
// a parent image or from the image's Dockerfile) and not specified in the container
// definition. Health check parameters that are specified in a container definition
// override any Docker health checks that exist in the container image.
HealthStatus * string ` locationName:"healthStatus" type:"string" enum:"HealthStatus" `
2017-02-07 22:33:23 +01:00
// The last known status of the task.
LastStatus * string ` locationName:"lastStatus" type:"string" `
2018-02-22 14:58:04 +01:00
// The launch type on which your task is running.
LaunchType * string ` locationName:"launchType" type:"string" enum:"LaunchType" `
2018-05-28 18:52:03 +02:00
// The amount of memory (in MiB) used by the task. It can be expressed as an
// integer using MiB, for example 1024, or as a string using GB, for example
// 1GB or 1 GB, in a task definition but is converted to an integer indicating
// the MiB when the task definition is registered.
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// If using the EC2 launch type, this field is optional.
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// If using the Fargate launch type, this field is required and you must use
// one of the following values, which determines your range of supported values
// for the cpu parameter:
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25
// vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values:
// 512 (.5 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168
// (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)
//
// * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) -
// Available cpu values: 2048 (2 vCPU)
//
// * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) -
// Available cpu values: 4096 (4 vCPU)
2018-02-22 14:58:04 +01:00
Memory * string ` locationName:"memory" type:"string" `
2017-02-07 22:33:23 +01:00
// One or more container overrides.
Overrides * TaskOverride ` locationName:"overrides" type:"structure" `
2018-02-22 14:58:04 +01:00
// The platform version on which your task is running. For more information,
// see AWS Fargate Platform Versions (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html)
// in the Amazon Elastic Container Service Developer Guide.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
// The Unix time stamp for when the container image pull began.
PullStartedAt * time . Time ` locationName:"pullStartedAt" type:"timestamp" timestampFormat:"unix" `
// The Unix time stamp for when the container image pull completed.
PullStoppedAt * time . Time ` locationName:"pullStoppedAt" type:"timestamp" timestampFormat:"unix" `
// The Unix time stamp for when the task started (the task transitioned from
2017-02-07 22:33:23 +01:00
// the PENDING state to the RUNNING state).
StartedAt * time . Time ` locationName:"startedAt" type:"timestamp" timestampFormat:"unix" `
// The tag specified when a task is started. If the task is started by an Amazon
// ECS service, then the startedBy parameter contains the deployment ID of the
// service that starts it.
StartedBy * string ` locationName:"startedBy" type:"string" `
2018-02-22 14:58:04 +01:00
// The Unix time stamp for when the task was stopped (the task transitioned
// from the RUNNING state to the STOPPED state).
2017-02-07 22:33:23 +01:00
StoppedAt * time . Time ` locationName:"stoppedAt" type:"timestamp" timestampFormat:"unix" `
// The reason the task was stopped.
StoppedReason * string ` locationName:"stoppedReason" type:"string" `
2018-05-28 18:52:03 +02:00
// The Unix time stamp for when the task will stop (transitions from the RUNNING
// state to STOPPED).
2018-02-22 14:58:04 +01:00
StoppingAt * time . Time ` locationName:"stoppingAt" type:"timestamp" timestampFormat:"unix" `
2017-02-07 22:33:23 +01:00
// The Amazon Resource Name (ARN) of the task.
TaskArn * string ` locationName:"taskArn" type:"string" `
2018-02-22 14:58:04 +01:00
// The ARN of the task definition that creates the task.
2017-02-07 22:33:23 +01:00
TaskDefinitionArn * string ` locationName:"taskDefinitionArn" type:"string" `
// The version counter for the task. Every time a task experiences a change
// that triggers a CloudWatch event, the version counter is incremented. If
2018-02-22 14:58:04 +01:00
// you are replicating your Amazon ECS task state with CloudWatch Events, you
2017-02-07 22:33:23 +01:00
// can compare the version of a task reported by the Amazon ECS APIs with the
2018-02-22 14:58:04 +01:00
// version reported in CloudWatch Events for the task (inside the detail object)
2017-02-07 22:33:23 +01:00
// to verify that the version in your event stream is current.
Version * int64 ` locationName:"version" type:"long" `
}
// String returns the string representation
func ( s Task ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Task ) GoString ( ) string {
return s . String ( )
}
2018-02-22 14:58:04 +01:00
// SetAttachments sets the Attachments field's value.
func ( s * Task ) SetAttachments ( v [ ] * Attachment ) * Task {
s . Attachments = v
return s
}
2017-02-07 22:33:23 +01:00
// SetClusterArn sets the ClusterArn field's value.
func ( s * Task ) SetClusterArn ( v string ) * Task {
s . ClusterArn = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetConnectivity sets the Connectivity field's value.
func ( s * Task ) SetConnectivity ( v string ) * Task {
s . Connectivity = & v
return s
}
// SetConnectivityAt sets the ConnectivityAt field's value.
func ( s * Task ) SetConnectivityAt ( v time . Time ) * Task {
s . ConnectivityAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetContainerInstanceArn sets the ContainerInstanceArn field's value.
func ( s * Task ) SetContainerInstanceArn ( v string ) * Task {
s . ContainerInstanceArn = & v
return s
}
// SetContainers sets the Containers field's value.
func ( s * Task ) SetContainers ( v [ ] * Container ) * Task {
s . Containers = v
return s
}
2018-02-22 14:58:04 +01:00
// SetCpu sets the Cpu field's value.
func ( s * Task ) SetCpu ( v string ) * Task {
s . Cpu = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetCreatedAt sets the CreatedAt field's value.
func ( s * Task ) SetCreatedAt ( v time . Time ) * Task {
s . CreatedAt = & v
return s
}
// SetDesiredStatus sets the DesiredStatus field's value.
func ( s * Task ) SetDesiredStatus ( v string ) * Task {
s . DesiredStatus = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetExecutionStoppedAt sets the ExecutionStoppedAt field's value.
func ( s * Task ) SetExecutionStoppedAt ( v time . Time ) * Task {
s . ExecutionStoppedAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetGroup sets the Group field's value.
func ( s * Task ) SetGroup ( v string ) * Task {
s . Group = & v
return s
}
2018-05-28 18:52:03 +02:00
// SetHealthStatus sets the HealthStatus field's value.
func ( s * Task ) SetHealthStatus ( v string ) * Task {
s . HealthStatus = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetLastStatus sets the LastStatus field's value.
func ( s * Task ) SetLastStatus ( v string ) * Task {
s . LastStatus = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetLaunchType sets the LaunchType field's value.
func ( s * Task ) SetLaunchType ( v string ) * Task {
s . LaunchType = & v
return s
}
// SetMemory sets the Memory field's value.
func ( s * Task ) SetMemory ( v string ) * Task {
s . Memory = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetOverrides sets the Overrides field's value.
func ( s * Task ) SetOverrides ( v * TaskOverride ) * Task {
s . Overrides = v
return s
}
2018-02-22 14:58:04 +01:00
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * Task ) SetPlatformVersion ( v string ) * Task {
s . PlatformVersion = & v
return s
}
// SetPullStartedAt sets the PullStartedAt field's value.
func ( s * Task ) SetPullStartedAt ( v time . Time ) * Task {
s . PullStartedAt = & v
return s
}
// SetPullStoppedAt sets the PullStoppedAt field's value.
func ( s * Task ) SetPullStoppedAt ( v time . Time ) * Task {
s . PullStoppedAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetStartedAt sets the StartedAt field's value.
func ( s * Task ) SetStartedAt ( v time . Time ) * Task {
s . StartedAt = & v
return s
}
// SetStartedBy sets the StartedBy field's value.
func ( s * Task ) SetStartedBy ( v string ) * Task {
s . StartedBy = & v
return s
}
// SetStoppedAt sets the StoppedAt field's value.
func ( s * Task ) SetStoppedAt ( v time . Time ) * Task {
s . StoppedAt = & v
return s
}
// SetStoppedReason sets the StoppedReason field's value.
func ( s * Task ) SetStoppedReason ( v string ) * Task {
s . StoppedReason = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetStoppingAt sets the StoppingAt field's value.
func ( s * Task ) SetStoppingAt ( v time . Time ) * Task {
s . StoppingAt = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetTaskArn sets the TaskArn field's value.
func ( s * Task ) SetTaskArn ( v string ) * Task {
s . TaskArn = & v
return s
}
// SetTaskDefinitionArn sets the TaskDefinitionArn field's value.
func ( s * Task ) SetTaskDefinitionArn ( v string ) * Task {
s . TaskDefinitionArn = & v
return s
}
// SetVersion sets the Version field's value.
func ( s * Task ) SetVersion ( v int64 ) * Task {
s . Version = & v
return s
}
// Details of a task definition.
type TaskDefinition struct {
_ struct { } ` type:"structure" `
2018-02-22 14:58:04 +01:00
// The launch type to use with your task. For more information, see Amazon ECS
// Launch Types (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/launch_types.html)
// in the Amazon Elastic Container Service Developer Guide.
Compatibilities [ ] * string ` locationName:"compatibilities" type:"list" `
2017-02-07 22:33:23 +01:00
// A list of container definitions in JSON format that describe the different
// containers that make up your task. For more information about container definition
// parameters and defaults, see Amazon ECS Task Definitions (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_defintions.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
ContainerDefinitions [ ] * ContainerDefinition ` locationName:"containerDefinitions" type:"list" `
2018-02-22 14:58:04 +01:00
// The number of cpu units used by the task. If using the EC2 launch type, this
// field is optional and any value can be used. If using the Fargate launch
// type, this field is required and you must use one of the following values,
// which determines your range of valid values for the memory parameter:
//
2018-05-28 18:52:03 +02:00
// * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB),
// 2048 (2 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072
// (3 GB), 4096 (4 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096
// (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384
// (16 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720
// (30 GB) in increments of 1024 (1 GB)
2018-02-22 14:58:04 +01:00
Cpu * string ` locationName:"cpu" type:"string" `
// The Amazon Resource Name (ARN) of the task execution role that the Amazon
// ECS container agent and the Docker daemon can assume.
ExecutionRoleArn * string ` locationName:"executionRoleArn" type:"string" `
2017-02-07 22:33:23 +01:00
// The family of your task definition, used as the definition name.
Family * string ` locationName:"family" type:"string" `
2018-02-22 14:58:04 +01:00
// The amount (in MiB) of memory used by the task. If using the EC2 launch type,
// this field is optional and any value can be used. If using the Fargate launch
// type, this field is required and you must use one of the following values,
// which determines your range of valid values for the cpu parameter:
//
2018-05-28 18:52:03 +02:00
// * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25
// vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values:
// 512 (.5 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168
// (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) -
// Available cpu values: 2048 (2 vCPU)
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) -
// Available cpu values: 4096 (4 vCPU)
2018-02-22 14:58:04 +01:00
Memory * string ` locationName:"memory" type:"string" `
2017-02-07 22:33:23 +01:00
// The Docker networking mode to use for the containers in the task. The valid
2018-02-22 14:58:04 +01:00
// values are none, bridge, awsvpc, and host. The default Docker network mode
// is bridge. If using the Fargate launch type, the awsvpc network mode is required.
// If using the EC2 launch type, any network mode can be used. If the network
// mode is set to none, you can't specify port mappings in your container definitions,
// and the task's containers do not have external connectivity. The host and
// awsvpc network modes offer the highest networking performance for containers
// because they use the EC2 network stack instead of the virtualized network
// stack provided by the bridge mode.
//
// With the host and awsvpc network modes, exposed container ports are mapped
// directly to the corresponding host port (for the host network mode) or the
// attached elastic network interface port (for the awsvpc network mode), so
// you cannot take advantage of dynamic host port mappings.
2017-02-07 22:33:23 +01:00
//
2018-02-22 14:58:04 +01:00
// If the network mode is awsvpc, the task is allocated an Elastic Network Interface,
// and you must specify a NetworkConfiguration when you create a service or
// run a task with the task definition. For more information, see Task Networking
// (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
//
// Currently, only the Amazon ECS-optimized AMI, other Amazon Linux variants
// with the ecs-init package, or AWS Fargate infrastructure support the awsvpc
// network mode.
//
// If the network mode is host, you can't run multiple instantiations of the
// same task on a single container instance when port mappings are used.
//
// Docker for Windows uses different network modes than Docker for Linux. When
// you register a task definition with Windows containers, you must not specify
// a network mode. If you use the console to register a task definition with
// Windows containers, you must choose the <default> network mode object.
2017-02-07 22:33:23 +01:00
//
// For more information, see Network settings (https://docs.docker.com/engine/reference/run/#network-settings)
// in the Docker run reference.
NetworkMode * string ` locationName:"networkMode" type:"string" enum:"NetworkMode" `
2018-02-22 14:58:04 +01:00
// An array of placement constraint objects to use for tasks. This field is
// not valid if using the Fargate launch type for your task.
2017-02-07 22:33:23 +01:00
PlacementConstraints [ ] * TaskDefinitionPlacementConstraint ` locationName:"placementConstraints" type:"list" `
2018-02-22 14:58:04 +01:00
// The container instance attributes required by your task. This field is not
// valid if using the Fargate launch type for your task.
2017-02-07 22:33:23 +01:00
RequiresAttributes [ ] * Attribute ` locationName:"requiresAttributes" type:"list" `
2018-02-22 14:58:04 +01:00
// The launch type the task is using.
RequiresCompatibilities [ ] * string ` locationName:"requiresCompatibilities" type:"list" `
2017-02-07 22:33:23 +01:00
// The revision of the task in a particular family. The revision is a version
// number of a task definition in a family. When you register a task definition
// for the first time, the revision is 1; each time you register a new revision
// of a task definition in the same family, the revision value always increases
// by one (even if you have deregistered previous revisions in this family).
Revision * int64 ` locationName:"revision" type:"integer" `
// The status of the task definition.
Status * string ` locationName:"status" type:"string" enum:"TaskDefinitionStatus" `
// The full Amazon Resource Name (ARN) of the task definition.
TaskDefinitionArn * string ` locationName:"taskDefinitionArn" type:"string" `
2018-02-22 14:58:04 +01:00
// The ARN of the IAM role that containers in this task can assume. All containers
// in this task are granted the permissions that are specified in this role.
//
// IAM roles for tasks on Windows require that the -EnableTaskIAMRole option
// is set when you launch the Amazon ECS-optimized Windows AMI. Your containers
// must also run some configuration code in order to take advantage of the feature.
// For more information, see Windows IAM Roles for Tasks (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/windows_task_IAM_roles.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
TaskRoleArn * string ` locationName:"taskRoleArn" type:"string" `
2018-02-22 14:58:04 +01:00
// The list of volumes in a task.
//
// If you are using the Fargate launch type, the host and sourcePath parameters
// are not supported.
//
// For more information about volume definition parameters and defaults, see
// Amazon ECS Task Definitions (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definitions.html)
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Volumes [ ] * Volume ` locationName:"volumes" type:"list" `
}
// String returns the string representation
func ( s TaskDefinition ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s TaskDefinition ) GoString ( ) string {
return s . String ( )
}
2018-02-22 14:58:04 +01:00
// SetCompatibilities sets the Compatibilities field's value.
func ( s * TaskDefinition ) SetCompatibilities ( v [ ] * string ) * TaskDefinition {
s . Compatibilities = v
return s
}
2017-02-07 22:33:23 +01:00
// SetContainerDefinitions sets the ContainerDefinitions field's value.
func ( s * TaskDefinition ) SetContainerDefinitions ( v [ ] * ContainerDefinition ) * TaskDefinition {
s . ContainerDefinitions = v
return s
}
2018-02-22 14:58:04 +01:00
// SetCpu sets the Cpu field's value.
func ( s * TaskDefinition ) SetCpu ( v string ) * TaskDefinition {
s . Cpu = & v
return s
}
// SetExecutionRoleArn sets the ExecutionRoleArn field's value.
func ( s * TaskDefinition ) SetExecutionRoleArn ( v string ) * TaskDefinition {
s . ExecutionRoleArn = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetFamily sets the Family field's value.
func ( s * TaskDefinition ) SetFamily ( v string ) * TaskDefinition {
s . Family = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetMemory sets the Memory field's value.
func ( s * TaskDefinition ) SetMemory ( v string ) * TaskDefinition {
s . Memory = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetNetworkMode sets the NetworkMode field's value.
func ( s * TaskDefinition ) SetNetworkMode ( v string ) * TaskDefinition {
s . NetworkMode = & v
return s
}
// SetPlacementConstraints sets the PlacementConstraints field's value.
func ( s * TaskDefinition ) SetPlacementConstraints ( v [ ] * TaskDefinitionPlacementConstraint ) * TaskDefinition {
s . PlacementConstraints = v
return s
}
// SetRequiresAttributes sets the RequiresAttributes field's value.
func ( s * TaskDefinition ) SetRequiresAttributes ( v [ ] * Attribute ) * TaskDefinition {
s . RequiresAttributes = v
return s
}
2018-02-22 14:58:04 +01:00
// SetRequiresCompatibilities sets the RequiresCompatibilities field's value.
func ( s * TaskDefinition ) SetRequiresCompatibilities ( v [ ] * string ) * TaskDefinition {
s . RequiresCompatibilities = v
return s
}
2017-02-07 22:33:23 +01:00
// SetRevision sets the Revision field's value.
func ( s * TaskDefinition ) SetRevision ( v int64 ) * TaskDefinition {
s . Revision = & v
return s
}
// SetStatus sets the Status field's value.
func ( s * TaskDefinition ) SetStatus ( v string ) * TaskDefinition {
s . Status = & v
return s
}
// SetTaskDefinitionArn sets the TaskDefinitionArn field's value.
func ( s * TaskDefinition ) SetTaskDefinitionArn ( v string ) * TaskDefinition {
s . TaskDefinitionArn = & v
return s
}
// SetTaskRoleArn sets the TaskRoleArn field's value.
func ( s * TaskDefinition ) SetTaskRoleArn ( v string ) * TaskDefinition {
s . TaskRoleArn = & v
return s
}
// SetVolumes sets the Volumes field's value.
func ( s * TaskDefinition ) SetVolumes ( v [ ] * Volume ) * TaskDefinition {
s . Volumes = v
return s
}
// An object representing a constraint on task placement in the task definition.
2018-02-22 14:58:04 +01:00
//
2018-05-28 18:52:03 +02:00
// If you are using the Fargate launch type, task placement constraints are
// not supported.
2018-02-22 14:58:04 +01:00
//
2017-02-07 22:33:23 +01:00
// For more information, see Task Placement Constraints (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
type TaskDefinitionPlacementConstraint struct {
_ struct { } ` type:"structure" `
// A cluster query language expression to apply to the constraint. For more
// information, see Cluster Query Language (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/cluster-query-language.html)
2018-02-22 14:58:04 +01:00
// in the Amazon Elastic Container Service Developer Guide.
2017-02-07 22:33:23 +01:00
Expression * string ` locationName:"expression" type:"string" `
// The type of constraint. The DistinctInstance constraint ensures that each
// task in a particular group is running on a different container instance.
// The MemberOf constraint restricts selection to be from a group of valid candidates.
Type * string ` locationName:"type" type:"string" enum:"TaskDefinitionPlacementConstraintType" `
}
// String returns the string representation
func ( s TaskDefinitionPlacementConstraint ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s TaskDefinitionPlacementConstraint ) GoString ( ) string {
return s . String ( )
}
// SetExpression sets the Expression field's value.
func ( s * TaskDefinitionPlacementConstraint ) SetExpression ( v string ) * TaskDefinitionPlacementConstraint {
s . Expression = & v
return s
}
// SetType sets the Type field's value.
func ( s * TaskDefinitionPlacementConstraint ) SetType ( v string ) * TaskDefinitionPlacementConstraint {
s . Type = & v
return s
}
// The overrides associated with a task.
type TaskOverride struct {
_ struct { } ` type:"structure" `
// One or more container overrides sent to a task.
ContainerOverrides [ ] * ContainerOverride ` locationName:"containerOverrides" type:"list" `
2018-02-22 14:58:04 +01:00
// The Amazon Resource Name (ARN) of the task execution role that the Amazon
// ECS container agent and the Docker daemon can assume.
ExecutionRoleArn * string ` locationName:"executionRoleArn" type:"string" `
2017-02-07 22:33:23 +01:00
// The Amazon Resource Name (ARN) of the IAM role that containers in this task
// can assume. All containers in this task are granted the permissions that
// are specified in this role.
TaskRoleArn * string ` locationName:"taskRoleArn" type:"string" `
}
// String returns the string representation
func ( s TaskOverride ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s TaskOverride ) GoString ( ) string {
return s . String ( )
}
// SetContainerOverrides sets the ContainerOverrides field's value.
func ( s * TaskOverride ) SetContainerOverrides ( v [ ] * ContainerOverride ) * TaskOverride {
s . ContainerOverrides = v
return s
}
2018-02-22 14:58:04 +01:00
// SetExecutionRoleArn sets the ExecutionRoleArn field's value.
func ( s * TaskOverride ) SetExecutionRoleArn ( v string ) * TaskOverride {
s . ExecutionRoleArn = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetTaskRoleArn sets the TaskRoleArn field's value.
func ( s * TaskOverride ) SetTaskRoleArn ( v string ) * TaskOverride {
s . TaskRoleArn = & v
return s
}
2018-05-28 18:52:03 +02:00
// The container path, mount options, and size of the tmpfs mount.
type Tmpfs struct {
_ struct { } ` type:"structure" `
// The absolute file path where the tmpfs volume will be mounted.
//
// ContainerPath is a required field
ContainerPath * string ` locationName:"containerPath" type:"string" required:"true" `
// The list of tmpfs volume mount options.
//
// Valid values: "defaults" | "ro" | "rw" | "suid" | "nosuid" | "dev" | "nodev"
// | "exec" | "noexec" | "sync" | "async" | "dirsync" | "remount" | "mand" |
// "nomand" | "atime" | "noatime" | "diratime" | "nodiratime" | "bind" | "rbind"
// | "unbindable" | "runbindable" | "private" | "rprivate" | "shared" | "rshared"
// | "slave" | "rslave" | "relatime" | "norelatime" | "strictatime" | "nostrictatime"
MountOptions [ ] * string ` locationName:"mountOptions" type:"list" `
// The size (in MiB) of the tmpfs volume.
//
// Size is a required field
Size * int64 ` locationName:"size" type:"integer" required:"true" `
}
// String returns the string representation
func ( s Tmpfs ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Tmpfs ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * Tmpfs ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "Tmpfs" }
if s . ContainerPath == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerPath" ) )
}
if s . Size == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Size" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetContainerPath sets the ContainerPath field's value.
func ( s * Tmpfs ) SetContainerPath ( v string ) * Tmpfs {
s . ContainerPath = & v
return s
}
// SetMountOptions sets the MountOptions field's value.
func ( s * Tmpfs ) SetMountOptions ( v [ ] * string ) * Tmpfs {
s . MountOptions = v
return s
}
// SetSize sets the Size field's value.
func ( s * Tmpfs ) SetSize ( v int64 ) * Tmpfs {
s . Size = & v
return s
}
2017-02-07 22:33:23 +01:00
// The ulimit settings to pass to the container.
type Ulimit struct {
_ struct { } ` type:"structure" `
// The hard limit for the ulimit type.
//
// HardLimit is a required field
HardLimit * int64 ` locationName:"hardLimit" type:"integer" required:"true" `
// The type of the ulimit.
//
// Name is a required field
Name * string ` locationName:"name" type:"string" required:"true" enum:"UlimitName" `
// The soft limit for the ulimit type.
//
// SoftLimit is a required field
SoftLimit * int64 ` locationName:"softLimit" type:"integer" required:"true" `
}
// String returns the string representation
func ( s Ulimit ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Ulimit ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * Ulimit ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "Ulimit" }
if s . HardLimit == nil {
invalidParams . Add ( request . NewErrParamRequired ( "HardLimit" ) )
}
if s . Name == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Name" ) )
}
if s . SoftLimit == nil {
invalidParams . Add ( request . NewErrParamRequired ( "SoftLimit" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetHardLimit sets the HardLimit field's value.
func ( s * Ulimit ) SetHardLimit ( v int64 ) * Ulimit {
s . HardLimit = & v
return s
}
// SetName sets the Name field's value.
func ( s * Ulimit ) SetName ( v string ) * Ulimit {
s . Name = & v
return s
}
// SetSoftLimit sets the SoftLimit field's value.
func ( s * Ulimit ) SetSoftLimit ( v int64 ) * Ulimit {
s . SoftLimit = & v
return s
}
type UpdateContainerAgentInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that your
// container instance is running on. If you do not specify a cluster, the default
// cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// The container instance ID or full ARN entries for the container instance
// on which you would like to update the Amazon ECS container agent.
2017-02-07 22:33:23 +01:00
//
// ContainerInstance is a required field
ContainerInstance * string ` locationName:"containerInstance" type:"string" required:"true" `
}
// String returns the string representation
func ( s UpdateContainerAgentInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateContainerAgentInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * UpdateContainerAgentInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "UpdateContainerAgentInput" }
if s . ContainerInstance == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerInstance" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * UpdateContainerAgentInput ) SetCluster ( v string ) * UpdateContainerAgentInput {
s . Cluster = & v
return s
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * UpdateContainerAgentInput ) SetContainerInstance ( v string ) * UpdateContainerAgentInput {
s . ContainerInstance = & v
return s
}
type UpdateContainerAgentOutput struct {
_ struct { } ` type:"structure" `
// The container instance for which the container agent was updated.
ContainerInstance * ContainerInstance ` locationName:"containerInstance" type:"structure" `
}
// String returns the string representation
func ( s UpdateContainerAgentOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateContainerAgentOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstance sets the ContainerInstance field's value.
func ( s * UpdateContainerAgentOutput ) SetContainerInstance ( v * ContainerInstance ) * UpdateContainerAgentOutput {
s . ContainerInstance = v
return s
}
type UpdateContainerInstancesStateInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that hosts
// the container instance to update. If you do not specify a cluster, the default
// cluster is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
2018-02-22 14:58:04 +01:00
// A list of container instance IDs or full ARN entries.
2017-02-07 22:33:23 +01:00
//
// ContainerInstances is a required field
ContainerInstances [ ] * string ` locationName:"containerInstances" type:"list" required:"true" `
// The container instance state with which to update the container instance.
//
// Status is a required field
Status * string ` locationName:"status" type:"string" required:"true" enum:"ContainerInstanceStatus" `
}
// String returns the string representation
func ( s UpdateContainerInstancesStateInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateContainerInstancesStateInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * UpdateContainerInstancesStateInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "UpdateContainerInstancesStateInput" }
if s . ContainerInstances == nil {
invalidParams . Add ( request . NewErrParamRequired ( "ContainerInstances" ) )
}
if s . Status == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Status" ) )
}
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * UpdateContainerInstancesStateInput ) SetCluster ( v string ) * UpdateContainerInstancesStateInput {
s . Cluster = & v
return s
}
// SetContainerInstances sets the ContainerInstances field's value.
func ( s * UpdateContainerInstancesStateInput ) SetContainerInstances ( v [ ] * string ) * UpdateContainerInstancesStateInput {
s . ContainerInstances = v
return s
}
// SetStatus sets the Status field's value.
func ( s * UpdateContainerInstancesStateInput ) SetStatus ( v string ) * UpdateContainerInstancesStateInput {
s . Status = & v
return s
}
type UpdateContainerInstancesStateOutput struct {
_ struct { } ` type:"structure" `
// The list of container instances.
ContainerInstances [ ] * ContainerInstance ` locationName:"containerInstances" type:"list" `
// Any failures associated with the call.
Failures [ ] * Failure ` locationName:"failures" type:"list" `
}
// String returns the string representation
func ( s UpdateContainerInstancesStateOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateContainerInstancesStateOutput ) GoString ( ) string {
return s . String ( )
}
// SetContainerInstances sets the ContainerInstances field's value.
func ( s * UpdateContainerInstancesStateOutput ) SetContainerInstances ( v [ ] * ContainerInstance ) * UpdateContainerInstancesStateOutput {
s . ContainerInstances = v
return s
}
// SetFailures sets the Failures field's value.
func ( s * UpdateContainerInstancesStateOutput ) SetFailures ( v [ ] * Failure ) * UpdateContainerInstancesStateOutput {
s . Failures = v
return s
}
type UpdateServiceInput struct {
_ struct { } ` type:"structure" `
// The short name or full Amazon Resource Name (ARN) of the cluster that your
// service is running on. If you do not specify a cluster, the default cluster
// is assumed.
Cluster * string ` locationName:"cluster" type:"string" `
// Optional deployment parameters that control how many tasks run during the
// deployment and the ordering of stopping and starting tasks.
DeploymentConfiguration * DeploymentConfiguration ` locationName:"deploymentConfiguration" type:"structure" `
// The number of instantiations of the task to place and keep running in your
// service.
DesiredCount * int64 ` locationName:"desiredCount" type:"integer" `
2018-05-28 18:52:03 +02:00
// Whether to force a new deployment of the service. Deployments are not forced
// by default. You can use this option to trigger a new deployment with no service
// definition changes. For example, you can update a service's tasks to use
// a newer Docker image with the same image/tag combination (my_image:latest)
// or to roll Fargate tasks onto a newer platform version.
2018-02-22 14:58:04 +01:00
ForceNewDeployment * bool ` locationName:"forceNewDeployment" type:"boolean" `
// The period of time, in seconds, that the Amazon ECS service scheduler should
// ignore unhealthy Elastic Load Balancing target health checks after a task
// has first started. This is only valid if your service is configured to use
// a load balancer. If your service's tasks take a while to start and respond
2018-05-28 18:52:03 +02:00
// to Elastic Load Balancing health checks, you can specify a health check grace
// period of up to 1,800 seconds during which the ECS service scheduler ignores
// the Elastic Load Balancing health check status. This grace period can prevent
// the ECS service scheduler from marking tasks as unhealthy and stopping them
// before they have time to come up.
2018-02-22 14:58:04 +01:00
HealthCheckGracePeriodSeconds * int64 ` locationName:"healthCheckGracePeriodSeconds" type:"integer" `
// The network configuration for the service. This parameter is required for
2018-05-28 18:52:03 +02:00
// task definitions that use the awsvpc network mode to receive their own elastic
// network interface, and it is not supported for other network modes. For more
2018-02-22 14:58:04 +01:00
// information, see Task Networking (http://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html)
// in the Amazon Elastic Container Service Developer Guide.
//
// Updating a service to add a subnet to a list of existing subnets does not
// trigger a service deployment. For example, if your network configuration
// change is to keep the existing subnets and simply add another subnet to the
// network configuration, this does not trigger a new service deployment.
NetworkConfiguration * NetworkConfiguration ` locationName:"networkConfiguration" type:"structure" `
// The platform version you want to update your service to run.
PlatformVersion * string ` locationName:"platformVersion" type:"string" `
2017-02-07 22:33:23 +01:00
// The name of the service to update.
//
// Service is a required field
Service * string ` locationName:"service" type:"string" required:"true" `
2018-02-22 14:58:04 +01:00
// The family and revision (family:revision) or full ARN of the task definition
// to run in your service. If a revision is not specified, the latest ACTIVE
// revision is used. If you modify the task definition with UpdateService, Amazon
// ECS spawns a task with the new version of the task definition and then stops
// an old task after the new version is running.
2017-02-07 22:33:23 +01:00
TaskDefinition * string ` locationName:"taskDefinition" type:"string" `
}
// String returns the string representation
func ( s UpdateServiceInput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateServiceInput ) GoString ( ) string {
return s . String ( )
}
// Validate inspects the fields of the type to determine if they are valid.
func ( s * UpdateServiceInput ) Validate ( ) error {
invalidParams := request . ErrInvalidParams { Context : "UpdateServiceInput" }
if s . Service == nil {
invalidParams . Add ( request . NewErrParamRequired ( "Service" ) )
}
2018-02-22 14:58:04 +01:00
if s . NetworkConfiguration != nil {
if err := s . NetworkConfiguration . Validate ( ) ; err != nil {
invalidParams . AddNested ( "NetworkConfiguration" , err . ( request . ErrInvalidParams ) )
}
}
2017-02-07 22:33:23 +01:00
if invalidParams . Len ( ) > 0 {
return invalidParams
}
return nil
}
// SetCluster sets the Cluster field's value.
func ( s * UpdateServiceInput ) SetCluster ( v string ) * UpdateServiceInput {
s . Cluster = & v
return s
}
// SetDeploymentConfiguration sets the DeploymentConfiguration field's value.
func ( s * UpdateServiceInput ) SetDeploymentConfiguration ( v * DeploymentConfiguration ) * UpdateServiceInput {
s . DeploymentConfiguration = v
return s
}
// SetDesiredCount sets the DesiredCount field's value.
func ( s * UpdateServiceInput ) SetDesiredCount ( v int64 ) * UpdateServiceInput {
s . DesiredCount = & v
return s
}
2018-02-22 14:58:04 +01:00
// SetForceNewDeployment sets the ForceNewDeployment field's value.
func ( s * UpdateServiceInput ) SetForceNewDeployment ( v bool ) * UpdateServiceInput {
s . ForceNewDeployment = & v
return s
}
// SetHealthCheckGracePeriodSeconds sets the HealthCheckGracePeriodSeconds field's value.
func ( s * UpdateServiceInput ) SetHealthCheckGracePeriodSeconds ( v int64 ) * UpdateServiceInput {
s . HealthCheckGracePeriodSeconds = & v
return s
}
// SetNetworkConfiguration sets the NetworkConfiguration field's value.
func ( s * UpdateServiceInput ) SetNetworkConfiguration ( v * NetworkConfiguration ) * UpdateServiceInput {
s . NetworkConfiguration = v
return s
}
// SetPlatformVersion sets the PlatformVersion field's value.
func ( s * UpdateServiceInput ) SetPlatformVersion ( v string ) * UpdateServiceInput {
s . PlatformVersion = & v
return s
}
2017-02-07 22:33:23 +01:00
// SetService sets the Service field's value.
func ( s * UpdateServiceInput ) SetService ( v string ) * UpdateServiceInput {
s . Service = & v
return s
}
// SetTaskDefinition sets the TaskDefinition field's value.
func ( s * UpdateServiceInput ) SetTaskDefinition ( v string ) * UpdateServiceInput {
s . TaskDefinition = & v
return s
}
type UpdateServiceOutput struct {
_ struct { } ` type:"structure" `
// The full description of your service following the update call.
Service * Service ` locationName:"service" type:"structure" `
}
// String returns the string representation
func ( s UpdateServiceOutput ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s UpdateServiceOutput ) GoString ( ) string {
return s . String ( )
}
// SetService sets the Service field's value.
func ( s * UpdateServiceOutput ) SetService ( v * Service ) * UpdateServiceOutput {
s . Service = v
return s
}
// The Docker and Amazon ECS container agent version information about a container
// instance.
type VersionInfo struct {
_ struct { } ` type:"structure" `
// The Git commit hash for the Amazon ECS container agent build on the amazon-ecs-agent
// (https://github.com/aws/amazon-ecs-agent/commits/master) GitHub repository.
AgentHash * string ` locationName:"agentHash" type:"string" `
// The version number of the Amazon ECS container agent.
AgentVersion * string ` locationName:"agentVersion" type:"string" `
// The Docker version running on the container instance.
DockerVersion * string ` locationName:"dockerVersion" type:"string" `
}
// String returns the string representation
func ( s VersionInfo ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s VersionInfo ) GoString ( ) string {
return s . String ( )
}
// SetAgentHash sets the AgentHash field's value.
func ( s * VersionInfo ) SetAgentHash ( v string ) * VersionInfo {
s . AgentHash = & v
return s
}
// SetAgentVersion sets the AgentVersion field's value.
func ( s * VersionInfo ) SetAgentVersion ( v string ) * VersionInfo {
s . AgentVersion = & v
return s
}
// SetDockerVersion sets the DockerVersion field's value.
func ( s * VersionInfo ) SetDockerVersion ( v string ) * VersionInfo {
s . DockerVersion = & v
return s
}
// A data volume used in a task definition.
type Volume struct {
_ struct { } ` type:"structure" `
// The contents of the host parameter determine whether your data volume persists
// on the host container instance and where it is stored. If the host parameter
// is empty, then the Docker daemon assigns a host path for your data volume,
// but the data is not guaranteed to persist after the containers associated
// with it stop running.
2018-02-22 14:58:04 +01:00
//
// Windows containers can mount whole directories on the same drive as $env:ProgramData.
// Windows containers cannot mount directories on a different drive, and mount
// point cannot be across drives. For example, you can mount C:\my\path:C:\my\path
// and D:\:D:\, but not D:\my\path:C:\my\path or D:\:C:\my\path.
2017-02-07 22:33:23 +01:00
Host * HostVolumeProperties ` locationName:"host" type:"structure" `
// The name of the volume. Up to 255 letters (uppercase and lowercase), numbers,
// hyphens, and underscores are allowed. This name is referenced in the sourceVolume
// parameter of container definition mountPoints.
Name * string ` locationName:"name" type:"string" `
}
// String returns the string representation
func ( s Volume ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s Volume ) GoString ( ) string {
return s . String ( )
}
// SetHost sets the Host field's value.
func ( s * Volume ) SetHost ( v * HostVolumeProperties ) * Volume {
s . Host = v
return s
}
// SetName sets the Name field's value.
func ( s * Volume ) SetName ( v string ) * Volume {
s . Name = & v
return s
}
2018-02-22 14:58:04 +01:00
// Details on a data volume from another container in the same task definition.
2017-02-07 22:33:23 +01:00
type VolumeFrom struct {
_ struct { } ` type:"structure" `
// If this value is true, the container has read-only access to the volume.
// If this value is false, then the container can write to the volume. The default
// value is false.
ReadOnly * bool ` locationName:"readOnly" type:"boolean" `
2018-02-22 14:58:04 +01:00
// The name of another container within the same task definition to mount volumes
// from.
2017-02-07 22:33:23 +01:00
SourceContainer * string ` locationName:"sourceContainer" type:"string" `
}
// String returns the string representation
func ( s VolumeFrom ) String ( ) string {
return awsutil . Prettify ( s )
}
// GoString returns the string representation
func ( s VolumeFrom ) GoString ( ) string {
return s . String ( )
}
// SetReadOnly sets the ReadOnly field's value.
func ( s * VolumeFrom ) SetReadOnly ( v bool ) * VolumeFrom {
s . ReadOnly = & v
return s
}
// SetSourceContainer sets the SourceContainer field's value.
func ( s * VolumeFrom ) SetSourceContainer ( v string ) * VolumeFrom {
s . SourceContainer = & v
return s
}
const (
// AgentUpdateStatusPending is a AgentUpdateStatus enum value
AgentUpdateStatusPending = "PENDING"
// AgentUpdateStatusStaging is a AgentUpdateStatus enum value
AgentUpdateStatusStaging = "STAGING"
// AgentUpdateStatusStaged is a AgentUpdateStatus enum value
AgentUpdateStatusStaged = "STAGED"
// AgentUpdateStatusUpdating is a AgentUpdateStatus enum value
AgentUpdateStatusUpdating = "UPDATING"
// AgentUpdateStatusUpdated is a AgentUpdateStatus enum value
AgentUpdateStatusUpdated = "UPDATED"
// AgentUpdateStatusFailed is a AgentUpdateStatus enum value
AgentUpdateStatusFailed = "FAILED"
)
2018-02-22 14:58:04 +01:00
const (
// AssignPublicIpEnabled is a AssignPublicIp enum value
AssignPublicIpEnabled = "ENABLED"
// AssignPublicIpDisabled is a AssignPublicIp enum value
AssignPublicIpDisabled = "DISABLED"
)
const (
// ClusterFieldStatistics is a ClusterField enum value
ClusterFieldStatistics = "STATISTICS"
)
const (
// CompatibilityEc2 is a Compatibility enum value
CompatibilityEc2 = "EC2"
// CompatibilityFargate is a Compatibility enum value
CompatibilityFargate = "FARGATE"
)
const (
// ConnectivityConnected is a Connectivity enum value
ConnectivityConnected = "CONNECTED"
// ConnectivityDisconnected is a Connectivity enum value
ConnectivityDisconnected = "DISCONNECTED"
)
2017-02-07 22:33:23 +01:00
const (
// ContainerInstanceStatusActive is a ContainerInstanceStatus enum value
ContainerInstanceStatusActive = "ACTIVE"
// ContainerInstanceStatusDraining is a ContainerInstanceStatus enum value
ContainerInstanceStatusDraining = "DRAINING"
)
const (
// DesiredStatusRunning is a DesiredStatus enum value
DesiredStatusRunning = "RUNNING"
// DesiredStatusPending is a DesiredStatus enum value
DesiredStatusPending = "PENDING"
// DesiredStatusStopped is a DesiredStatus enum value
DesiredStatusStopped = "STOPPED"
)
2018-02-22 14:58:04 +01:00
const (
// DeviceCgroupPermissionRead is a DeviceCgroupPermission enum value
DeviceCgroupPermissionRead = "read"
// DeviceCgroupPermissionWrite is a DeviceCgroupPermission enum value
DeviceCgroupPermissionWrite = "write"
// DeviceCgroupPermissionMknod is a DeviceCgroupPermission enum value
DeviceCgroupPermissionMknod = "mknod"
)
2018-05-28 18:52:03 +02:00
const (
// HealthStatusHealthy is a HealthStatus enum value
HealthStatusHealthy = "HEALTHY"
// HealthStatusUnhealthy is a HealthStatus enum value
HealthStatusUnhealthy = "UNHEALTHY"
// HealthStatusUnknown is a HealthStatus enum value
HealthStatusUnknown = "UNKNOWN"
)
2018-02-22 14:58:04 +01:00
const (
// LaunchTypeEc2 is a LaunchType enum value
LaunchTypeEc2 = "EC2"
// LaunchTypeFargate is a LaunchType enum value
LaunchTypeFargate = "FARGATE"
)
2017-02-07 22:33:23 +01:00
const (
// LogDriverJsonFile is a LogDriver enum value
LogDriverJsonFile = "json-file"
// LogDriverSyslog is a LogDriver enum value
LogDriverSyslog = "syslog"
// LogDriverJournald is a LogDriver enum value
LogDriverJournald = "journald"
// LogDriverGelf is a LogDriver enum value
LogDriverGelf = "gelf"
// LogDriverFluentd is a LogDriver enum value
LogDriverFluentd = "fluentd"
// LogDriverAwslogs is a LogDriver enum value
LogDriverAwslogs = "awslogs"
// LogDriverSplunk is a LogDriver enum value
LogDriverSplunk = "splunk"
)
const (
// NetworkModeBridge is a NetworkMode enum value
NetworkModeBridge = "bridge"
// NetworkModeHost is a NetworkMode enum value
NetworkModeHost = "host"
2018-02-22 14:58:04 +01:00
// NetworkModeAwsvpc is a NetworkMode enum value
NetworkModeAwsvpc = "awsvpc"
2017-02-07 22:33:23 +01:00
// NetworkModeNone is a NetworkMode enum value
NetworkModeNone = "none"
)
const (
// PlacementConstraintTypeDistinctInstance is a PlacementConstraintType enum value
PlacementConstraintTypeDistinctInstance = "distinctInstance"
// PlacementConstraintTypeMemberOf is a PlacementConstraintType enum value
PlacementConstraintTypeMemberOf = "memberOf"
)
const (
// PlacementStrategyTypeRandom is a PlacementStrategyType enum value
PlacementStrategyTypeRandom = "random"
// PlacementStrategyTypeSpread is a PlacementStrategyType enum value
PlacementStrategyTypeSpread = "spread"
// PlacementStrategyTypeBinpack is a PlacementStrategyType enum value
PlacementStrategyTypeBinpack = "binpack"
)
const (
// SortOrderAsc is a SortOrder enum value
SortOrderAsc = "ASC"
// SortOrderDesc is a SortOrder enum value
SortOrderDesc = "DESC"
)
const (
// TargetTypeContainerInstance is a TargetType enum value
TargetTypeContainerInstance = "container-instance"
)
const (
// TaskDefinitionFamilyStatusActive is a TaskDefinitionFamilyStatus enum value
TaskDefinitionFamilyStatusActive = "ACTIVE"
// TaskDefinitionFamilyStatusInactive is a TaskDefinitionFamilyStatus enum value
TaskDefinitionFamilyStatusInactive = "INACTIVE"
// TaskDefinitionFamilyStatusAll is a TaskDefinitionFamilyStatus enum value
TaskDefinitionFamilyStatusAll = "ALL"
)
const (
// TaskDefinitionPlacementConstraintTypeMemberOf is a TaskDefinitionPlacementConstraintType enum value
TaskDefinitionPlacementConstraintTypeMemberOf = "memberOf"
)
const (
// TaskDefinitionStatusActive is a TaskDefinitionStatus enum value
TaskDefinitionStatusActive = "ACTIVE"
// TaskDefinitionStatusInactive is a TaskDefinitionStatus enum value
TaskDefinitionStatusInactive = "INACTIVE"
)
const (
// TransportProtocolTcp is a TransportProtocol enum value
TransportProtocolTcp = "tcp"
// TransportProtocolUdp is a TransportProtocol enum value
TransportProtocolUdp = "udp"
)
const (
// UlimitNameCore is a UlimitName enum value
UlimitNameCore = "core"
// UlimitNameCpu is a UlimitName enum value
UlimitNameCpu = "cpu"
// UlimitNameData is a UlimitName enum value
UlimitNameData = "data"
// UlimitNameFsize is a UlimitName enum value
UlimitNameFsize = "fsize"
// UlimitNameLocks is a UlimitName enum value
UlimitNameLocks = "locks"
// UlimitNameMemlock is a UlimitName enum value
UlimitNameMemlock = "memlock"
// UlimitNameMsgqueue is a UlimitName enum value
UlimitNameMsgqueue = "msgqueue"
// UlimitNameNice is a UlimitName enum value
UlimitNameNice = "nice"
// UlimitNameNofile is a UlimitName enum value
UlimitNameNofile = "nofile"
// UlimitNameNproc is a UlimitName enum value
UlimitNameNproc = "nproc"
// UlimitNameRss is a UlimitName enum value
UlimitNameRss = "rss"
// UlimitNameRtprio is a UlimitName enum value
UlimitNameRtprio = "rtprio"
// UlimitNameRttime is a UlimitName enum value
UlimitNameRttime = "rttime"
// UlimitNameSigpending is a UlimitName enum value
UlimitNameSigpending = "sigpending"
// UlimitNameStack is a UlimitName enum value
UlimitNameStack = "stack"
)