You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdenetwork/kopete/protocols/jabber/jabbercontactpool.h

127 lines
3.1 KiB

/*
* jabbercontactpool.h
*
* Copyright (c) 2004 by Till Gerken <till@tantalo.net>
*
* Kopete (c) 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 JABBERCONTACTPOOL_H
#define JABBERCONTACTPOOL_H
#include <tqobject.h>
#include <im.h>
namespace Kopete { class MetaContact; }
namespace Kopete { class Contact; }
class JabberContactPoolItem;
class JabberBaseContact;
class JabberContact;
class JabberGroupContact;
class JabberAccount;
class JabberTransport;
/**
* @author Till Gerken <till@tantalo.net>
*/
class JabberContactPool : public TQObject
{
TQ_OBJECT
public:
/**
* Default constructor
*/
JabberContactPool ( JabberAccount *account );
/**
* Default destructor
*/
~JabberContactPool();
/**
* Add a contact to the pool
*/
JabberContact *addContact ( const XMPP::RosterItem &contact, Kopete::MetaContact *metaContact, bool dirty = true );
JabberBaseContact *addGroupContact ( const XMPP::RosterItem &contact, bool roomContact, Kopete::MetaContact *metaContact, bool dirty = true );
/**
* Remove a contact from the pool
*/
void removeContact ( const XMPP::Jid &jid );
/**
* Remove all contacts from the pool
*/
void clear ();
/**
* Sets the "dirty" flag for a certain contact
*/
void setDirty ( const XMPP::Jid &jid, bool dirty );
/**
* Remove all dirty elements from the pool
* (used after connecting to delete removed items from the roster)
*/
void cleanUp ();
/**
* Find an exact match in the pool by full JID.
*/
JabberBaseContact *findExactMatch ( const XMPP::Jid &jid );
/**
* Find a relevant recipient for a given JID.
* This will match user@domain for a given user@domain/resource,
* but NOT user@domain/resource for a given user@domain.
*/
JabberBaseContact *findRelevantRecipient ( const XMPP::Jid &jid );
/**
* Find relevant sources for a given JID.
* This will match user@domain/resource for a given user@domain.
*/
TQPtrList<JabberBaseContact> findRelevantSources ( const XMPP::Jid &jid );
private slots:
void slotContactDestroyed ( Kopete::Contact *contact );
private:
JabberContactPoolItem *findPoolItem ( const XMPP::RosterItem &contact );
TQPtrList<JabberContactPoolItem> mPool;
JabberAccount *mAccount;
};
class JabberContactPoolItem : TQObject
{
TQ_OBJECT
public:
JabberContactPoolItem ( JabberBaseContact *contact );
~JabberContactPoolItem ();
void setDirty ( bool dirty );
bool dirty ();
JabberBaseContact *contact ();
private:
bool mDirty;
JabberBaseContact *mContact;
};
#endif