data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.podio.subscription.SubscriptionAPI Maven / Gradle / Ivy
package com.podio.subscription;
import javax.ws.rs.core.MediaType;
import com.podio.ResourceFactory;
import com.podio.common.Empty;
import com.podio.common.Reference;
/**
* Subscriptions allows the user to be notified when an object is created,
* updated, delete, comments added to it or rated.
*/
public class SubscriptionAPI {
private final ResourceFactory resourceFactory;
public SubscriptionAPI(ResourceFactory baseAPI) {
this.resourceFactory = baseAPI;
}
/**
* Returns the subscription with the given id
*
* @param susbcriptionId
* The id of the subscription
* @return The subscription
*/
public Subscription getSubscription(int susbcriptionId) {
return resourceFactory
.getApiResource("/subscription/" + susbcriptionId).get(
Subscription.class);
}
/**
* Get the subscription for the given object
*
* @param reference
* The reference to object
* @return The subscription on the object
*/
public Subscription getSubscription(Reference reference) {
return resourceFactory.getApiResource(
"/subscription/" + reference.toURLFragment(false)).get(
Subscription.class);
}
/**
* Subscribes the user to the given object. Based on the object type, the
* user will receive notifications when actions are performed on the object.
* See the area for more details.
*
* @param reference
* The reference to the object to subscribe to
*/
public void subscribe(Reference reference) {
resourceFactory
.getApiResource(
"/subscription/" + reference.toURLFragment(false))
.entity(new Empty(), MediaType.APPLICATION_JSON_TYPE).post();
}
/**
* Stops the subscription with the given id
*
* @param subscriptionId
* The id of the subscription
*/
public void unsubscribe(int subscriptionId) {
resourceFactory.getApiResource("/subscription/" + subscriptionId)
.delete();
}
/**
* Unsubscribe from getting notifications on actions on the given object.
*
* @param reference
* The reference to the object
*/
public void unsubscribe(Reference reference) {
resourceFactory.getApiResource(
"/subscription/" + reference.toURLFragment(false)).delete();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy