com.github.marsbits.restfbmessenger.Messenger Maven / Gradle / Ivy
/*
* Copyright 2015-2017 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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.github.marsbits.restfbmessenger;
import com.github.marsbits.restfbmessenger.send.SendOperations;
import com.restfb.exception.FacebookException;
import com.restfb.types.User;
import com.restfb.types.send.CallToAction;
import com.restfb.types.send.Greeting;
import com.restfb.types.send.PageMessageTag;
import java.util.List;
/**
* Interface specifying the operations for interacting with Facebook Messenger.
*
* @author Marcel Overdijk
* @since 1.0.0
*/
public interface Messenger {
/**
* The {@code hub.mode} request parameter name.
*/
String HUB_MODE_PARAM_NAME = "hub.mode";
/**
* The {@code hub.mode} {@code subscribe} request parameter value.
*/
String HUB_MODE_SUBSCRIBE_VALUE = "subscribe";
/**
* The {@code hub.verify_token} request parameter name.
*/
String HUB_VERIFY_TOKEN_PARAM_NAME = "hub.verify_token";
/**
* The {@code hub.challenge} request parameter name.
*/
String HUB_CHALLENGE_PARAM_NAME = "hub.challenge";
/**
* The {@code X-Hub-Signature} request header name.
*/
String HUB_SIGNATURE_HEADER_NAME = "X-Hub-Signature";
/**
* Verifies the webhook verify token.
*
* @param token the received webhook verify token
* @return {@code true} if token is valid, otherwise {@code false}
*/
boolean verifyToken(String token);
/**
* Handles the webhook callback.
*
* @param payload the received webhook payload
* @param signature the received webhook signature
*/
void handleCallback(String payload, String signature);
/**
* Returns the {@link User} for the given user id.
*
* @param userId the user id
* @return the user
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
User getUserProfile(String userId) throws FacebookException;
/**
* Returns the {@link User} for the given user id. Only the given fields will be retrieved and populated in the returned user object.
*
* @param userId the user id
* @param fields the list of user fields
* @return the user
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
User getUserProfile(String userId, String... fields) throws FacebookException;
/**
* Returns the {@link User} for the given user id. Only the given fields will be retrieved and populated in the returned user object.
*
* @param userId the user id
* @param fields the comma separated list of user fields
* @return the user
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
User getUserProfile(String userId, String fields) throws FacebookException;
/**
* Send API for sending messages to users.
*/
SendOperations send();
/**
* Sets the greeting text for new conversations.
*
* @param greeting the greeting, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setGreeting(String greeting) throws FacebookException;
/**
* Sets the greeting text for new conversations.
*
* @param greeting the greeting, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setGreeting(Greeting greeting) throws FacebookException;
/**
* Removes the greeting text for new conversations.
*
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removeGreeting() throws FacebookException;
/**
* Sets the get started button for the welcome screen.
*
* @param payload the payload, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setGetStartedButton(String payload) throws FacebookException;
/**
* Sets the get started button for the welcome screen.
*
* @param callToAction the call to action, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setGetStartedButton(CallToAction callToAction) throws FacebookException;
/**
* Removes the get started button for the welcome screen.
*
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removeGetStartedButton() throws FacebookException;
/**
* Sets the persistent menu.
*
* @param callToActions the call to actions, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setPersistentMenu(List callToActions) throws FacebookException;
/**
* Removes the persistent menu.
*
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removePersistentMenu() throws FacebookException;
/**
* Sets the account linking url.
*
* @param url the account linking url, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void setAccountLinkingUrl(String url) throws FacebookException;
/**
* Removes the account linking url.
*
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removeAccountLinkingUrl() throws FacebookException;
/**
* Adds the provided url to the domain whitelist.
*
* @param url the url, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void addDomainWhitelisting(String url) throws FacebookException;
/**
* Adds the provided urls to the domain whitelist.
*
* @param urls the urls, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void addDomainWhitelisting(List urls) throws FacebookException;
/**
* Removes the provided url from the domain whitelist.
*
* @param url the url, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removeDomainWhitelisting(String url) throws FacebookException;
/**
* Removes the provided urls from the domain whitelist.
*
* @param urls the urls, not null
* @return the {@code SendResponse}
* @throws FacebookException in case an error occurs while performing the Facebook API call
*/
void removeDomainWhitelisting(List urls) throws FacebookException;
/**
* Returns the list of supported message tags.
*
* @return the list of supported message tags
* * @throws FacebookException in case an error occurs while performing the Facebook API call
*/
List getMessageTags() throws FacebookException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy