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

com.amazonaws.services.appstream.model.CreateStackRequest Maven / Gradle / Ivy

/*
 * Copyright 2017-2022 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.appstream.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 CreateStackRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {

    /**
     * 

* The name of the stack. *

*/ private String name; /** *

* The description to display. *

*/ private String description; /** *

* The stack name to display. *

*/ private String displayName; /** *

* The storage connectors to enable. *

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

* The URL that users are redirected to after their streaming session ends. *

*/ private String redirectURL; /** *

* The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no Send * Feedback link is displayed. *

*/ private String feedbackURL; /** *

* The actions that are enabled or disabled for users during their streaming sessions. By default, these actions are * enabled. *

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

* The persistent application settings for users of a stack. When these settings are enabled, changes that users * make to applications and Windows settings are automatically saved after each session and applied to the next * session. *

*/ private ApplicationSettings applicationSettings; /** *

* The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=. *

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following special * characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your Resources * in the Amazon AppStream 2.0 Administration Guide. *

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

* The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to AppStream 2.0 * only through the specified endpoints. *

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

* The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the domains * that you want to host embedded AppStream 2.0 streaming sessions. *

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

* The name of the stack. *

* * @param name * The name of the stack. */ public void setName(String name) { this.name = name; } /** *

* The name of the stack. *

* * @return The name of the stack. */ public String getName() { return this.name; } /** *

* The name of the stack. *

* * @param name * The name of the stack. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withName(String name) { setName(name); return this; } /** *

* The description to display. *

* * @param description * The description to display. */ public void setDescription(String description) { this.description = description; } /** *

* The description to display. *

* * @return The description to display. */ public String getDescription() { return this.description; } /** *

* The description to display. *

* * @param description * The description to display. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withDescription(String description) { setDescription(description); return this; } /** *

* The stack name to display. *

* * @param displayName * The stack name to display. */ public void setDisplayName(String displayName) { this.displayName = displayName; } /** *

* The stack name to display. *

* * @return The stack name to display. */ public String getDisplayName() { return this.displayName; } /** *

* The stack name to display. *

* * @param displayName * The stack name to display. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withDisplayName(String displayName) { setDisplayName(displayName); return this; } /** *

* The storage connectors to enable. *

* * @return The storage connectors to enable. */ public java.util.List getStorageConnectors() { return storageConnectors; } /** *

* The storage connectors to enable. *

* * @param storageConnectors * The storage connectors to enable. */ public void setStorageConnectors(java.util.Collection storageConnectors) { if (storageConnectors == null) { this.storageConnectors = null; return; } this.storageConnectors = new java.util.ArrayList(storageConnectors); } /** *

* The storage connectors to enable. *

*

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

* * @param storageConnectors * The storage connectors to enable. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withStorageConnectors(StorageConnector... storageConnectors) { if (this.storageConnectors == null) { setStorageConnectors(new java.util.ArrayList(storageConnectors.length)); } for (StorageConnector ele : storageConnectors) { this.storageConnectors.add(ele); } return this; } /** *

* The storage connectors to enable. *

* * @param storageConnectors * The storage connectors to enable. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withStorageConnectors(java.util.Collection storageConnectors) { setStorageConnectors(storageConnectors); return this; } /** *

* The URL that users are redirected to after their streaming session ends. *

* * @param redirectURL * The URL that users are redirected to after their streaming session ends. */ public void setRedirectURL(String redirectURL) { this.redirectURL = redirectURL; } /** *

* The URL that users are redirected to after their streaming session ends. *

* * @return The URL that users are redirected to after their streaming session ends. */ public String getRedirectURL() { return this.redirectURL; } /** *

* The URL that users are redirected to after their streaming session ends. *

* * @param redirectURL * The URL that users are redirected to after their streaming session ends. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withRedirectURL(String redirectURL) { setRedirectURL(redirectURL); return this; } /** *

* The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no Send * Feedback link is displayed. *

* * @param feedbackURL * The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no * Send Feedback link is displayed. */ public void setFeedbackURL(String feedbackURL) { this.feedbackURL = feedbackURL; } /** *

* The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no Send * Feedback link is displayed. *

* * @return The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no * Send Feedback link is displayed. */ public String getFeedbackURL() { return this.feedbackURL; } /** *

* The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no Send * Feedback link is displayed. *

* * @param feedbackURL * The URL that users are redirected to after they click the Send Feedback link. If no URL is specified, no * Send Feedback link is displayed. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withFeedbackURL(String feedbackURL) { setFeedbackURL(feedbackURL); return this; } /** *

* The actions that are enabled or disabled for users during their streaming sessions. By default, these actions are * enabled. *

* * @return The actions that are enabled or disabled for users during their streaming sessions. By default, these * actions are enabled. */ public java.util.List getUserSettings() { return userSettings; } /** *

* The actions that are enabled or disabled for users during their streaming sessions. By default, these actions are * enabled. *

* * @param userSettings * The actions that are enabled or disabled for users during their streaming sessions. By default, these * actions are enabled. */ public void setUserSettings(java.util.Collection userSettings) { if (userSettings == null) { this.userSettings = null; return; } this.userSettings = new java.util.ArrayList(userSettings); } /** *

* The actions that are enabled or disabled for users during their streaming sessions. By default, these actions are * enabled. *

*

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

* * @param userSettings * The actions that are enabled or disabled for users during their streaming sessions. By default, these * actions are enabled. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withUserSettings(UserSetting... userSettings) { if (this.userSettings == null) { setUserSettings(new java.util.ArrayList(userSettings.length)); } for (UserSetting ele : userSettings) { this.userSettings.add(ele); } return this; } /** *

* The actions that are enabled or disabled for users during their streaming sessions. By default, these actions are * enabled. *

* * @param userSettings * The actions that are enabled or disabled for users during their streaming sessions. By default, these * actions are enabled. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withUserSettings(java.util.Collection userSettings) { setUserSettings(userSettings); return this; } /** *

* The persistent application settings for users of a stack. When these settings are enabled, changes that users * make to applications and Windows settings are automatically saved after each session and applied to the next * session. *

* * @param applicationSettings * The persistent application settings for users of a stack. When these settings are enabled, changes that * users make to applications and Windows settings are automatically saved after each session and applied to * the next session. */ public void setApplicationSettings(ApplicationSettings applicationSettings) { this.applicationSettings = applicationSettings; } /** *

* The persistent application settings for users of a stack. When these settings are enabled, changes that users * make to applications and Windows settings are automatically saved after each session and applied to the next * session. *

* * @return The persistent application settings for users of a stack. When these settings are enabled, changes that * users make to applications and Windows settings are automatically saved after each session and applied to * the next session. */ public ApplicationSettings getApplicationSettings() { return this.applicationSettings; } /** *

* The persistent application settings for users of a stack. When these settings are enabled, changes that users * make to applications and Windows settings are automatically saved after each session and applied to the next * session. *

* * @param applicationSettings * The persistent application settings for users of a stack. When these settings are enabled, changes that * users make to applications and Windows settings are automatically saved after each session and applied to * the next session. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withApplicationSettings(ApplicationSettings applicationSettings) { setApplicationSettings(applicationSettings); return this; } /** *

* The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=. *

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following special * characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your Resources * in the Amazon AppStream 2.0 Administration Guide. *

* * @return The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=.

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following * special characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your * Resources in the Amazon AppStream 2.0 Administration Guide. */ public java.util.Map getTags() { return tags; } /** *

* The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=. *

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following special * characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your Resources * in the Amazon AppStream 2.0 Administration Guide. *

* * @param tags * The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=.

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following * special characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your * Resources in the Amazon AppStream 2.0 Administration Guide. */ public void setTags(java.util.Map tags) { this.tags = tags; } /** *

* The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=. *

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following special * characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your Resources * in the Amazon AppStream 2.0 Administration Guide. *

* * @param tags * The tags to associate with the stack. A tag is a key-value pair, and the value is optional. For example, * Environment=Test. If you do not specify a value, Environment=.

*

* If you do not specify a value, the value is set to an empty string. *

*

* Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following * special characters: *

*

* _ . : / = + \ - @ *

*

* For more information about tags, see Tagging Your * Resources in the Amazon AppStream 2.0 Administration Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withTags(java.util.Map tags) { setTags(tags); return this; } /** * Add a single Tags entry * * @see CreateStackRequest#withTags * @returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest 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 CreateStackRequest clearTagsEntries() { this.tags = null; return this; } /** *

* The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to AppStream 2.0 * only through the specified endpoints. *

* * @return The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to * AppStream 2.0 only through the specified endpoints. */ public java.util.List getAccessEndpoints() { return accessEndpoints; } /** *

* The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to AppStream 2.0 * only through the specified endpoints. *

* * @param accessEndpoints * The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to * AppStream 2.0 only through the specified endpoints. */ public void setAccessEndpoints(java.util.Collection accessEndpoints) { if (accessEndpoints == null) { this.accessEndpoints = null; return; } this.accessEndpoints = new java.util.ArrayList(accessEndpoints); } /** *

* The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to AppStream 2.0 * only through the specified endpoints. *

*

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

* * @param accessEndpoints * The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to * AppStream 2.0 only through the specified endpoints. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withAccessEndpoints(AccessEndpoint... accessEndpoints) { if (this.accessEndpoints == null) { setAccessEndpoints(new java.util.ArrayList(accessEndpoints.length)); } for (AccessEndpoint ele : accessEndpoints) { this.accessEndpoints.add(ele); } return this; } /** *

* The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to AppStream 2.0 * only through the specified endpoints. *

* * @param accessEndpoints * The list of interface VPC endpoint (interface endpoint) objects. Users of the stack can connect to * AppStream 2.0 only through the specified endpoints. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withAccessEndpoints(java.util.Collection accessEndpoints) { setAccessEndpoints(accessEndpoints); return this; } /** *

* The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the domains * that you want to host embedded AppStream 2.0 streaming sessions. *

* * @return The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the * domains that you want to host embedded AppStream 2.0 streaming sessions. */ public java.util.List getEmbedHostDomains() { return embedHostDomains; } /** *

* The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the domains * that you want to host embedded AppStream 2.0 streaming sessions. *

* * @param embedHostDomains * The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the * domains that you want to host embedded AppStream 2.0 streaming sessions. */ public void setEmbedHostDomains(java.util.Collection embedHostDomains) { if (embedHostDomains == null) { this.embedHostDomains = null; return; } this.embedHostDomains = new java.util.ArrayList(embedHostDomains); } /** *

* The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the domains * that you want to host embedded AppStream 2.0 streaming sessions. *

*

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

* * @param embedHostDomains * The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the * domains that you want to host embedded AppStream 2.0 streaming sessions. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withEmbedHostDomains(String... embedHostDomains) { if (this.embedHostDomains == null) { setEmbedHostDomains(new java.util.ArrayList(embedHostDomains.length)); } for (String ele : embedHostDomains) { this.embedHostDomains.add(ele); } return this; } /** *

* The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the domains * that you want to host embedded AppStream 2.0 streaming sessions. *

* * @param embedHostDomains * The domains where AppStream 2.0 streaming sessions can be embedded in an iframe. You must approve the * domains that you want to host embedded AppStream 2.0 streaming sessions. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateStackRequest withEmbedHostDomains(java.util.Collection embedHostDomains) { setEmbedHostDomains(embedHostDomains); 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 (getDescription() != null) sb.append("Description: ").append(getDescription()).append(","); if (getDisplayName() != null) sb.append("DisplayName: ").append(getDisplayName()).append(","); if (getStorageConnectors() != null) sb.append("StorageConnectors: ").append(getStorageConnectors()).append(","); if (getRedirectURL() != null) sb.append("RedirectURL: ").append(getRedirectURL()).append(","); if (getFeedbackURL() != null) sb.append("FeedbackURL: ").append(getFeedbackURL()).append(","); if (getUserSettings() != null) sb.append("UserSettings: ").append(getUserSettings()).append(","); if (getApplicationSettings() != null) sb.append("ApplicationSettings: ").append(getApplicationSettings()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()).append(","); if (getAccessEndpoints() != null) sb.append("AccessEndpoints: ").append(getAccessEndpoints()).append(","); if (getEmbedHostDomains() != null) sb.append("EmbedHostDomains: ").append(getEmbedHostDomains()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateStackRequest == false) return false; CreateStackRequest other = (CreateStackRequest) obj; if (other.getName() == null ^ this.getName() == null) return false; if (other.getName() != null && other.getName().equals(this.getName()) == false) return false; if (other.getDescription() == null ^ this.getDescription() == null) return false; if (other.getDescription() != null && other.getDescription().equals(this.getDescription()) == false) return false; if (other.getDisplayName() == null ^ this.getDisplayName() == null) return false; if (other.getDisplayName() != null && other.getDisplayName().equals(this.getDisplayName()) == false) return false; if (other.getStorageConnectors() == null ^ this.getStorageConnectors() == null) return false; if (other.getStorageConnectors() != null && other.getStorageConnectors().equals(this.getStorageConnectors()) == false) return false; if (other.getRedirectURL() == null ^ this.getRedirectURL() == null) return false; if (other.getRedirectURL() != null && other.getRedirectURL().equals(this.getRedirectURL()) == false) return false; if (other.getFeedbackURL() == null ^ this.getFeedbackURL() == null) return false; if (other.getFeedbackURL() != null && other.getFeedbackURL().equals(this.getFeedbackURL()) == false) return false; if (other.getUserSettings() == null ^ this.getUserSettings() == null) return false; if (other.getUserSettings() != null && other.getUserSettings().equals(this.getUserSettings()) == false) return false; if (other.getApplicationSettings() == null ^ this.getApplicationSettings() == null) return false; if (other.getApplicationSettings() != null && other.getApplicationSettings().equals(this.getApplicationSettings()) == 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.getAccessEndpoints() == null ^ this.getAccessEndpoints() == null) return false; if (other.getAccessEndpoints() != null && other.getAccessEndpoints().equals(this.getAccessEndpoints()) == false) return false; if (other.getEmbedHostDomains() == null ^ this.getEmbedHostDomains() == null) return false; if (other.getEmbedHostDomains() != null && other.getEmbedHostDomains().equals(this.getEmbedHostDomains()) == 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 + ((getDescription() == null) ? 0 : getDescription().hashCode()); hashCode = prime * hashCode + ((getDisplayName() == null) ? 0 : getDisplayName().hashCode()); hashCode = prime * hashCode + ((getStorageConnectors() == null) ? 0 : getStorageConnectors().hashCode()); hashCode = prime * hashCode + ((getRedirectURL() == null) ? 0 : getRedirectURL().hashCode()); hashCode = prime * hashCode + ((getFeedbackURL() == null) ? 0 : getFeedbackURL().hashCode()); hashCode = prime * hashCode + ((getUserSettings() == null) ? 0 : getUserSettings().hashCode()); hashCode = prime * hashCode + ((getApplicationSettings() == null) ? 0 : getApplicationSettings().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); hashCode = prime * hashCode + ((getAccessEndpoints() == null) ? 0 : getAccessEndpoints().hashCode()); hashCode = prime * hashCode + ((getEmbedHostDomains() == null) ? 0 : getEmbedHostDomains().hashCode()); return hashCode; } @Override public CreateStackRequest clone() { return (CreateStackRequest) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy