Files
@ d6c003bad3b6
Branch filter:
Location: libtransport.git/src/user.cpp - annotation
d6c003bad3b6
5.8 KiB
text/x-c++hdr
Added AttentionPayload + parser and serializer
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 | c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa 2ae880ff94b5 88865c1234e3 50bcfbf84cb1 76c678dd6f1d c5edfd19b1aa 3f3c73988787 3f3c73988787 1ebe5535c4f3 c00d5149d528 c00d5149d528 c00d5149d528 c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c00d5149d528 c00d5149d528 50bcfbf84cb1 c5edfd19b1aa c5edfd19b1aa 2ae880ff94b5 c5edfd19b1aa c5edfd19b1aa 50bcfbf84cb1 2ae880ff94b5 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 d39705842a2a 5f017bd15dc7 88865c1234e3 88865c1234e3 76c678dd6f1d c00d5149d528 c5edfd19b1aa 2ae880ff94b5 c5edfd19b1aa c00d5149d528 50bcfbf84cb1 88865c1234e3 76c678dd6f1d c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa c5edfd19b1aa 2ae880ff94b5 2ae880ff94b5 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 c00d5149d528 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 62fcb141926d c00d5149d528 c00d5149d528 c00d5149d528 62fcb141926d 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 1ebe5535c4f3 1ebe5535c4f3 2c526db0f32e c00d5149d528 2c526db0f32e 2c526db0f32e 2c526db0f32e 8e03fbec4701 8e03fbec4701 c00d5149d528 8e03fbec4701 8e03fbec4701 8e03fbec4701 c00d5149d528 2c526db0f32e 2c526db0f32e 1ebe5535c4f3 1ebe5535c4f3 5f017bd15dc7 2ae880ff94b5 5f017bd15dc7 2ae880ff94b5 79cc6dc63de8 c00d5149d528 bdc94b104270 2ae880ff94b5 2ae880ff94b5 2ae880ff94b5 2ae880ff94b5 2ae880ff94b5 2ae880ff94b5 79cc6dc63de8 bdc94b104270 2ae880ff94b5 2ae880ff94b5 2ae880ff94b5 5797b554ea69 5797b554ea69 5797b554ea69 5797b554ea69 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 5f017bd15dc7 50bcfbf84cb1 c00d5149d528 c00d5149d528 c00d5149d528 c00d5149d528 c00d5149d528 c00d5149d528 50bcfbf84cb1 c7dd572625a2 c7dd572625a2 c7dd572625a2 c7dd572625a2 6a4fffdfe8c7 c7dd572625a2 cdb464dd99d4 6a4fffdfe8c7 cdb464dd99d4 6a4fffdfe8c7 c7dd572625a2 50bcfbf84cb1 50bcfbf84cb1 50bcfbf84cb1 c5edfd19b1aa | /**
* libtransport -- C++ library for easy XMPP Transports development
*
* Copyright (C) 2011, Jan Kaluza <hanzz.k@gmail.com>
*
* 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
*/
#include "transport/user.h"
#include "transport/transport.h"
#include "transport/storagebackend.h"
#include "transport/rostermanager.h"
#include "transport/usermanager.h"
#include "transport/conversationmanager.h"
#include "Swiften/Swiften.h"
#include "Swiften/Server/ServerStanzaChannel.h"
#include "Swiften/Elements/StreamError.h"
#include "Swiften/Elements/MUCPayload.h"
#include "log4cxx/logger.h"
using namespace log4cxx;
namespace Transport {
static LoggerPtr logger = Logger::getLogger("User");
User::User(const Swift::JID &jid, UserInfo &userInfo, Component *component, UserManager *userManager) {
m_jid = jid;
m_component = component;
m_presenceOracle = component->m_presenceOracle;
m_entityCapsManager = component->m_entityCapsManager;
m_userManager = userManager;
m_userInfo = userInfo;
m_connected = false;
m_readyForConnect = false;
m_reconnectTimer = m_component->getNetworkFactories()->getTimerFactory()->createTimer(10000);
m_reconnectTimer->onTick.connect(boost::bind(&User::onConnectingTimeout, this));
m_rosterManager = new RosterManager(this, m_component);
m_conversationManager = new ConversationManager(this, m_component);
LOG4CXX_INFO(logger, m_jid.toString() << ": Created");
}
User::~User(){
LOG4CXX_INFO(logger, m_jid.toString() << ": Destroying");
m_reconnectTimer->stop();
delete m_rosterManager;
delete m_conversationManager;
}
const Swift::JID &User::getJID() {
return m_jid;
}
void User::handlePresence(Swift::Presence::ref presence) {
Swift::Presence::ref highest = m_presenceOracle->getHighestPriorityPresence(m_jid.toBare());
if (!m_connected) {
// we are not connected to legacy network, so we should do it when disco#info arrive :)
if (m_readyForConnect == false) {
// Forward status message to legacy network, but only if it's sent from active resource
// if (m_activeResource == presence->getFrom().getResource().getUTF8String()) {
// forwardStatus(presenceShow, stanzaStatus);
// }
boost::shared_ptr<Swift::CapsInfo> capsInfo = presence->getPayload<Swift::CapsInfo>();
if (capsInfo && capsInfo->getHash() == "sha-1") {
if (m_entityCapsManager->getCaps(presence->getFrom()) != Swift::DiscoInfo::ref()) {
LOG4CXX_INFO(logger, m_jid.toString() << ": Ready to be connected to legacy network");
m_readyForConnect = true;
onReadyToConnect();
}
}
else if (m_component->inServerMode()) {
LOG4CXX_INFO(logger, m_jid.toString() << ": Ready to be connected to legacy network");
m_readyForConnect = true;
onReadyToConnect();
}
else {
m_reconnectTimer->start();
}
}
}
bool isMUC = presence->getPayload<Swift::MUCPayload>() != NULL || *presence->getTo().getNode().c_str() == '#';
if (isMUC) {
if (presence->getType() == Swift::Presence::Unavailable) {
LOG4CXX_INFO(logger, m_jid.toString() << ": Going to left room " << presence->getTo().getNode());
onRoomLeft(presence->getTo().getNode());
}
else {
// force connection to legacy network to let backend to handle auto-join on connect.
if (!m_readyForConnect) {
LOG4CXX_INFO(logger, m_jid.toString() << ": Ready to be connected to legacy network");
m_readyForConnect = true;
onReadyToConnect();
}
LOG4CXX_INFO(logger, m_jid.toString() << ": Going to join room " << presence->getTo().getNode() << " as " << presence->getTo().getResource());
onRoomJoined(presence->getTo().getNode(), presence->getTo().getResource(), "");
}
return;
}
if (highest) {
highest->setTo(presence->getFrom().toBare());
highest->setFrom(m_component->getJID());
m_component->getStanzaChannel()->sendPresence(highest);
LOG4CXX_INFO(logger, m_jid.toString() << ": Changing legacy network presence to " << highest->getType());
onPresenceChanged(highest);
}
else {
Swift::Presence::ref response = Swift::Presence::create();
response->setTo(m_jid.toBare());
response->setFrom(m_component->getJID());
response->setType(Swift::Presence::Unavailable);
m_component->getStanzaChannel()->sendPresence(response);
onPresenceChanged(response);
}
}
void User::handleSubscription(Swift::Presence::ref presence) {
m_rosterManager->handleSubscription(presence);
}
void User::onConnectingTimeout() {
if (m_connected || m_readyForConnect)
return;
m_reconnectTimer->stop();
m_readyForConnect = true;
onReadyToConnect();
}
void User::handleDisconnected(const std::string &error) {
if (error.empty()) {
LOG4CXX_INFO(logger, m_jid.toString() << ": Disconnected from legacy network");
}
else {
LOG4CXX_INFO(logger, m_jid.toString() << ": Disconnected from legacy network with error " << error);
}
onDisconnected();
boost::shared_ptr<Swift::Message> msg(new Swift::Message());
msg->setBody(error);
msg->setTo(m_jid.toBare());
msg->setFrom(m_component->getJID());
m_component->getStanzaChannel()->sendMessage(msg);
if (m_component->inServerMode()) {
dynamic_cast<Swift::ServerStanzaChannel *>(m_component->getStanzaChannel())->finishSession(m_jid, boost::shared_ptr<Swift::Element>(new Swift::StreamError()));
}
m_userManager->removeUser(this);
}
}
|