stopTask method

Future<StopTaskResponse> stopTask({
  1. required String task,
  2. String? cluster,
  3. String? reason,
})

Stops a running task. Any tags associated with the task will be deleted.

When StopTask is called on a task, the equivalent of docker stop is issued to the containers running in the task. This results in a SIGTERM value and a default 30-second timeout, after which the SIGKILL value is sent and the containers are forcibly stopped. If the container handles the SIGTERM value gracefully and exits within 30 seconds from receiving it, no SIGKILL value is sent.

May throw ServerException. May throw ClientException. May throw InvalidParameterException. May throw ClusterNotFoundException.

Parameter task : The task ID or full Amazon Resource Name (ARN) of the task to stop.

Parameter cluster : 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.

Parameter reason : 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 for stopping the task here, and the message appears in subsequent DescribeTasks API operations on this task. Up to 255 characters are allowed in this message.

Implementation

Future<StopTaskResponse> stopTask({
  required String task,
  String? cluster,
  String? reason,
}) async {
  ArgumentError.checkNotNull(task, 'task');
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target': 'AmazonEC2ContainerServiceV20141113.StopTask'
  };
  final jsonResponse = await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'task': task,
      if (cluster != null) 'cluster': cluster,
      if (reason != null) 'reason': reason,
    },
  );

  return StopTaskResponse.fromJson(jsonResponse.body);
}