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

com.amazonaws.services.ecs.model.FirelensConfiguration 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 FireLens configuration for the container. This is used to specify and configure a log router for container logs. * For more information, see Custom log routing in the * Amazon Elastic Container Service Developer Guide. *

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

* The log router to use. The valid values are fluentd or fluentbit. *

*/ private String type; /** *

* The options to use when configuring the log router. This field is optional and can be used to specify a custom * configuration file or to add additional metadata, such as the task, task definition, cluster, and container * instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating * a task definition that uses a FireLens configuration in the Amazon Elastic Container Service Developer * Guide. *

* *

* Tasks hosted on Fargate only support the file configuration file type. *

*
*/ private java.util.Map options; /** *

* The log router to use. The valid values are fluentd or fluentbit. *

* * @param type * The log router to use. The valid values are fluentd or fluentbit. * @see FirelensConfigurationType */ public void setType(String type) { this.type = type; } /** *

* The log router to use. The valid values are fluentd or fluentbit. *

* * @return The log router to use. The valid values are fluentd or fluentbit. * @see FirelensConfigurationType */ public String getType() { return this.type; } /** *

* The log router to use. The valid values are fluentd or fluentbit. *

* * @param type * The log router to use. The valid values are fluentd or fluentbit. * @return Returns a reference to this object so that method calls can be chained together. * @see FirelensConfigurationType */ public FirelensConfiguration withType(String type) { setType(type); return this; } /** *

* The log router to use. The valid values are fluentd or fluentbit. *

* * @param type * The log router to use. The valid values are fluentd or fluentbit. * @return Returns a reference to this object so that method calls can be chained together. * @see FirelensConfigurationType */ public FirelensConfiguration withType(FirelensConfigurationType type) { this.type = type.toString(); return this; } /** *

* The options to use when configuring the log router. This field is optional and can be used to specify a custom * configuration file or to add additional metadata, such as the task, task definition, cluster, and container * instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating * a task definition that uses a FireLens configuration in the Amazon Elastic Container Service Developer * Guide. *

* *

* Tasks hosted on Fargate only support the file configuration file type. *

*
* * @return The options to use when configuring the log router. This field is optional and can be used to specify a * custom configuration file or to add additional metadata, such as the task, task definition, cluster, and * container instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating a task definition that uses a FireLens configuration in the Amazon Elastic Container * Service Developer Guide.

*

* Tasks hosted on Fargate only support the file configuration file type. *

*/ public java.util.Map getOptions() { return options; } /** *

* The options to use when configuring the log router. This field is optional and can be used to specify a custom * configuration file or to add additional metadata, such as the task, task definition, cluster, and container * instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating * a task definition that uses a FireLens configuration in the Amazon Elastic Container Service Developer * Guide. *

* *

* Tasks hosted on Fargate only support the file configuration file type. *

*
* * @param options * The options to use when configuring the log router. This field is optional and can be used to specify a * custom configuration file or to add additional metadata, such as the task, task definition, cluster, and * container instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating a task definition that uses a FireLens configuration in the Amazon Elastic Container * Service Developer Guide.

*

* Tasks hosted on Fargate only support the file configuration file type. *

*/ public void setOptions(java.util.Map options) { this.options = options; } /** *

* The options to use when configuring the log router. This field is optional and can be used to specify a custom * configuration file or to add additional metadata, such as the task, task definition, cluster, and container * instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating * a task definition that uses a FireLens configuration in the Amazon Elastic Container Service Developer * Guide. *

* *

* Tasks hosted on Fargate only support the file configuration file type. *

*
* * @param options * The options to use when configuring the log router. This field is optional and can be used to specify a * custom configuration file or to add additional metadata, such as the task, task definition, cluster, and * container instance details to the log event. If specified, the syntax to use is * "options":{"enable-ecs-log-metadata":"true|false","config-file-type:"s3|file","config-file-value":"arn:aws:s3:::mybucket/fluent.conf|filepath"} * . For more information, see Creating a task definition that uses a FireLens configuration in the Amazon Elastic Container * Service Developer Guide.

*

* Tasks hosted on Fargate only support the file configuration file type. *

* @return Returns a reference to this object so that method calls can be chained together. */ public FirelensConfiguration withOptions(java.util.Map options) { setOptions(options); return this; } /** * Add a single Options entry * * @see FirelensConfiguration#withOptions * @returns a reference to this object so that method calls can be chained together. */ public FirelensConfiguration addOptionsEntry(String key, String value) { if (null == this.options) { this.options = new java.util.HashMap(); } if (this.options.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.options.put(key, value); return this; } /** * Removes all the entries added into Options. * * @return Returns a reference to this object so that method calls can be chained together. */ public FirelensConfiguration clearOptionsEntries() { this.options = null; 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 (getType() != null) sb.append("Type: ").append(getType()).append(","); if (getOptions() != null) sb.append("Options: ").append(getOptions()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof FirelensConfiguration == false) return false; FirelensConfiguration other = (FirelensConfiguration) obj; if (other.getType() == null ^ this.getType() == null) return false; if (other.getType() != null && other.getType().equals(this.getType()) == false) return false; if (other.getOptions() == null ^ this.getOptions() == null) return false; if (other.getOptions() != null && other.getOptions().equals(this.getOptions()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getType() == null) ? 0 : getType().hashCode()); hashCode = prime * hashCode + ((getOptions() == null) ? 0 : getOptions().hashCode()); return hashCode; } @Override public FirelensConfiguration clone() { try { return (FirelensConfiguration) 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.FirelensConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy