/*
    msninvitation.cpp

    Copyright (c) 2003 by Olivier Goffart        <ogoffart @ kde.org>

    Kopete    (c) 2003 by the Kopete developers  <kopete-devel@kde.org>

    *************************************************************************
    *                                                                       *
    * This program is free software; you can redistribute it and/or modify  *
    * it under the terms of the GNU General Public License as published by  *
    * the Free Software Foundation; either version 2 of the License, or     *
    * (at your option) any later version.                                   *
    *                                                                       *
    *************************************************************************
*/
#ifndef MSNINVITATION_H
#define MSNINVITATION_H

#include <tqstring.h>

#include "kopete_export.h"

class TQObject;

/**
 * @author Olivier Goffart
 *
 * The invitation is the base class which handle an MSN invitation.
 * The implemented class must to herits from TQObject too.
 * You can accept the invitation by catching @ref MSNProtocol::invitation() signals
 * or create one and insert it to a kmm with @ref MSNChatSession::initInvitation()
 * you can add action with @ref Kopete::Plugin::customChatActions()
 */
class KOPETE_EXPORT MSNInvitation
{
public:
	/**
	 * Constructor
	 * @param incoming say if it is an incoming invitation
	 * @param applicationID is the exadecimal id of the invitation
	 * @param applicationName is a i18n'ed string of the name of the application
	 */
	MSNInvitation(bool incoming,const TQString &applicationID , const TQString &applicationName);
	virtual ~MSNInvitation();

	/**
	 * @internal
	 * it is a reject invitation because the invitation is not implemented
	 */
	static TQCString unimplemented(long unsigned int cookie);

	/**
	 * you can set manualy the cookie. note that a cookie is automatically generated when a new
	 * invitation is created, or in @ref parseInvitation
	 */
	void setCookie( long unsigned int c ) { m_cookie = c; }
	/**
	 * @return the cookie
	 */
	long unsigned int cookie() { return m_cookie; }

	/**
	 * @return true if it is an incommijng invitation
	 */
	bool incoming() { return m_incoming; }


	/**
	 * reimplement this. this is the invitation string used in @ref MSNChatSession::initInvitation()
	 * the default implementation return the common begin.
	 * You can also set the state to Invited (the default implementation do that)
	 */
	virtual TQString invitationHead();

	/**
	 * This is the reject invitation string
	 * @param rejectcode is the code, it can be "REJECT" or "TIMEOUT"
	 */
	TQCString rejectMessage(const TQString & rejectcode = "REJECT");

	/**
	 * reimplement this method. it is called when an invitation message with the invitation's cookie is received
	 * the default implementation parse the cookie, or the reject message
	 */
	virtual void parseInvitation(const TQString& invitation);

	/**
	 * return the qobject (this)
	 */
	virtual TQObject* object()=0;
//signals:
	/**
	 * reimplement this as a signal, and emit it when the invitation has to be destroyed.
	 * don't delete the invitation yourself
	 */
	virtual void done(MSNInvitation*)=0;

	/**
	 * This indiquate the state. it is going to be completed later
	 * - Nothing means than nothing has been done in the invitaiton (nothing has been sent/received)
	 * - Invited means than the invitaiton has been sent
	 */
	enum State { Nothing=0 , Invited=1 };
	/**
	 * retrun the current state
	 */
	State state();
	/**
	 * set the current State
	 */
	void setState(State);



protected:
	bool m_incoming;
	long unsigned int m_cookie;
	TQString m_applicationId;
	TQString m_applicationName;
	State m_state;


};

#endif