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

com.amazonaws.services.oam.model.CreateLinkRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for CloudWatch Observability Access Manager module holds the client classes that are used for communicating with CloudWatch Observability Access Manager 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.oam.model;

import java.io.Serializable;
import javax.annotation.Generated;

import com.amazonaws.AmazonWebServiceRequest;

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

    /**
     * 

* Specify a friendly human-readable name to use to identify this source account when you are viewing data from it * in the monitoring account. *

*

* You can use a custom label or use the following variables: *

*
    *
  • *

    * $AccountName is the name of the account *

    *
  • *
  • *

    * $AccountEmail is the globally unique email address of the account *

    *
  • *
  • *

    * $AccountEmailNoDomain is the email address of the account without the domain name *

    *
  • *
*/ private String labelTemplate; /** *

* Use this structure to optionally create filters that specify that only some metric namespaces or log groups are * to be shared from the source account to the monitoring account. *

*/ private LinkConfiguration linkConfiguration; /** *

* An array of strings that define which types of data that the source account shares with the monitoring account. *

*/ private java.util.List resourceTypes; /** *

* The ARN of the sink to use to create this link. You can use ListSinks to find the ARNs of * sinks. *

*

* For more information about sinks, see CreateSink. *

*/ private String sinkIdentifier; /** *

* Assigns one or more tags (key-value pairs) to the link. *

*

* Tags can help you organize and categorize your resources. You can also use them to scope user permissions by * granting a user permission to access or change only resources with certain tag values. *

*

* For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. *

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

* Specify a friendly human-readable name to use to identify this source account when you are viewing data from it * in the monitoring account. *

*

* You can use a custom label or use the following variables: *

*
    *
  • *

    * $AccountName is the name of the account *

    *
  • *
  • *

    * $AccountEmail is the globally unique email address of the account *

    *
  • *
  • *

    * $AccountEmailNoDomain is the email address of the account without the domain name *

    *
  • *
* * @param labelTemplate * Specify a friendly human-readable name to use to identify this source account when you are viewing data * from it in the monitoring account.

*

* You can use a custom label or use the following variables: *

*
    *
  • *

    * $AccountName is the name of the account *

    *
  • *
  • *

    * $AccountEmail is the globally unique email address of the account *

    *
  • *
  • *

    * $AccountEmailNoDomain is the email address of the account without the domain name *

    *
  • */ public void setLabelTemplate(String labelTemplate) { this.labelTemplate = labelTemplate; } /** *

    * Specify a friendly human-readable name to use to identify this source account when you are viewing data from it * in the monitoring account. *

    *

    * You can use a custom label or use the following variables: *

    *
      *
    • *

      * $AccountName is the name of the account *

      *
    • *
    • *

      * $AccountEmail is the globally unique email address of the account *

      *
    • *
    • *

      * $AccountEmailNoDomain is the email address of the account without the domain name *

      *
    • *
    * * @return Specify a friendly human-readable name to use to identify this source account when you are viewing data * from it in the monitoring account.

    *

    * You can use a custom label or use the following variables: *

    *
      *
    • *

      * $AccountName is the name of the account *

      *
    • *
    • *

      * $AccountEmail is the globally unique email address of the account *

      *
    • *
    • *

      * $AccountEmailNoDomain is the email address of the account without the domain name *

      *
    • */ public String getLabelTemplate() { return this.labelTemplate; } /** *

      * Specify a friendly human-readable name to use to identify this source account when you are viewing data from it * in the monitoring account. *

      *

      * You can use a custom label or use the following variables: *

      *
        *
      • *

        * $AccountName is the name of the account *

        *
      • *
      • *

        * $AccountEmail is the globally unique email address of the account *

        *
      • *
      • *

        * $AccountEmailNoDomain is the email address of the account without the domain name *

        *
      • *
      * * @param labelTemplate * Specify a friendly human-readable name to use to identify this source account when you are viewing data * from it in the monitoring account.

      *

      * You can use a custom label or use the following variables: *

      *
        *
      • *

        * $AccountName is the name of the account *

        *
      • *
      • *

        * $AccountEmail is the globally unique email address of the account *

        *
      • *
      • *

        * $AccountEmailNoDomain is the email address of the account without the domain name *

        *
      • * @return Returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest withLabelTemplate(String labelTemplate) { setLabelTemplate(labelTemplate); return this; } /** *

        * Use this structure to optionally create filters that specify that only some metric namespaces or log groups are * to be shared from the source account to the monitoring account. *

        * * @param linkConfiguration * Use this structure to optionally create filters that specify that only some metric namespaces or log * groups are to be shared from the source account to the monitoring account. */ public void setLinkConfiguration(LinkConfiguration linkConfiguration) { this.linkConfiguration = linkConfiguration; } /** *

        * Use this structure to optionally create filters that specify that only some metric namespaces or log groups are * to be shared from the source account to the monitoring account. *

        * * @return Use this structure to optionally create filters that specify that only some metric namespaces or log * groups are to be shared from the source account to the monitoring account. */ public LinkConfiguration getLinkConfiguration() { return this.linkConfiguration; } /** *

        * Use this structure to optionally create filters that specify that only some metric namespaces or log groups are * to be shared from the source account to the monitoring account. *

        * * @param linkConfiguration * Use this structure to optionally create filters that specify that only some metric namespaces or log * groups are to be shared from the source account to the monitoring account. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest withLinkConfiguration(LinkConfiguration linkConfiguration) { setLinkConfiguration(linkConfiguration); return this; } /** *

        * An array of strings that define which types of data that the source account shares with the monitoring account. *

        * * @return An array of strings that define which types of data that the source account shares with the monitoring * account. * @see ResourceType */ public java.util.List getResourceTypes() { return resourceTypes; } /** *

        * An array of strings that define which types of data that the source account shares with the monitoring account. *

        * * @param resourceTypes * An array of strings that define which types of data that the source account shares with the monitoring * account. * @see ResourceType */ public void setResourceTypes(java.util.Collection resourceTypes) { if (resourceTypes == null) { this.resourceTypes = null; return; } this.resourceTypes = new java.util.ArrayList(resourceTypes); } /** *

        * An array of strings that define which types of data that the source account shares with the monitoring account. *

        *

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

        * * @param resourceTypes * An array of strings that define which types of data that the source account shares with the monitoring * account. * @return Returns a reference to this object so that method calls can be chained together. * @see ResourceType */ public CreateLinkRequest withResourceTypes(String... resourceTypes) { if (this.resourceTypes == null) { setResourceTypes(new java.util.ArrayList(resourceTypes.length)); } for (String ele : resourceTypes) { this.resourceTypes.add(ele); } return this; } /** *

        * An array of strings that define which types of data that the source account shares with the monitoring account. *

        * * @param resourceTypes * An array of strings that define which types of data that the source account shares with the monitoring * account. * @return Returns a reference to this object so that method calls can be chained together. * @see ResourceType */ public CreateLinkRequest withResourceTypes(java.util.Collection resourceTypes) { setResourceTypes(resourceTypes); return this; } /** *

        * An array of strings that define which types of data that the source account shares with the monitoring account. *

        * * @param resourceTypes * An array of strings that define which types of data that the source account shares with the monitoring * account. * @return Returns a reference to this object so that method calls can be chained together. * @see ResourceType */ public CreateLinkRequest withResourceTypes(ResourceType... resourceTypes) { java.util.ArrayList resourceTypesCopy = new java.util.ArrayList(resourceTypes.length); for (ResourceType value : resourceTypes) { resourceTypesCopy.add(value.toString()); } if (getResourceTypes() == null) { setResourceTypes(resourceTypesCopy); } else { getResourceTypes().addAll(resourceTypesCopy); } return this; } /** *

        * The ARN of the sink to use to create this link. You can use ListSinks to find the ARNs of * sinks. *

        *

        * For more information about sinks, see CreateSink. *

        * * @param sinkIdentifier * The ARN of the sink to use to create this link. You can use ListSinks to find the * ARNs of sinks.

        *

        * For more information about sinks, see CreateSink. */ public void setSinkIdentifier(String sinkIdentifier) { this.sinkIdentifier = sinkIdentifier; } /** *

        * The ARN of the sink to use to create this link. You can use ListSinks to find the ARNs of * sinks. *

        *

        * For more information about sinks, see CreateSink. *

        * * @return The ARN of the sink to use to create this link. You can use ListSinks to find the * ARNs of sinks.

        *

        * For more information about sinks, see CreateSink. */ public String getSinkIdentifier() { return this.sinkIdentifier; } /** *

        * The ARN of the sink to use to create this link. You can use ListSinks to find the ARNs of * sinks. *

        *

        * For more information about sinks, see CreateSink. *

        * * @param sinkIdentifier * The ARN of the sink to use to create this link. You can use ListSinks to find the * ARNs of sinks.

        *

        * For more information about sinks, see CreateSink. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest withSinkIdentifier(String sinkIdentifier) { setSinkIdentifier(sinkIdentifier); return this; } /** *

        * Assigns one or more tags (key-value pairs) to the link. *

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions by * granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. *

        * * @return Assigns one or more tags (key-value pairs) to the link.

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions * by granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. */ public java.util.Map getTags() { return tags; } /** *

        * Assigns one or more tags (key-value pairs) to the link. *

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions by * granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. *

        * * @param tags * Assigns one or more tags (key-value pairs) to the link.

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions * by granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. */ public void setTags(java.util.Map tags) { this.tags = tags; } /** *

        * Assigns one or more tags (key-value pairs) to the link. *

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions by * granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. *

        * * @param tags * Assigns one or more tags (key-value pairs) to the link.

        *

        * Tags can help you organize and categorize your resources. You can also use them to scope user permissions * by granting a user permission to access or change only resources with certain tag values. *

        *

        * For more information about using tags to control access, see Controlling access to Amazon Web * Services resources using tags. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest withTags(java.util.Map tags) { setTags(tags); return this; } /** * Add a single Tags entry * * @see CreateLinkRequest#withTags * @returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest addTagsEntry(String key, String value) { if (null == this.tags) { this.tags = new java.util.HashMap(); } if (this.tags.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.tags.put(key, value); return this; } /** * Removes all the entries added into Tags. * * @return Returns a reference to this object so that method calls can be chained together. */ public CreateLinkRequest clearTagsEntries() { this.tags = 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 (getLabelTemplate() != null) sb.append("LabelTemplate: ").append(getLabelTemplate()).append(","); if (getLinkConfiguration() != null) sb.append("LinkConfiguration: ").append(getLinkConfiguration()).append(","); if (getResourceTypes() != null) sb.append("ResourceTypes: ").append(getResourceTypes()).append(","); if (getSinkIdentifier() != null) sb.append("SinkIdentifier: ").append(getSinkIdentifier()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateLinkRequest == false) return false; CreateLinkRequest other = (CreateLinkRequest) obj; if (other.getLabelTemplate() == null ^ this.getLabelTemplate() == null) return false; if (other.getLabelTemplate() != null && other.getLabelTemplate().equals(this.getLabelTemplate()) == false) return false; if (other.getLinkConfiguration() == null ^ this.getLinkConfiguration() == null) return false; if (other.getLinkConfiguration() != null && other.getLinkConfiguration().equals(this.getLinkConfiguration()) == false) return false; if (other.getResourceTypes() == null ^ this.getResourceTypes() == null) return false; if (other.getResourceTypes() != null && other.getResourceTypes().equals(this.getResourceTypes()) == false) return false; if (other.getSinkIdentifier() == null ^ this.getSinkIdentifier() == null) return false; if (other.getSinkIdentifier() != null && other.getSinkIdentifier().equals(this.getSinkIdentifier()) == false) return false; if (other.getTags() == null ^ this.getTags() == null) return false; if (other.getTags() != null && other.getTags().equals(this.getTags()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getLabelTemplate() == null) ? 0 : getLabelTemplate().hashCode()); hashCode = prime * hashCode + ((getLinkConfiguration() == null) ? 0 : getLinkConfiguration().hashCode()); hashCode = prime * hashCode + ((getResourceTypes() == null) ? 0 : getResourceTypes().hashCode()); hashCode = prime * hashCode + ((getSinkIdentifier() == null) ? 0 : getSinkIdentifier().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); return hashCode; } @Override public CreateLinkRequest clone() { return (CreateLinkRequest) super.clone(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy