/** * XMPP - libpurple transport * * Copyright (C) 2009, Jan Kaluza * * 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. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA */ #pragma once #include #include #include #include #include #include // #include "rosterstorage.h" #include "Swiften/Elements/RosterPayload.h" #include "Swiften/Queries/GenericRequest.h" #include "Swiften/Roster/SetRosterRequest.h" #include "Swiften/Elements/Presence.h" #include "Swiften/Network/Timer.h" namespace Transport { class Buddy; class User; class Component; class StorageBackend; class RosterStorage; /// Manages roster of one XMPP user. class RosterManager { public: typedef std::map, boost::pool_allocator< std::pair > > BuddiesMap; /// Creates new RosterManager. /// \param user User associated with this RosterManager. /// \param component Transport instance associated with this roster. RosterManager(User *user, Component *component); /// Destructor. virtual ~RosterManager(); virtual void doRemoveBuddy(Buddy *buddy) = 0; virtual void doAddBuddy(Buddy *buddy) = 0; virtual void doUpdateBuddy(Buddy *buddy) = 0; /// Associates the buddy with this roster, /// and if the buddy is not already in XMPP user's server-side roster, the proper requests /// are sent to XMPP user (subscribe presences, Roster Item Exchange stanza or /// the buddy is added to server-side roster using remote-roster protoXEP). /// \param buddy Buddy void setBuddy(Buddy *buddy); /// Deassociates the buddy with this roster. /// \param buddy Buddy. void unsetBuddy(Buddy *buddy); /// Removes buddy from this roster, sends proper XML to XMPP side and deletes it. /// \param name Buddy name. void removeBuddy(const std::string &name); Buddy *getBuddy(const std::string &name); void setStorageBackend(StorageBackend *storageBackend); void storeBuddy(Buddy *buddy); Swift::RosterPayload::ref generateRosterPayload(); /// Returns user associated with this roster. /// \return User User *getUser() { return m_user; } const BuddiesMap &getBuddies() { return m_buddies; } bool isRemoteRosterSupported() { return m_supportRemoteRoster; } /// Called when new Buddy is added to this roster. /// \param buddy newly added Buddy boost::signal onBuddySet; /// Called when Buddy has been removed from this roster. /// \param buddy removed Buddy boost::signal onBuddyUnset; boost::signal onBuddyAdded; boost::signal onBuddyRemoved; void handleBuddyChanged(Buddy *buddy); void handleSubscription(Swift::Presence::ref presence); void sendBuddyRosterRemove(Buddy *buddy); void sendBuddySubscribePresence(Buddy *buddy); void sendBuddyUnsubscribePresence(Buddy *buddy); void sendCurrentPresences(const Swift::JID &to); void sendCurrentPresence(const Swift::JID &from, const Swift::JID &to); void sendUnavailablePresences(const Swift::JID &to); protected: std::map, boost::pool_allocator< std::pair > > m_buddies; private: Component *m_component; RosterStorage *m_rosterStorage; User *m_user; Swift::Timer::ref m_setBuddyTimer; Swift::Timer::ref m_RIETimer; std::list m_requests; bool m_supportRemoteRoster; }; }