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

com.amazonaws.services.appmesh.model.CreateRouteRequest Maven / Gradle / Ivy

/*
 * 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.appmesh.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 CreateRouteRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {

    /**
     * 

* Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 letters, * numbers, hyphens, and underscores are allowed. *

*/ private String clientToken; /** *

* The name of the service mesh to create the route in. *

*/ private String meshName; /** *

* The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then the * account that you specify must share the mesh with your account before you can create the resource in the service * mesh. For more information about mesh sharing, see Working with shared meshes. *

*/ private String meshOwner; /** *

* The name to use for the route. *

*/ private String routeName; /** *

* The route specification to apply. *

*/ private RouteSpec spec; /** *

* Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length * of 128 characters, and tag values can have a maximum length of 256 characters. *

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

* The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, then you * must be the owner of the virtual router resource. *

*/ private String virtualRouterName; /** *

* Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 letters, * numbers, hyphens, and underscores are allowed. *

* * @param clientToken * Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 * letters, numbers, hyphens, and underscores are allowed. */ public void setClientToken(String clientToken) { this.clientToken = clientToken; } /** *

* Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 letters, * numbers, hyphens, and underscores are allowed. *

* * @return Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 * letters, numbers, hyphens, and underscores are allowed. */ public String getClientToken() { return this.clientToken; } /** *

* Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 letters, * numbers, hyphens, and underscores are allowed. *

* * @param clientToken * Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 * letters, numbers, hyphens, and underscores are allowed. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withClientToken(String clientToken) { setClientToken(clientToken); return this; } /** *

* The name of the service mesh to create the route in. *

* * @param meshName * The name of the service mesh to create the route in. */ public void setMeshName(String meshName) { this.meshName = meshName; } /** *

* The name of the service mesh to create the route in. *

* * @return The name of the service mesh to create the route in. */ public String getMeshName() { return this.meshName; } /** *

* The name of the service mesh to create the route in. *

* * @param meshName * The name of the service mesh to create the route in. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withMeshName(String meshName) { setMeshName(meshName); return this; } /** *

* The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then the * account that you specify must share the mesh with your account before you can create the resource in the service * mesh. For more information about mesh sharing, see Working with shared meshes. *

* * @param meshOwner * The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then * the account that you specify must share the mesh with your account before you can create the resource in * the service mesh. For more information about mesh sharing, see Working with shared meshes. */ public void setMeshOwner(String meshOwner) { this.meshOwner = meshOwner; } /** *

* The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then the * account that you specify must share the mesh with your account before you can create the resource in the service * mesh. For more information about mesh sharing, see Working with shared meshes. *

* * @return The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then * the account that you specify must share the mesh with your account before you can create the resource in * the service mesh. For more information about mesh sharing, see Working with shared meshes. */ public String getMeshOwner() { return this.meshOwner; } /** *

* The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then the * account that you specify must share the mesh with your account before you can create the resource in the service * mesh. For more information about mesh sharing, see Working with shared meshes. *

* * @param meshOwner * The Amazon Web Services IAM account ID of the service mesh owner. If the account ID is not your own, then * the account that you specify must share the mesh with your account before you can create the resource in * the service mesh. For more information about mesh sharing, see Working with shared meshes. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withMeshOwner(String meshOwner) { setMeshOwner(meshOwner); return this; } /** *

* The name to use for the route. *

* * @param routeName * The name to use for the route. */ public void setRouteName(String routeName) { this.routeName = routeName; } /** *

* The name to use for the route. *

* * @return The name to use for the route. */ public String getRouteName() { return this.routeName; } /** *

* The name to use for the route. *

* * @param routeName * The name to use for the route. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withRouteName(String routeName) { setRouteName(routeName); return this; } /** *

* The route specification to apply. *

* * @param spec * The route specification to apply. */ public void setSpec(RouteSpec spec) { this.spec = spec; } /** *

* The route specification to apply. *

* * @return The route specification to apply. */ public RouteSpec getSpec() { return this.spec; } /** *

* The route specification to apply. *

* * @param spec * The route specification to apply. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withSpec(RouteSpec spec) { setSpec(spec); return this; } /** *

* Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length * of 128 characters, and tag values can have a maximum length of 256 characters. *

* * @return Optional metadata that you can apply to the route to assist with categorization and organization. Each * tag consists of a key and an optional value, both of which you define. Tag keys can have a maximum * character length of 128 characters, and tag values can have a maximum length of 256 characters. */ public java.util.List getTags() { return tags; } /** *

* Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length * of 128 characters, and tag values can have a maximum length of 256 characters. *

* * @param tags * Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character * length of 128 characters, and tag values can have a maximum length of 256 characters. */ public void setTags(java.util.Collection tags) { if (tags == null) { this.tags = null; return; } this.tags = new java.util.ArrayList(tags); } /** *

* Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length * of 128 characters, and tag values can have a maximum length of 256 characters. *

*

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

* * @param tags * Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character * length of 128 characters, and tag values can have a maximum length of 256 characters. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withTags(TagRef... tags) { if (this.tags == null) { setTags(new java.util.ArrayList(tags.length)); } for (TagRef ele : tags) { this.tags.add(ele); } return this; } /** *

* Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length * of 128 characters, and tag values can have a maximum length of 256 characters. *

* * @param tags * Optional metadata that you can apply to the route to assist with categorization and organization. Each tag * consists of a key and an optional value, both of which you define. Tag keys can have a maximum character * length of 128 characters, and tag values can have a maximum length of 256 characters. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withTags(java.util.Collection tags) { setTags(tags); return this; } /** *

* The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, then you * must be the owner of the virtual router resource. *

* * @param virtualRouterName * The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, * then you must be the owner of the virtual router resource. */ public void setVirtualRouterName(String virtualRouterName) { this.virtualRouterName = virtualRouterName; } /** *

* The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, then you * must be the owner of the virtual router resource. *

* * @return The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, * then you must be the owner of the virtual router resource. */ public String getVirtualRouterName() { return this.virtualRouterName; } /** *

* The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, then you * must be the owner of the virtual router resource. *

* * @param virtualRouterName * The name of the virtual router in which to create the route. If the virtual router is in a shared mesh, * then you must be the owner of the virtual router resource. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateRouteRequest withVirtualRouterName(String virtualRouterName) { setVirtualRouterName(virtualRouterName); 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 (getClientToken() != null) sb.append("ClientToken: ").append(getClientToken()).append(","); if (getMeshName() != null) sb.append("MeshName: ").append(getMeshName()).append(","); if (getMeshOwner() != null) sb.append("MeshOwner: ").append(getMeshOwner()).append(","); if (getRouteName() != null) sb.append("RouteName: ").append(getRouteName()).append(","); if (getSpec() != null) sb.append("Spec: ").append(getSpec()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()).append(","); if (getVirtualRouterName() != null) sb.append("VirtualRouterName: ").append(getVirtualRouterName()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateRouteRequest == false) return false; CreateRouteRequest other = (CreateRouteRequest) obj; if (other.getClientToken() == null ^ this.getClientToken() == null) return false; if (other.getClientToken() != null && other.getClientToken().equals(this.getClientToken()) == false) return false; if (other.getMeshName() == null ^ this.getMeshName() == null) return false; if (other.getMeshName() != null && other.getMeshName().equals(this.getMeshName()) == false) return false; if (other.getMeshOwner() == null ^ this.getMeshOwner() == null) return false; if (other.getMeshOwner() != null && other.getMeshOwner().equals(this.getMeshOwner()) == false) return false; if (other.getRouteName() == null ^ this.getRouteName() == null) return false; if (other.getRouteName() != null && other.getRouteName().equals(this.getRouteName()) == false) return false; if (other.getSpec() == null ^ this.getSpec() == null) return false; if (other.getSpec() != null && other.getSpec().equals(this.getSpec()) == false) return false; if (other.getTags() == null ^ this.getTags() == null) return false; if (other.getTags() != null && other.getTags().equals(this.getTags()) == false) return false; if (other.getVirtualRouterName() == null ^ this.getVirtualRouterName() == null) return false; if (other.getVirtualRouterName() != null && other.getVirtualRouterName().equals(this.getVirtualRouterName()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getClientToken() == null) ? 0 : getClientToken().hashCode()); hashCode = prime * hashCode + ((getMeshName() == null) ? 0 : getMeshName().hashCode()); hashCode = prime * hashCode + ((getMeshOwner() == null) ? 0 : getMeshOwner().hashCode()); hashCode = prime * hashCode + ((getRouteName() == null) ? 0 : getRouteName().hashCode()); hashCode = prime * hashCode + ((getSpec() == null) ? 0 : getSpec().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); hashCode = prime * hashCode + ((getVirtualRouterName() == null) ? 0 : getVirtualRouterName().hashCode()); return hashCode; } @Override public CreateRouteRequest clone() { return (CreateRouteRequest) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy