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

com.amazonaws.services.ioteventsdata.model.Message Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS IoT Events Data module holds the client classes that are used for communicating with AWS IoT Events Data Service

There is a newer version: 1.12.780
Show 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.ioteventsdata.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Information about a message. *

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

* The ID to assign to the message. Within each batch sent, each "messageId" must be unique. *

*/ private String messageId; /** *

* The name of the input into which the message payload is transformed. *

*/ private String inputName; /** *

* The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data (in * which case you must decode it). *

*/ private java.nio.ByteBuffer payload; /** *

* The timestamp associated with the message. *

*/ private TimestampValue timestamp; /** *

* The ID to assign to the message. Within each batch sent, each "messageId" must be unique. *

* * @param messageId * The ID to assign to the message. Within each batch sent, each "messageId" must be unique. */ public void setMessageId(String messageId) { this.messageId = messageId; } /** *

* The ID to assign to the message. Within each batch sent, each "messageId" must be unique. *

* * @return The ID to assign to the message. Within each batch sent, each "messageId" must be unique. */ public String getMessageId() { return this.messageId; } /** *

* The ID to assign to the message. Within each batch sent, each "messageId" must be unique. *

* * @param messageId * The ID to assign to the message. Within each batch sent, each "messageId" must be unique. * @return Returns a reference to this object so that method calls can be chained together. */ public Message withMessageId(String messageId) { setMessageId(messageId); return this; } /** *

* The name of the input into which the message payload is transformed. *

* * @param inputName * The name of the input into which the message payload is transformed. */ public void setInputName(String inputName) { this.inputName = inputName; } /** *

* The name of the input into which the message payload is transformed. *

* * @return The name of the input into which the message payload is transformed. */ public String getInputName() { return this.inputName; } /** *

* The name of the input into which the message payload is transformed. *

* * @param inputName * The name of the input into which the message payload is transformed. * @return Returns a reference to this object so that method calls can be chained together. */ public Message withInputName(String inputName) { setInputName(inputName); return this; } /** *

* The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data (in * which case you must decode it). *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param payload * The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data * (in which case you must decode it). */ public void setPayload(java.nio.ByteBuffer payload) { this.payload = payload; } /** *

* The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data (in * which case you must decode it). *

*

* {@code ByteBuffer}s are stateful. Calling their {@code get} methods changes their {@code position}. We recommend * using {@link java.nio.ByteBuffer#asReadOnlyBuffer()} to create a read-only view of the buffer with an independent * {@code position}, and calling {@code get} methods on this rather than directly on the returned {@code ByteBuffer}. * Doing so will ensure that anyone else using the {@code ByteBuffer} will not be affected by changes to the * {@code position}. *

* * @return The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary * data (in which case you must decode it). */ public java.nio.ByteBuffer getPayload() { return this.payload; } /** *

* The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data (in * which case you must decode it). *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param payload * The payload of the message. This can be a JSON string or a Base-64-encoded string representing binary data * (in which case you must decode it). * @return Returns a reference to this object so that method calls can be chained together. */ public Message withPayload(java.nio.ByteBuffer payload) { setPayload(payload); return this; } /** *

* The timestamp associated with the message. *

* * @param timestamp * The timestamp associated with the message. */ public void setTimestamp(TimestampValue timestamp) { this.timestamp = timestamp; } /** *

* The timestamp associated with the message. *

* * @return The timestamp associated with the message. */ public TimestampValue getTimestamp() { return this.timestamp; } /** *

* The timestamp associated with the message. *

* * @param timestamp * The timestamp associated with the message. * @return Returns a reference to this object so that method calls can be chained together. */ public Message withTimestamp(TimestampValue timestamp) { setTimestamp(timestamp); 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 (getMessageId() != null) sb.append("MessageId: ").append(getMessageId()).append(","); if (getInputName() != null) sb.append("InputName: ").append(getInputName()).append(","); if (getPayload() != null) sb.append("Payload: ").append(getPayload()).append(","); if (getTimestamp() != null) sb.append("Timestamp: ").append(getTimestamp()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Message == false) return false; Message other = (Message) obj; if (other.getMessageId() == null ^ this.getMessageId() == null) return false; if (other.getMessageId() != null && other.getMessageId().equals(this.getMessageId()) == false) return false; if (other.getInputName() == null ^ this.getInputName() == null) return false; if (other.getInputName() != null && other.getInputName().equals(this.getInputName()) == false) return false; if (other.getPayload() == null ^ this.getPayload() == null) return false; if (other.getPayload() != null && other.getPayload().equals(this.getPayload()) == false) return false; if (other.getTimestamp() == null ^ this.getTimestamp() == null) return false; if (other.getTimestamp() != null && other.getTimestamp().equals(this.getTimestamp()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getMessageId() == null) ? 0 : getMessageId().hashCode()); hashCode = prime * hashCode + ((getInputName() == null) ? 0 : getInputName().hashCode()); hashCode = prime * hashCode + ((getPayload() == null) ? 0 : getPayload().hashCode()); hashCode = prime * hashCode + ((getTimestamp() == null) ? 0 : getTimestamp().hashCode()); return hashCode; } @Override public Message clone() { try { return (Message) 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.ioteventsdata.model.transform.MessageMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy