/**
* GRANITE DATA SERVICES
* Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S.
*
* This file is part of the Granite Data Services Platform.
*
* Granite Data Services is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Granite Data Services is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
* General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA, or see <http://www.gnu.org/licenses/>.
*/
package org.granite.client.messaging;
import org.granite.client.messaging.events.CancelledEvent;
import org.granite.client.messaging.events.FailureEvent;
import org.granite.client.messaging.events.FaultEvent;
import org.granite.client.messaging.events.ResultEvent;
import org.granite.client.messaging.events.TimeoutEvent;
/**
* Callback interface for remoting/messaging asynchronous events
*
* @author Franck WOLFF
*/
public interface ResponseListener {
/**
* Callback when a request has been successfully processed
* @param event result event holding the result message
*/
void onResult(ResultEvent event);
/**
* Callback when a fault is received (usually server exceptions are received as faults)
* @param event fault event holding the remote error
*/
void onFault(FaultEvent event);
/**
* Callback when a failure occurs on the client side (network issue, serializable error...)
* @param event failure event holding the local exception
*/
void onFailure(FailureEvent event);
/**
* Callback when a request times out
* @param event timeout event holding the local exception
*/
void onTimeout(TimeoutEvent event);
/**
* Callback when a request is cancelled
* @param event cancel event holding the local exception
*/
void onCancelled(CancelledEvent event);
}