Clementine-audio-player-Mac.../3rdparty/gloox/discohandler.h

84 lines
2.4 KiB
C++

/*
Copyright (c) 2004-2009 by Jakob Schroeter <js@camaya.net>
This file is part of the gloox library. http://camaya.net/gloox
This software is distributed under a license. The full license
agreement can be found in the file LICENSE in this distribution.
This software may not be copied, modified, sold or distributed
other than expressed in the named license agreement.
This software is distributed without any warranty.
*/
#ifndef DISCOHANDLER_H__
#define DISCOHANDLER_H__
#include "macros.h"
#include "disco.h"
#include <string>
namespace gloox
{
class IQ;
/**
* @brief A virtual interface that enables objects to receive Service Discovery (XEP-0030) events.
*
* A class implementing this interface can receive the results of sent disco queries.
*
* @author Jakob Schroeter <js@camaya.net>
*/
class GLOOX_API DiscoHandler
{
public:
/**
* Virtual Destructor.
*/
virtual ~DiscoHandler() {}
/**
* Reimplement this function if you want to be notified about the result
* of an disco#info query.
* @param from The sender of the disco#info result.
* @param info The Info.
* @param context A context identifier.
* @since 1.0
*/
virtual void handleDiscoInfo( const JID& from, const Disco::Info& info, int context ) = 0;
/**
* Reimplement this function if you want to be notified about the result
* of a disco#items query.
* @param from The sender of the disco#items result.
* @param items The Items.
* @param context A context identifier.
* @since 1.0
*/
virtual void handleDiscoItems( const JID& from, const Disco::Items& items, int context ) = 0;
/**
* Reimplement this function to receive disco error notifications.
* @param from The sender of the error result.
* @param error The Error. May be 0.
* @param context A context identifier.
* @since 1.0
*/
virtual void handleDiscoError( const JID& from, const Error* error, int context ) = 0;
/**
* Reimplement this function to receive notifications about incoming IQ
* stanzas of type 'set' in the disco namespace.
* @param iq The full IQ.
* @return Returns @b true if the stanza was handled and answered, @b false otherwise.
*/
virtual bool handleDiscoSet( const IQ& iq ) { (void)iq; return false; }
};
}
#endif // DISCOHANDLER_H__