118 lines
3.3 KiB
C
118 lines
3.3 KiB
C
|
/*
|
||
|
Copyright (c) 2007-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 UNIQUEMUCROOM_H__
|
||
|
#define UNIQUEMUCROOM_H__
|
||
|
|
||
|
#include "instantmucroom.h"
|
||
|
#include "stanzaextension.h"
|
||
|
|
||
|
namespace gloox
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* @brief This class implements a unique MUC room.
|
||
|
*
|
||
|
* A unique MUC room is a room with a non-human-readable name. It is primarily intended
|
||
|
* to be used when converting one-to-one chats to multi-user chats.
|
||
|
*
|
||
|
* XEP version: 1.21
|
||
|
* @author Jakob Schroeter <js@camaya.net>
|
||
|
* @since 0.9
|
||
|
*/
|
||
|
class GLOOX_API UniqueMUCRoom : public InstantMUCRoom
|
||
|
{
|
||
|
public:
|
||
|
/**
|
||
|
* Creates a new abstraction of a @b unique Multi-User Chat room. The room is not joined
|
||
|
* automatically. Use join() to join the room, use leave() to leave it. See MUCRoom for
|
||
|
* detailed info.
|
||
|
* @param parent The ClientBase object to use for the communication.
|
||
|
* @param nick The service to create the room on plus the desired nickname in the form
|
||
|
* @b service/nick.
|
||
|
* @param mrh The MUCRoomHandler that will listen to room events. May be 0 and may be specified
|
||
|
* later using registerMUCRoomHandler(). However, without one, MUC is no joy.
|
||
|
* @note To subsequently configure the room, use MUCRoom::registerMUCRoomConfigHandler().
|
||
|
*/
|
||
|
UniqueMUCRoom( ClientBase* parent, const JID& nick, MUCRoomHandler* mrh );
|
||
|
|
||
|
/**
|
||
|
* Virtual Destructor.
|
||
|
*/
|
||
|
virtual ~UniqueMUCRoom();
|
||
|
|
||
|
// reimplemented from MUCRoom
|
||
|
virtual void join();
|
||
|
|
||
|
private:
|
||
|
#ifdef UNIQUEMUCROOM_TEST
|
||
|
public:
|
||
|
#endif
|
||
|
/**
|
||
|
* @brief A stanza extension wrapping MUC's <unique> element.
|
||
|
*
|
||
|
* @author Jakob Schroeter <js@camaya.net>
|
||
|
* @since 1.0
|
||
|
*/
|
||
|
class Unique : public StanzaExtension
|
||
|
{
|
||
|
public:
|
||
|
/**
|
||
|
* Creates a new object from the given Tag.
|
||
|
* @param tag The Tag to parse.
|
||
|
*/
|
||
|
Unique( const Tag* tag = 0 );
|
||
|
|
||
|
/**
|
||
|
*Virtual Destructor.
|
||
|
*/
|
||
|
virtual ~Unique() {}
|
||
|
|
||
|
/**
|
||
|
* Returns the unique name created by the server.
|
||
|
* @return The server-created unique room name.
|
||
|
*/
|
||
|
const std::string& name() const { return m_name; }
|
||
|
|
||
|
// reimplemented from StanzaExtension
|
||
|
virtual const std::string& filterString() const;
|
||
|
|
||
|
// reimplemented from StanzaExtension
|
||
|
virtual StanzaExtension* newInstance( const Tag* tag ) const
|
||
|
{
|
||
|
return new Unique( tag );
|
||
|
}
|
||
|
|
||
|
// reimplemented from StanzaExtension
|
||
|
virtual Tag* tag() const;
|
||
|
|
||
|
// reimplemented from StanzaExtension
|
||
|
virtual StanzaExtension* clone() const
|
||
|
{
|
||
|
return new Unique( *this );
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
std::string m_name;
|
||
|
};
|
||
|
|
||
|
// reimplemented from MUCRoom (IqHandler)
|
||
|
void handleIqID( const IQ& iq, int context );
|
||
|
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif // UNIQUEMUCROOM_H__
|