io.sphere.sdk.channels.Channel Maven / Gradle / Ivy
package io.sphere.sdk.channels;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.sphere.sdk.carts.LineItem;
import io.sphere.sdk.models.LocalizedString;
import io.sphere.sdk.models.Resource;
import io.sphere.sdk.models.Reference;
import io.sphere.sdk.models.WithKey;
import io.sphere.sdk.orders.SyncInfo;
import io.sphere.sdk.reviews.Review;
import io.sphere.sdk.reviews.ReviewDraft;
import io.sphere.sdk.reviews.ReviewRatingStatistics;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.Set;
/** Channels represent a source or destination of different entities.
@see io.sphere.sdk.channels.commands.ChannelCreateCommand
@see io.sphere.sdk.channels.commands.ChannelUpdateCommand
@see io.sphere.sdk.channels.commands.ChannelDeleteCommand
@see io.sphere.sdk.channels.queries.ChannelQuery
@see io.sphere.sdk.channels.queries.ChannelByIdGet
@see LineItem#getSupplyChannel()
@see io.sphere.sdk.inventory.InventoryEntry#getSupplyChannel()
@see SyncInfo#getChannel()
@see io.sphere.sdk.products.Price#getChannel()
@see Review#getTarget()
*/
@JsonDeserialize(as = ChannelImpl.class)
public interface Channel extends Resource, WithKey {
/**
* Any arbitrary string key that unique identifies this channel within the project.
*
* @see io.sphere.sdk.channels.commands.updateactions.ChangeKey
*
* @return key
*/
String getKey();
/**
* The roles of this channel. Each channel must have at least one role.
*
* @see io.sphere.sdk.channels.commands.updateactions.SetRoles
* @see io.sphere.sdk.channels.commands.updateactions.AddRoles
* @see io.sphere.sdk.channels.commands.updateactions.RemoveRoles
*
* @return roles
*/
@Nonnull
Set getRoles();
/**
* Name of this channel.
*
* @see io.sphere.sdk.channels.commands.updateactions.ChangeName
*
* @return name
*/
@Nullable
LocalizedString getName();
/**
* Description of this channel.
*
* @see io.sphere.sdk.channels.commands.updateactions.ChangeDescription
*
* @return description
*/
@Nullable
LocalizedString getDescription();
/**
* The {@link Review} ratings of this channel.
*
* @see Review
* @see ReviewDraft#getTarget()
*
* @return ratings or null
*/
@Nullable
ReviewRatingStatistics getReviewRatingStatistics();
default Reference toReference() {
return Reference.of(referenceTypeId(), getId(), this);
}
/**
* A type hint for references which resource type is linked in a reference.
* @see Reference#getTypeId()
* @return type hint
*/
static String referenceTypeId() {
return "channel";
}
/**
*
* @deprecated use {@link #referenceTypeId()} instead
* @return referenceTypeId
*/
@Deprecated
static String typeId(){
return "channel";
}
/**
* Creates a container which contains the full Java type information to deserialize this class from JSON.
*
* @see io.sphere.sdk.json.SphereJsonUtils#readObject(byte[], TypeReference)
* @see io.sphere.sdk.json.SphereJsonUtils#readObject(String, TypeReference)
* @see io.sphere.sdk.json.SphereJsonUtils#readObject(com.fasterxml.jackson.databind.JsonNode, TypeReference)
* @see io.sphere.sdk.json.SphereJsonUtils#readObjectFromResource(String, TypeReference)
*
* @return type reference
*/
static TypeReference typeReference() {
return new TypeReference() {
@Override
public String toString() {
return "TypeReference";
}
};
}
/**
* Creates a reference for one item of this class by a known ID.
*
* An example for categories but this applies for other resources, too:
* {@include.example io.sphere.sdk.categories.CategoryTest#referenceOfId()}
*
* If you already have a resource object, then use {@link #toReference()} instead:
*
* {@include.example io.sphere.sdk.categories.CategoryTest#toReference()}
*
* @param id the ID of the resource which should be referenced.
* @return reference
*/
static Reference referenceOfId(final String id) {
return Reference.of(referenceTypeId(), id);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy