/* * Copyright 2018-2023 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.pinpoint.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* Specifies the default settings and content for a message template that can be used in messages that are sent through * a push notification channel. *
* * @see AWS API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class DefaultPushNotificationTemplate implements Serializable, Cloneable, StructuredPojo { /** ** The action to occur if a recipient taps a push notification that's based on the message template. Valid values * are: *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the default * action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** The message body to use in push notifications that are based on the message template. *
*/ private String body; /** ** The sound to play when a recipient receives a push notification that's based on the message template. You can use * the default stream or specify the file name of a sound resource that's bundled in your app. On an Android * platform, the sound file must reside in /res/raw/. *
** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify default for * the value, the system plays the default alert sound. *
*/ private String sound; /** ** The title to use in push notifications that are based on the message template. This title appears above the * notification message on a recipient's device. *
*/ private String title; /** ** The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's based on * the message template and the value of the Action property is URL. *
*/ private String url; /** ** The action to occur if a recipient taps a push notification that's based on the message template. Valid values * are: *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the default * action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the * default action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** The action to occur if a recipient taps a push notification that's based on the message template. Valid values * are: *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the default * action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the * default action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** The action to occur if a recipient taps a push notification that's based on the message template. Valid values * are: *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the default * action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the * default action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** The action to occur if a recipient taps a push notification that's based on the message template. Valid values * are: *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the default * action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** OPEN_APP - Your app opens or it becomes the foreground app if it was sent to the background. This is the * default action. *
** DEEP_LINK - Your app opens and displays a designated user interface in the app. This setting uses the * deep-linking features of the iOS and Android platforms. *
** URL - The default mobile browser on the recipient's device opens and loads the web page at a URL that you * specify. *
** The message body to use in push notifications that are based on the message template. *
* * @param body * The message body to use in push notifications that are based on the message template. */ public void setBody(String body) { this.body = body; } /** ** The message body to use in push notifications that are based on the message template. *
* * @return The message body to use in push notifications that are based on the message template. */ public String getBody() { return this.body; } /** ** The message body to use in push notifications that are based on the message template. *
* * @param body * The message body to use in push notifications that are based on the message template. * @return Returns a reference to this object so that method calls can be chained together. */ public DefaultPushNotificationTemplate withBody(String body) { setBody(body); return this; } /** ** The sound to play when a recipient receives a push notification that's based on the message template. You can use * the default stream or specify the file name of a sound resource that's bundled in your app. On an Android * platform, the sound file must reside in /res/raw/. *
** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify default for * the value, the system plays the default alert sound. *
* * @param sound * The sound to play when a recipient receives a push notification that's based on the message template. You * can use the default stream or specify the file name of a sound resource that's bundled in your app. On an * Android platform, the sound file must reside in /res/raw/. ** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify * default for the value, the system plays the default alert sound. */ public void setSound(String sound) { this.sound = sound; } /** *
* The sound to play when a recipient receives a push notification that's based on the message template. You can use * the default stream or specify the file name of a sound resource that's bundled in your app. On an Android * platform, the sound file must reside in /res/raw/. *
** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify default for * the value, the system plays the default alert sound. *
* * @return The sound to play when a recipient receives a push notification that's based on the message template. You * can use the default stream or specify the file name of a sound resource that's bundled in your app. On an * Android platform, the sound file must reside in /res/raw/. ** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify * default for the value, the system plays the default alert sound. */ public String getSound() { return this.sound; } /** *
* The sound to play when a recipient receives a push notification that's based on the message template. You can use * the default stream or specify the file name of a sound resource that's bundled in your app. On an Android * platform, the sound file must reside in /res/raw/. *
** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify default for * the value, the system plays the default alert sound. *
* * @param sound * The sound to play when a recipient receives a push notification that's based on the message template. You * can use the default stream or specify the file name of a sound resource that's bundled in your app. On an * Android platform, the sound file must reside in /res/raw/. ** For an iOS platform, this value is the key for the name of a sound file in your app's main bundle or the * Library/Sounds folder in your app's data container. If the sound file can't be found or you specify * default for the value, the system plays the default alert sound. * @return Returns a reference to this object so that method calls can be chained together. */ public DefaultPushNotificationTemplate withSound(String sound) { setSound(sound); return this; } /** *
* The title to use in push notifications that are based on the message template. This title appears above the * notification message on a recipient's device. *
* * @param title * The title to use in push notifications that are based on the message template. This title appears above * the notification message on a recipient's device. */ public void setTitle(String title) { this.title = title; } /** ** The title to use in push notifications that are based on the message template. This title appears above the * notification message on a recipient's device. *
* * @return The title to use in push notifications that are based on the message template. This title appears above * the notification message on a recipient's device. */ public String getTitle() { return this.title; } /** ** The title to use in push notifications that are based on the message template. This title appears above the * notification message on a recipient's device. *
* * @param title * The title to use in push notifications that are based on the message template. This title appears above * the notification message on a recipient's device. * @return Returns a reference to this object so that method calls can be chained together. */ public DefaultPushNotificationTemplate withTitle(String title) { setTitle(title); return this; } /** ** The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's based on * the message template and the value of the Action property is URL. *
* * @param url * The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's * based on the message template and the value of the Action property is URL. */ public void setUrl(String url) { this.url = url; } /** ** The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's based on * the message template and the value of the Action property is URL. *
* * @return The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's * based on the message template and the value of the Action property is URL. */ public String getUrl() { return this.url; } /** ** The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's based on * the message template and the value of the Action property is URL. *
* * @param url * The URL to open in a recipient's default mobile browser, if a recipient taps a push notification that's * based on the message template and the value of the Action property is URL. * @return Returns a reference to this object so that method calls can be chained together. */ public DefaultPushNotificationTemplate withUrl(String url) { setUrl(url); 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 (getAction() != null) sb.append("Action: ").append(getAction()).append(","); if (getBody() != null) sb.append("Body: ").append(getBody()).append(","); if (getSound() != null) sb.append("Sound: ").append(getSound()).append(","); if (getTitle() != null) sb.append("Title: ").append(getTitle()).append(","); if (getUrl() != null) sb.append("Url: ").append(getUrl()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DefaultPushNotificationTemplate == false) return false; DefaultPushNotificationTemplate other = (DefaultPushNotificationTemplate) obj; if (other.getAction() == null ^ this.getAction() == null) return false; if (other.getAction() != null && other.getAction().equals(this.getAction()) == false) return false; if (other.getBody() == null ^ this.getBody() == null) return false; if (other.getBody() != null && other.getBody().equals(this.getBody()) == false) return false; if (other.getSound() == null ^ this.getSound() == null) return false; if (other.getSound() != null && other.getSound().equals(this.getSound()) == false) return false; if (other.getTitle() == null ^ this.getTitle() == null) return false; if (other.getTitle() != null && other.getTitle().equals(this.getTitle()) == false) return false; if (other.getUrl() == null ^ this.getUrl() == null) return false; if (other.getUrl() != null && other.getUrl().equals(this.getUrl()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getAction() == null) ? 0 : getAction().hashCode()); hashCode = prime * hashCode + ((getBody() == null) ? 0 : getBody().hashCode()); hashCode = prime * hashCode + ((getSound() == null) ? 0 : getSound().hashCode()); hashCode = prime * hashCode + ((getTitle() == null) ? 0 : getTitle().hashCode()); hashCode = prime * hashCode + ((getUrl() == null) ? 0 : getUrl().hashCode()); return hashCode; } @Override public DefaultPushNotificationTemplate clone() { try { return (DefaultPushNotificationTemplate) 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.pinpoint.model.transform.DefaultPushNotificationTemplateMarshaller.getInstance().marshall(this, protocolMarshaller); } }