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

com.github.marsbits.restfbmessenger.Messenger Maven / Gradle / Ivy

There is a newer version: 2.2.1
Show newest version
/*
 * 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