diff --git a/src/blockresponder.cpp b/src/blockresponder.cpp new file mode 100644 index 0000000000000000000000000000000000000000..7710fcc6ebc4ba99bd5a5f7be2569e26c31ed009 --- /dev/null +++ b/src/blockresponder.cpp @@ -0,0 +1,69 @@ +/** + * 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 + */ + +#include "blockresponder.h" + +#include +#include +#include "Swiften/Queries/IQRouter.h" +#include "Swiften/Elements/BlockPayload.h" +#include "Swiften/Swiften.h" +#include "transport/usermanager.h" +#include "transport/user.h" +#include "transport/buddy.h" +#include "transport/rostermanager.h" +#include "log4cxx/logger.h" + +using namespace log4cxx; + +using namespace Swift; +using namespace boost; + +namespace Transport { + +static LoggerPtr logger = Logger::getLogger("BlockResponder"); + +BlockResponder::BlockResponder(Swift::IQRouter *router, UserManager *userManager) : Swift::SetResponder(router) { + m_userManager = userManager; +} + +BlockResponder::~BlockResponder() { + +} + +bool BlockResponder::handleSetRequest(const Swift::JID& from, const Swift::JID& to, const std::string& id, boost::shared_ptr info) { + User *user = m_userManager->getUser(from.toBare().toString()); + if (!user) { + LOG4CXX_WARN(logger, from.toBare().toString() << ": User is not logged in"); + return true; + } + + Buddy *buddy = user->getRosterManager()->getBuddy(Buddy::JIDToLegacyName(to)); + if (buddy) { + LOG4CXX_WARN(logger, from.toBare().toString() << ": Buddy " << Buddy::JIDToLegacyName(to) << " does not exist"); + return true; + } + + onBlockToggled(buddy); + + return true; +} + +}