All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.ecs.model.ContainerOverride Maven / Gradle / Ivy

Go to download

The AWS Java SDK for the Amazon EC2 Container Service holds the client classes that are used for communicating with the Amazon EC2 Container Service

The newest version!
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.ecs.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* The overrides that are sent to a container. An empty container override can be passed in. An example of an empty * container override is {"containerOverrides": [ ] }. If a non-empty container override is specified, the * name parameter must be included. *

*

* You can use Secrets Manager or Amazon Web Services Systems Manager Parameter Store to store the sensitive data. For * more information, see Retrieve secrets through * environment variables in the Amazon ECS Developer Guide. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class ContainerOverride implements Serializable, Cloneable, StructuredPojo { /** *

* The name of the container that receives the override. This parameter is required if any override is specified. *

*/ private String name; /** *

* The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. *

*/ private com.amazonaws.internal.SdkInternalList command; /** *

* 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. You must also specify a container name. *

*/ private com.amazonaws.internal.SdkInternalList environment; /** *

* A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. *

*/ private com.amazonaws.internal.SdkInternalList environmentFiles; /** *

* 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. *

*/ private Integer cpu; /** *

* 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. *

*/ private Integer memory; /** *

* 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. *

*/ private Integer memoryReservation; /** *

* The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. *

*/ private com.amazonaws.internal.SdkInternalList resourceRequirements; /** *

* The name of the container that receives the override. This parameter is required if any override is specified. *

* * @param name * The name of the container that receives the override. This parameter is required if any override is * specified. */ public void setName(String name) { this.name = name; } /** *

* The name of the container that receives the override. This parameter is required if any override is specified. *

* * @return The name of the container that receives the override. This parameter is required if any override is * specified. */ public String getName() { return this.name; } /** *

* The name of the container that receives the override. This parameter is required if any override is specified. *

* * @param name * The name of the container that receives the override. This parameter is required if any override is * specified. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withName(String name) { setName(name); return this; } /** *

* The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. *

* * @return The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. */ public java.util.List getCommand() { if (command == null) { command = new com.amazonaws.internal.SdkInternalList(); } return command; } /** *

* The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. *

* * @param command * The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. */ public void setCommand(java.util.Collection command) { if (command == null) { this.command = null; return; } this.command = new com.amazonaws.internal.SdkInternalList(command); } /** *

* The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setCommand(java.util.Collection)} or {@link #withCommand(java.util.Collection)} if you want to override * the existing values. *

* * @param command * The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withCommand(String... command) { if (this.command == null) { setCommand(new com.amazonaws.internal.SdkInternalList(command.length)); } for (String ele : command) { this.command.add(ele); } return this; } /** *

* The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. *

* * @param command * The command to send to the container that overrides the default command from the Docker image or the task * definition. You must also specify a container name. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withCommand(java.util.Collection command) { setCommand(command); return this; } /** *

* 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. You must also specify a container name. *

* * @return 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. You must also specify a container name. */ public java.util.List getEnvironment() { if (environment == null) { environment = new com.amazonaws.internal.SdkInternalList(); } return environment; } /** *

* 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. You must also specify a container name. *

* * @param environment * 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. You must also specify a container name. */ public void setEnvironment(java.util.Collection environment) { if (environment == null) { this.environment = null; return; } this.environment = new com.amazonaws.internal.SdkInternalList(environment); } /** *

* 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. You must also specify a container name. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setEnvironment(java.util.Collection)} or {@link #withEnvironment(java.util.Collection)} if you want to * override the existing values. *

* * @param environment * 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. You must also specify a container name. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withEnvironment(KeyValuePair... environment) { if (this.environment == null) { setEnvironment(new com.amazonaws.internal.SdkInternalList(environment.length)); } for (KeyValuePair ele : environment) { this.environment.add(ele); } return this; } /** *

* 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. You must also specify a container name. *

* * @param environment * 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. You must also specify a container name. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withEnvironment(java.util.Collection environment) { setEnvironment(environment); return this; } /** *

* A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. *

* * @return A list of files containing the environment variables to pass to a container, instead of the value from * the container definition. */ public java.util.List getEnvironmentFiles() { if (environmentFiles == null) { environmentFiles = new com.amazonaws.internal.SdkInternalList(); } return environmentFiles; } /** *

* A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. *

* * @param environmentFiles * A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. */ public void setEnvironmentFiles(java.util.Collection environmentFiles) { if (environmentFiles == null) { this.environmentFiles = null; return; } this.environmentFiles = new com.amazonaws.internal.SdkInternalList(environmentFiles); } /** *

* A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setEnvironmentFiles(java.util.Collection)} or {@link #withEnvironmentFiles(java.util.Collection)} if you * want to override the existing values. *

* * @param environmentFiles * A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withEnvironmentFiles(EnvironmentFile... environmentFiles) { if (this.environmentFiles == null) { setEnvironmentFiles(new com.amazonaws.internal.SdkInternalList(environmentFiles.length)); } for (EnvironmentFile ele : environmentFiles) { this.environmentFiles.add(ele); } return this; } /** *

* A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. *

* * @param environmentFiles * A list of files containing the environment variables to pass to a container, instead of the value from the * container definition. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withEnvironmentFiles(java.util.Collection environmentFiles) { setEnvironmentFiles(environmentFiles); return this; } /** *

* 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. *

* * @param cpu * 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. */ public void setCpu(Integer cpu) { this.cpu = cpu; } /** *

* 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. *

* * @return 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. */ public Integer getCpu() { return this.cpu; } /** *

* 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. *

* * @param cpu * 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. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withCpu(Integer cpu) { setCpu(cpu); return this; } /** *

* 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. *

* * @param memory * 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. */ public void setMemory(Integer memory) { this.memory = memory; } /** *

* 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. *

* * @return 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. */ public Integer getMemory() { return this.memory; } /** *

* 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. *

* * @param memory * 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. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withMemory(Integer memory) { setMemory(memory); return this; } /** *

* 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. *

* * @param memoryReservation * 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. */ public void setMemoryReservation(Integer memoryReservation) { this.memoryReservation = memoryReservation; } /** *

* 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. *

* * @return 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. */ public Integer getMemoryReservation() { return this.memoryReservation; } /** *

* 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. *

* * @param memoryReservation * 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. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withMemoryReservation(Integer memoryReservation) { setMemoryReservation(memoryReservation); return this; } /** *

* The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. *

* * @return The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. */ public java.util.List getResourceRequirements() { if (resourceRequirements == null) { resourceRequirements = new com.amazonaws.internal.SdkInternalList(); } return resourceRequirements; } /** *

* The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. *

* * @param resourceRequirements * The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. */ public void setResourceRequirements(java.util.Collection resourceRequirements) { if (resourceRequirements == null) { this.resourceRequirements = null; return; } this.resourceRequirements = new com.amazonaws.internal.SdkInternalList(resourceRequirements); } /** *

* The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setResourceRequirements(java.util.Collection)} or {@link #withResourceRequirements(java.util.Collection)} * if you want to override the existing values. *

* * @param resourceRequirements * The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withResourceRequirements(ResourceRequirement... resourceRequirements) { if (this.resourceRequirements == null) { setResourceRequirements(new com.amazonaws.internal.SdkInternalList(resourceRequirements.length)); } for (ResourceRequirement ele : resourceRequirements) { this.resourceRequirements.add(ele); } return this; } /** *

* The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. *

* * @param resourceRequirements * The type and amount of a resource to assign to a container, instead of the default value from the task * definition. The only supported resource is a GPU. * @return Returns a reference to this object so that method calls can be chained together. */ public ContainerOverride withResourceRequirements(java.util.Collection resourceRequirements) { setResourceRequirements(resourceRequirements); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getName() != null) sb.append("Name: ").append(getName()).append(","); if (getCommand() != null) sb.append("Command: ").append(getCommand()).append(","); if (getEnvironment() != null) sb.append("Environment: ").append(getEnvironment()).append(","); if (getEnvironmentFiles() != null) sb.append("EnvironmentFiles: ").append(getEnvironmentFiles()).append(","); if (getCpu() != null) sb.append("Cpu: ").append(getCpu()).append(","); if (getMemory() != null) sb.append("Memory: ").append(getMemory()).append(","); if (getMemoryReservation() != null) sb.append("MemoryReservation: ").append(getMemoryReservation()).append(","); if (getResourceRequirements() != null) sb.append("ResourceRequirements: ").append(getResourceRequirements()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ContainerOverride == false) return false; ContainerOverride other = (ContainerOverride) obj; if (other.getName() == null ^ this.getName() == null) return false; if (other.getName() != null && other.getName().equals(this.getName()) == false) return false; if (other.getCommand() == null ^ this.getCommand() == null) return false; if (other.getCommand() != null && other.getCommand().equals(this.getCommand()) == false) return false; if (other.getEnvironment() == null ^ this.getEnvironment() == null) return false; if (other.getEnvironment() != null && other.getEnvironment().equals(this.getEnvironment()) == false) return false; if (other.getEnvironmentFiles() == null ^ this.getEnvironmentFiles() == null) return false; if (other.getEnvironmentFiles() != null && other.getEnvironmentFiles().equals(this.getEnvironmentFiles()) == false) return false; if (other.getCpu() == null ^ this.getCpu() == null) return false; if (other.getCpu() != null && other.getCpu().equals(this.getCpu()) == false) return false; if (other.getMemory() == null ^ this.getMemory() == null) return false; if (other.getMemory() != null && other.getMemory().equals(this.getMemory()) == false) return false; if (other.getMemoryReservation() == null ^ this.getMemoryReservation() == null) return false; if (other.getMemoryReservation() != null && other.getMemoryReservation().equals(this.getMemoryReservation()) == false) return false; if (other.getResourceRequirements() == null ^ this.getResourceRequirements() == null) return false; if (other.getResourceRequirements() != null && other.getResourceRequirements().equals(this.getResourceRequirements()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getName() == null) ? 0 : getName().hashCode()); hashCode = prime * hashCode + ((getCommand() == null) ? 0 : getCommand().hashCode()); hashCode = prime * hashCode + ((getEnvironment() == null) ? 0 : getEnvironment().hashCode()); hashCode = prime * hashCode + ((getEnvironmentFiles() == null) ? 0 : getEnvironmentFiles().hashCode()); hashCode = prime * hashCode + ((getCpu() == null) ? 0 : getCpu().hashCode()); hashCode = prime * hashCode + ((getMemory() == null) ? 0 : getMemory().hashCode()); hashCode = prime * hashCode + ((getMemoryReservation() == null) ? 0 : getMemoryReservation().hashCode()); hashCode = prime * hashCode + ((getResourceRequirements() == null) ? 0 : getResourceRequirements().hashCode()); return hashCode; } @Override public ContainerOverride clone() { try { return (ContainerOverride) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.ecs.model.transform.ContainerOverrideMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy