2011-03-21 21:29:02 +01:00
|
|
|
/**
|
|
|
|
* XMPP - libpurple transport
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009, Jan Kaluza <hanzz@soc.pidgin.im>
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2015-11-18 14:05:57 +01:00
|
|
|
#include "transport/RosterManager.h"
|
|
|
|
#include "transport/RosterStorage.h"
|
|
|
|
#include "transport/StorageBackend.h"
|
|
|
|
#include "transport/Buddy.h"
|
|
|
|
#include "transport/User.h"
|
|
|
|
#include "transport/Logging.h"
|
|
|
|
#include "transport/Frontend.h"
|
|
|
|
#include "transport/Factory.h"
|
|
|
|
#include "transport/Transport.h"
|
2011-03-30 21:23:39 +02:00
|
|
|
#include "Swiften/Elements/RosterPayload.h"
|
|
|
|
#include "Swiften/Elements/RosterItemPayload.h"
|
2011-04-04 23:26:05 +02:00
|
|
|
#include "Swiften/Elements/RosterItemExchangePayload.h"
|
2013-01-23 11:29:43 +01:00
|
|
|
#include "Swiften/Elements/Nickname.h"
|
2011-08-31 19:37:58 +02:00
|
|
|
#include <boost/foreach.hpp>
|
2013-01-23 11:29:43 +01:00
|
|
|
#include <boost/make_shared.hpp>
|
2016-01-22 15:17:51 +01:00
|
|
|
#include <boost/algorithm/string.hpp>
|
2016-01-23 21:58:48 +01:00
|
|
|
#include <boost/locale.hpp>
|
2011-06-21 14:30:49 +02:00
|
|
|
|
2011-09-07 14:03:27 +02:00
|
|
|
#include <map>
|
|
|
|
#include <iterator>
|
|
|
|
|
2011-03-21 21:29:02 +01:00
|
|
|
namespace Transport {
|
|
|
|
|
2012-03-21 16:31:51 +01:00
|
|
|
DEFINE_LOGGER(logger, "RosterManager");
|
2011-06-21 14:30:49 +02:00
|
|
|
|
2011-03-21 21:29:02 +01:00
|
|
|
RosterManager::RosterManager(User *user, Component *component){
|
2011-04-07 09:53:33 +02:00
|
|
|
m_rosterStorage = NULL;
|
2011-03-21 21:29:02 +01:00
|
|
|
m_user = user;
|
|
|
|
m_component = component;
|
2016-01-23 21:58:48 +01:00
|
|
|
|
|
|
|
boost::locale::generator gen;
|
2017-06-27 14:13:52 +03:00
|
|
|
std::locale::global(gen(""));
|
2011-03-21 21:29:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
RosterManager::~RosterManager() {
|
2011-06-05 11:35:37 +02:00
|
|
|
if (m_rosterStorage) {
|
|
|
|
m_rosterStorage->storeBuddies();
|
|
|
|
}
|
|
|
|
|
2011-07-12 22:02:02 +02:00
|
|
|
sendUnavailablePresences(m_user->getJID().toBare());
|
|
|
|
|
2017-02-17 13:36:10 +01:00
|
|
|
for (std::map<std::string, Buddy *, std::less<std::string>, boost::pool_allocator< std::pair<const std::string, Buddy *> > >::iterator it = m_buddies.begin(); it != m_buddies.end(); it++) {
|
2011-05-13 10:54:03 +02:00
|
|
|
Buddy *buddy = (*it).second;
|
2011-07-10 15:32:01 +02:00
|
|
|
if (!buddy) {
|
|
|
|
continue;
|
|
|
|
}
|
2011-05-13 10:54:03 +02:00
|
|
|
delete buddy;
|
|
|
|
}
|
2011-07-12 22:02:02 +02:00
|
|
|
|
2011-08-26 11:47:28 +02:00
|
|
|
boost::singleton_pool<boost::pool_allocator_tag, sizeof(unsigned int)>::release_memory();
|
|
|
|
|
2011-04-07 09:53:33 +02:00
|
|
|
if (m_rosterStorage)
|
|
|
|
delete m_rosterStorage;
|
2011-03-21 21:29:02 +01:00
|
|
|
}
|
|
|
|
|
2016-01-22 15:17:51 +01:00
|
|
|
void RosterManager::removeBuddy(const std::string &_name) {
|
|
|
|
std::string name = _name;
|
2016-01-23 21:58:48 +01:00
|
|
|
name = boost::locale::to_lower(name);
|
2012-06-14 08:06:46 +02:00
|
|
|
Buddy *buddy = getBuddy(name);
|
|
|
|
if (!buddy) {
|
|
|
|
LOG4CXX_WARN(logger, m_user->getJID().toString() << ": Tried to remove unknown buddy " << name);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-11-16 10:49:10 +01:00
|
|
|
doRemoveBuddy(buddy);
|
2012-06-14 08:06:46 +02:00
|
|
|
|
2012-07-20 13:46:28 +02:00
|
|
|
if (m_rosterStorage)
|
|
|
|
m_rosterStorage->removeBuddy(buddy);
|
|
|
|
|
2012-06-14 08:06:46 +02:00
|
|
|
unsetBuddy(buddy);
|
|
|
|
delete buddy;
|
|
|
|
}
|
|
|
|
|
2011-03-30 21:23:39 +02:00
|
|
|
|
2012-06-14 08:06:46 +02:00
|
|
|
void RosterManager::sendBuddyUnsubscribePresence(Buddy *buddy) {
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
|
|
|
response->setTo(m_user->getJID());
|
|
|
|
response->setFrom(buddy->getJID());
|
|
|
|
response->setType(Swift::Presence::Unsubscribe);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2012-06-14 08:06:46 +02:00
|
|
|
|
|
|
|
response = Swift::Presence::create();
|
|
|
|
response->setTo(m_user->getJID());
|
|
|
|
response->setFrom(buddy->getJID());
|
|
|
|
response->setType(Swift::Presence::Unsubscribed);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2012-06-14 08:06:46 +02:00
|
|
|
}
|
|
|
|
|
2011-07-14 14:21:40 +02:00
|
|
|
void RosterManager::sendBuddySubscribePresence(Buddy *buddy) {
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
|
|
|
response->setTo(m_user->getJID());
|
2013-03-19 15:18:03 +01:00
|
|
|
response->setFrom(buddy->getJID().toBare());
|
2011-07-14 14:21:40 +02:00
|
|
|
response->setType(Swift::Presence::Subscribe);
|
2012-12-28 08:55:29 +01:00
|
|
|
if (!buddy->getAlias().empty()) {
|
2016-09-12 18:20:58 +02:00
|
|
|
response->addPayload(SWIFTEN_SHRPTR_NAMESPACE::make_shared<Swift::Nickname>(buddy->getAlias()));
|
2012-12-28 08:55:29 +01:00
|
|
|
}
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-07-14 14:21:40 +02:00
|
|
|
}
|
|
|
|
|
2011-08-23 08:02:41 +02:00
|
|
|
void RosterManager::handleBuddyChanged(Buddy *buddy) {
|
|
|
|
}
|
|
|
|
|
2015-11-16 10:49:10 +01:00
|
|
|
void RosterManager::setBuddy(Buddy *buddy) {
|
2016-01-22 15:17:51 +01:00
|
|
|
std::string name = buddy->getName();
|
2016-01-23 21:58:48 +01:00
|
|
|
name = boost::locale::to_lower(name);
|
2016-01-22 15:17:51 +01:00
|
|
|
LOG4CXX_INFO(logger, "Associating buddy " << name << " with " << m_user->getJID().toString());
|
|
|
|
m_buddies[name] = buddy;
|
2011-03-21 21:29:02 +01:00
|
|
|
onBuddySet(buddy);
|
2011-03-24 11:42:31 +01:00
|
|
|
|
2015-11-16 10:49:10 +01:00
|
|
|
doAddBuddy(buddy);
|
2011-04-07 14:21:42 +02:00
|
|
|
|
|
|
|
if (m_rosterStorage)
|
|
|
|
m_rosterStorage->storeBuddy(buddy);
|
2011-03-21 21:29:02 +01:00
|
|
|
}
|
|
|
|
|
2011-04-03 11:39:06 +02:00
|
|
|
void RosterManager::unsetBuddy(Buddy *buddy) {
|
2016-01-22 15:17:51 +01:00
|
|
|
std::string name = buddy->getName();
|
2016-01-23 21:58:48 +01:00
|
|
|
name = boost::locale::to_lower(name);
|
2016-01-22 15:17:51 +01:00
|
|
|
m_buddies.erase(name);
|
2011-04-07 09:53:33 +02:00
|
|
|
if (m_rosterStorage)
|
|
|
|
m_rosterStorage->removeBuddyFromQueue(buddy);
|
2011-03-21 21:29:02 +01:00
|
|
|
onBuddyUnset(buddy);
|
|
|
|
}
|
|
|
|
|
2011-06-09 13:54:09 +02:00
|
|
|
void RosterManager::storeBuddy(Buddy *buddy) {
|
|
|
|
if (m_rosterStorage) {
|
|
|
|
m_rosterStorage->storeBuddy(buddy);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-22 15:17:51 +01:00
|
|
|
Buddy *RosterManager::getBuddy(const std::string &_name) {
|
|
|
|
std::string name = _name;
|
2016-01-23 21:58:48 +01:00
|
|
|
name = boost::locale::to_lower(name);
|
2011-04-01 23:54:29 +02:00
|
|
|
return m_buddies[name];
|
|
|
|
}
|
|
|
|
|
2011-04-04 23:26:05 +02:00
|
|
|
|
2011-04-06 14:05:52 +02:00
|
|
|
void RosterManager::handleSubscription(Swift::Presence::ref presence) {
|
2016-01-22 15:17:51 +01:00
|
|
|
std::string legacyName = Buddy::JIDToLegacyName(presence->getTo(), m_user);
|
2012-04-11 17:59:19 +02:00
|
|
|
if (legacyName.empty()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-06-17 13:43:31 +02:00
|
|
|
// For server mode the subscription changes are handler in rosterresponder.cpp
|
|
|
|
// using roster pushes.
|
|
|
|
if (m_component->inServerMode()) {
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
2012-02-17 16:54:40 +01:00
|
|
|
response->setTo(presence->getFrom().toBare());
|
|
|
|
response->setFrom(presence->getTo().toBare());
|
2016-01-22 15:17:51 +01:00
|
|
|
Buddy *buddy = getBuddy(legacyName);
|
2011-06-17 13:43:31 +02:00
|
|
|
if (buddy) {
|
2016-01-22 15:17:51 +01:00
|
|
|
LOG4CXX_INFO(logger, m_user->getJID().toString() << ": Subscription received and buddy " << legacyName << " is already there => answering");
|
2011-06-17 13:43:31 +02:00
|
|
|
switch (presence->getType()) {
|
|
|
|
case Swift::Presence::Subscribe:
|
2011-08-13 21:32:48 +02:00
|
|
|
onBuddyAdded(buddy);
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Subscribed);
|
|
|
|
break;
|
|
|
|
case Swift::Presence::Unsubscribe:
|
2011-08-13 21:32:48 +02:00
|
|
|
onBuddyRemoved(buddy);
|
2012-08-13 08:29:44 +02:00
|
|
|
removeBuddy(buddy->getName());
|
|
|
|
buddy = NULL;
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Unsubscribed);
|
|
|
|
break;
|
2011-08-13 21:32:48 +02:00
|
|
|
case Swift::Presence::Subscribed:
|
|
|
|
onBuddyAdded(buddy);
|
|
|
|
break;
|
2011-06-17 13:43:31 +02:00
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-06-17 13:43:31 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
BuddyInfo buddyInfo;
|
|
|
|
switch (presence->getType()) {
|
|
|
|
// buddy is not in roster, so add him
|
|
|
|
case Swift::Presence::Subscribe:
|
|
|
|
buddyInfo.id = -1;
|
|
|
|
buddyInfo.alias = "";
|
2016-01-22 15:17:51 +01:00
|
|
|
buddyInfo.legacyName = legacyName;
|
2011-06-17 13:43:31 +02:00
|
|
|
buddyInfo.subscription = "both";
|
2012-08-09 14:57:57 +02:00
|
|
|
buddyInfo.flags = Buddy::buddyFlagsFromJID(presence->getTo());
|
2011-06-21 14:30:49 +02:00
|
|
|
LOG4CXX_INFO(logger, m_user->getJID().toString() << ": Subscription received for new buddy " << buddyInfo.legacyName << " => adding to legacy network");
|
2011-06-17 13:43:31 +02:00
|
|
|
|
|
|
|
buddy = m_component->getFactory()->createBuddy(this, buddyInfo);
|
|
|
|
setBuddy(buddy);
|
|
|
|
onBuddyAdded(buddy);
|
|
|
|
response->setType(Swift::Presence::Subscribed);
|
|
|
|
break;
|
2011-08-13 21:32:48 +02:00
|
|
|
case Swift::Presence::Subscribed:
|
2012-03-09 09:35:36 +01:00
|
|
|
// onBuddyAdded(buddy);
|
2012-03-09 19:36:48 +01:00
|
|
|
return;
|
2012-08-13 08:29:44 +02:00
|
|
|
// buddy is not there, so nothing to do, just answer
|
2011-06-17 13:43:31 +02:00
|
|
|
case Swift::Presence::Unsubscribe:
|
2012-08-13 08:29:44 +02:00
|
|
|
buddyInfo.id = -1;
|
|
|
|
buddyInfo.alias = "";
|
2016-01-22 15:17:51 +01:00
|
|
|
buddyInfo.legacyName = legacyName;
|
2012-08-13 08:29:44 +02:00
|
|
|
buddyInfo.subscription = "both";
|
|
|
|
buddyInfo.flags = Buddy::buddyFlagsFromJID(presence->getTo());
|
|
|
|
|
|
|
|
buddy = m_component->getFactory()->createBuddy(this, buddyInfo);
|
|
|
|
onBuddyRemoved(buddy);
|
|
|
|
delete buddy;
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Unsubscribed);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-06-17 13:43:31 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
2011-07-12 21:18:56 +02:00
|
|
|
Swift::Presence::ref currentPresence;
|
2011-12-08 12:14:13 +01:00
|
|
|
response->setTo(presence->getFrom().toBare());
|
2012-02-17 16:54:40 +01:00
|
|
|
response->setFrom(presence->getTo().toBare());
|
2011-06-17 13:43:31 +02:00
|
|
|
|
2016-01-22 15:17:51 +01:00
|
|
|
Buddy *buddy = getBuddy(legacyName);
|
2011-06-17 13:43:31 +02:00
|
|
|
if (buddy) {
|
2013-02-22 09:45:31 +01:00
|
|
|
std::vector<Swift::Presence::ref> &presences = buddy->generatePresenceStanzas(255);
|
2011-06-17 13:43:31 +02:00
|
|
|
switch (presence->getType()) {
|
|
|
|
// buddy is already there, so nothing to do, just answer
|
|
|
|
case Swift::Presence::Subscribe:
|
2011-08-13 21:32:48 +02:00
|
|
|
onBuddyAdded(buddy);
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Subscribed);
|
2013-02-22 09:45:31 +01:00
|
|
|
BOOST_FOREACH(Swift::Presence::ref ¤tPresence, presences) {
|
2011-07-12 21:18:56 +02:00
|
|
|
currentPresence->setTo(presence->getFrom());
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(currentPresence);
|
2011-07-10 15:32:01 +02:00
|
|
|
}
|
2012-03-09 09:35:36 +01:00
|
|
|
if (buddy->getSubscription() != Buddy::Both) {
|
|
|
|
buddy->setSubscription(Buddy::Both);
|
2012-11-14 14:52:23 +01:00
|
|
|
storeBuddy(buddy);
|
2012-03-09 09:35:36 +01:00
|
|
|
}
|
2011-06-17 13:43:31 +02:00
|
|
|
break;
|
|
|
|
// remove buddy
|
|
|
|
case Swift::Presence::Unsubscribe:
|
|
|
|
response->setType(Swift::Presence::Unsubscribed);
|
|
|
|
onBuddyRemoved(buddy);
|
2012-11-14 14:52:23 +01:00
|
|
|
removeBuddy(buddy->getName());
|
|
|
|
buddy = NULL;
|
2011-06-17 13:43:31 +02:00
|
|
|
break;
|
|
|
|
// just send response
|
|
|
|
case Swift::Presence::Unsubscribed:
|
2011-12-08 12:14:13 +01:00
|
|
|
response->setType(Swift::Presence::Unsubscribe);
|
2012-03-09 09:35:36 +01:00
|
|
|
// We set both here, because this Unsubscribed can be response to
|
|
|
|
// subscribe presence and we don't want that unsubscribe presence
|
|
|
|
// to be send later again
|
|
|
|
if (buddy->getSubscription() != Buddy::Both) {
|
|
|
|
buddy->setSubscription(Buddy::Both);
|
2012-11-14 14:52:23 +01:00
|
|
|
storeBuddy(buddy);
|
2012-03-09 09:35:36 +01:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case Swift::Presence::Subscribed:
|
|
|
|
if (buddy->getSubscription() != Buddy::Both) {
|
|
|
|
buddy->setSubscription(Buddy::Both);
|
2012-11-14 14:52:23 +01:00
|
|
|
storeBuddy(buddy);
|
2012-03-09 09:35:36 +01:00
|
|
|
}
|
2012-03-09 19:36:48 +01:00
|
|
|
return;
|
2011-06-17 13:43:31 +02:00
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
BuddyInfo buddyInfo;
|
|
|
|
switch (presence->getType()) {
|
|
|
|
// buddy is not in roster, so add him
|
|
|
|
case Swift::Presence::Subscribe:
|
|
|
|
buddyInfo.id = -1;
|
|
|
|
buddyInfo.alias = "";
|
2016-01-22 15:17:51 +01:00
|
|
|
buddyInfo.legacyName = legacyName;
|
2011-06-17 13:43:31 +02:00
|
|
|
buddyInfo.subscription = "both";
|
2012-08-09 14:57:57 +02:00
|
|
|
buddyInfo.flags = Buddy::buddyFlagsFromJID(presence->getTo());
|
2011-06-17 13:43:31 +02:00
|
|
|
|
|
|
|
buddy = m_component->getFactory()->createBuddy(this, buddyInfo);
|
|
|
|
setBuddy(buddy);
|
|
|
|
onBuddyAdded(buddy);
|
2013-01-25 13:26:49 +01:00
|
|
|
LOG4CXX_INFO(logger, m_user->getJID().toString() << ": Subscription received for new buddy " << buddyInfo.legacyName << " => adding to legacy network");
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Subscribed);
|
|
|
|
break;
|
|
|
|
case Swift::Presence::Unsubscribe:
|
2012-11-14 14:52:23 +01:00
|
|
|
buddyInfo.id = -1;
|
|
|
|
buddyInfo.alias = "";
|
2016-01-22 15:17:51 +01:00
|
|
|
buddyInfo.legacyName = legacyName;
|
2012-11-14 14:52:23 +01:00
|
|
|
buddyInfo.subscription = "both";
|
|
|
|
buddyInfo.flags = Buddy::buddyFlagsFromJID(presence->getTo());
|
|
|
|
|
2011-06-17 13:43:31 +02:00
|
|
|
response->setType(Swift::Presence::Unsubscribed);
|
2012-11-14 14:52:23 +01:00
|
|
|
|
|
|
|
buddy = m_component->getFactory()->createBuddy(this, buddyInfo);
|
|
|
|
onBuddyRemoved(buddy);
|
|
|
|
delete buddy;
|
|
|
|
buddy = NULL;
|
2011-06-17 13:43:31 +02:00
|
|
|
break;
|
|
|
|
// just send response
|
|
|
|
case Swift::Presence::Unsubscribed:
|
|
|
|
response->setType(Swift::Presence::Unsubscribe);
|
|
|
|
break;
|
|
|
|
// just send response
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-06-17 13:43:31 +02:00
|
|
|
|
|
|
|
// We have to act as buddy and send its subscribe/unsubscribe just to be sure...
|
|
|
|
switch (response->getType()) {
|
|
|
|
case Swift::Presence::Unsubscribed:
|
|
|
|
response->setType(Swift::Presence::Unsubscribe);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-06-17 13:43:31 +02:00
|
|
|
break;
|
|
|
|
case Swift::Presence::Subscribed:
|
|
|
|
response->setType(Swift::Presence::Subscribe);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-06-17 13:43:31 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2011-04-07 09:53:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void RosterManager::setStorageBackend(StorageBackend *storageBackend) {
|
2011-06-13 23:31:06 +02:00
|
|
|
if (m_rosterStorage || !storageBackend) {
|
2011-06-05 11:58:10 +02:00
|
|
|
return;
|
2011-04-07 09:53:33 +02:00
|
|
|
}
|
2012-07-29 05:59:55 +02:00
|
|
|
RosterStorage *storage = new RosterStorage(m_user, storageBackend);
|
2011-05-28 16:38:56 +02:00
|
|
|
|
|
|
|
std::list<BuddyInfo> roster;
|
|
|
|
storageBackend->getBuddies(m_user->getUserInfo().id, roster);
|
|
|
|
|
|
|
|
for (std::list<BuddyInfo>::const_iterator it = roster.begin(); it != roster.end(); it++) {
|
|
|
|
Buddy *buddy = m_component->getFactory()->createBuddy(this, *it);
|
2012-08-07 17:41:13 +02:00
|
|
|
if (buddy) {
|
|
|
|
LOG4CXX_INFO(logger, m_user->getJID().toString() << ": Adding cached buddy " << buddy->getName() << " fom database");
|
2016-01-22 15:17:51 +01:00
|
|
|
std::string name = buddy->getName();
|
2016-01-23 21:58:48 +01:00
|
|
|
name = boost::locale::to_lower(name);
|
2016-01-22 15:17:51 +01:00
|
|
|
m_buddies[name] = buddy;
|
2012-08-07 17:41:13 +02:00
|
|
|
onBuddySet(buddy);
|
|
|
|
}
|
2011-05-28 16:38:56 +02:00
|
|
|
}
|
2012-07-29 05:59:55 +02:00
|
|
|
|
|
|
|
m_rosterStorage = storage;
|
2011-04-06 14:05:52 +02:00
|
|
|
}
|
|
|
|
|
2011-05-31 16:01:17 +02:00
|
|
|
Swift::RosterPayload::ref RosterManager::generateRosterPayload() {
|
|
|
|
Swift::RosterPayload::ref payload = Swift::RosterPayload::ref(new Swift::RosterPayload());
|
|
|
|
|
2017-02-17 13:36:10 +01:00
|
|
|
for (std::map<std::string, Buddy *, std::less<std::string>, boost::pool_allocator< std::pair<const std::string, Buddy *> > >::iterator it = m_buddies.begin(); it != m_buddies.end(); it++) {
|
2011-05-31 16:01:17 +02:00
|
|
|
Buddy *buddy = (*it).second;
|
2011-07-10 15:32:01 +02:00
|
|
|
if (!buddy) {
|
|
|
|
continue;
|
|
|
|
}
|
2011-05-31 16:01:17 +02:00
|
|
|
Swift::RosterItemPayload item;
|
|
|
|
item.setJID(buddy->getJID().toBare());
|
|
|
|
item.setName(buddy->getAlias());
|
|
|
|
item.setGroups(buddy->getGroups());
|
2011-06-10 21:29:28 +02:00
|
|
|
item.setSubscription(Swift::RosterItemPayload::Both);
|
2011-05-31 16:01:17 +02:00
|
|
|
payload->addItem(item);
|
|
|
|
}
|
|
|
|
return payload;
|
|
|
|
}
|
|
|
|
|
2011-06-28 21:57:49 +02:00
|
|
|
void RosterManager::sendCurrentPresences(const Swift::JID &to) {
|
2017-02-17 13:36:10 +01:00
|
|
|
for (std::map<std::string, Buddy *, std::less<std::string>, boost::pool_allocator< std::pair<const std::string, Buddy *> > >::iterator it = m_buddies.begin(); it != m_buddies.end(); it++) {
|
2011-06-28 21:57:49 +02:00
|
|
|
Buddy *buddy = (*it).second;
|
2011-07-10 15:32:01 +02:00
|
|
|
if (!buddy) {
|
|
|
|
continue;
|
|
|
|
}
|
2013-02-22 09:45:31 +01:00
|
|
|
if (!buddy->isAvailable()) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
std::vector<Swift::Presence::ref> &presences = buddy->generatePresenceStanzas(255);
|
|
|
|
BOOST_FOREACH(Swift::Presence::ref &presence, presences) {
|
2011-06-28 21:57:49 +02:00
|
|
|
presence->setTo(to);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(presence);
|
2011-06-28 21:57:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-08-05 09:30:24 +02:00
|
|
|
void RosterManager::sendCurrentPresence(const Swift::JID &from, const Swift::JID &to) {
|
2016-01-22 15:17:51 +01:00
|
|
|
Buddy *buddy = Buddy::JIDToBuddy(from, m_user);
|
2011-08-05 09:30:24 +02:00
|
|
|
if (buddy) {
|
2013-02-22 09:45:31 +01:00
|
|
|
std::vector<Swift::Presence::ref> &presences = buddy->generatePresenceStanzas(255);
|
|
|
|
BOOST_FOREACH(Swift::Presence::ref &presence, presences) {
|
2011-08-05 09:30:24 +02:00
|
|
|
presence->setTo(to);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(presence);
|
2011-08-05 09:30:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
|
|
|
response->setTo(to);
|
|
|
|
response->setFrom(from);
|
|
|
|
response->setType(Swift::Presence::Unavailable);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-08-05 09:30:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-07-12 22:02:02 +02:00
|
|
|
void RosterManager::sendUnavailablePresences(const Swift::JID &to) {
|
2017-02-17 13:36:10 +01:00
|
|
|
for (std::map<std::string, Buddy *, std::less<std::string>, boost::pool_allocator< std::pair<const std::string, Buddy *> > >::iterator it = m_buddies.begin(); it != m_buddies.end(); it++) {
|
2011-07-12 22:02:02 +02:00
|
|
|
Buddy *buddy = (*it).second;
|
|
|
|
if (!buddy) {
|
|
|
|
continue;
|
|
|
|
}
|
2013-02-22 09:45:31 +01:00
|
|
|
|
|
|
|
if (!buddy->isAvailable()) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<Swift::Presence::ref> &presences = buddy->generatePresenceStanzas(255);
|
|
|
|
BOOST_FOREACH(Swift::Presence::ref &presence, presences) {
|
|
|
|
Swift::Presence::Type type = presence->getType();
|
2011-07-12 22:02:02 +02:00
|
|
|
presence->setTo(to);
|
|
|
|
presence->setType(Swift::Presence::Unavailable);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(presence);
|
2013-02-22 09:45:31 +01:00
|
|
|
presence->setType(type);
|
2011-07-12 22:02:02 +02:00
|
|
|
}
|
|
|
|
}
|
2011-09-11 12:09:07 +02:00
|
|
|
|
|
|
|
// in gateway mode, we have to send unavailable presence for transport
|
|
|
|
// contact
|
|
|
|
Swift::Presence::ref response = Swift::Presence::create();
|
|
|
|
response->setTo(to);
|
|
|
|
response->setFrom(m_component->getJID());
|
|
|
|
response->setType(Swift::Presence::Unavailable);
|
2015-11-16 10:49:10 +01:00
|
|
|
m_component->getFrontend()->sendPresence(response);
|
2011-07-12 22:02:02 +02:00
|
|
|
}
|
|
|
|
|
2011-04-06 14:32:03 +02:00
|
|
|
}
|