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

io.sphere.sdk.subscriptions.MessageSubscriptionPayload Maven / Gradle / Ivy

package io.sphere.sdk.subscriptions;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonUnwrapped;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.sphere.sdk.annotations.ResourceValue;
import io.sphere.sdk.messages.Message;

/**
 * This payload will be sent for a MessageSubscription.
 *
 * @param  the resource type {@link MessageSubscription#getResourceTypeId()}
 */
@JsonDeserialize(as = MessageSubscriptionPayloadImpl.class)
@ResourceValue
public interface MessageSubscriptionPayload extends Payload {
    /**
     * The message payload will always contain the common fields:
     * 
    *
  • {@link Message#getId()}
  • *
  • {@link Message#getVersion()}
  • *
  • {@link Message#getSequenceNumber()}
  • *
  • {@link Message#getResourceVersion()}
  • *
  • {@link Message#getCreatedAt()}
  • *
  • {@link Message#getLastModifiedAt()}
  • *
* for any message. If the payload fits within the size limit of you message queue (the limit is often 256kb), * all additional fields for the specific message are included as well (along with the {@link Message#getType()} property). * If the payload did not fit, it can be retrieved from the Messages endpoint if messages are enabled. *

* You can check if this payloads contains a complete message with {@link #hasCompleteMessage()}. * In this case you can use {@link #as(Class)} to retrieve the typed message. * * @return the message payload */ @JsonUnwrapped @JsonProperty("message") Message getMessage(); /** * Returns true iff. this payload contains a complete message. * * @return true iff. this payload contains a complete message * @see #getMessage() */ @JsonIgnore default boolean hasCompleteMessage() { return getMessage().getType() != null; } /** * Returns {@link #getMessage()} as a message of the given message class. * * @param messageClass the message class * @param the message type * * @return the typed message * @throws IllegalStateException if this payload contains an incomplete message {@link #hasCompleteMessage()} */ @JsonIgnore default M as(final Class messageClass) { if (!hasCompleteMessage()) { throw new IllegalStateException("Can't retrieve typed message for an incomplete message"); } return getMessage().as(messageClass); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy