diff options
author | Vincent Richard <[email protected]> | 2005-08-23 20:26:20 +0000 |
---|---|---|
committer | Vincent Richard <[email protected]> | 2005-08-23 20:26:20 +0000 |
commit | a530f25c79c2da9483caa6b7c0f3c17e12e379c6 (patch) | |
tree | 326f115b099088b76eedd49aa2da050487b1d19f /src/messaging/serviceFactory.cpp | |
parent | Renamed 'vmime::messaging' to 'vmime::net'. (diff) | |
download | vmime-a530f25c79c2da9483caa6b7c0f3c17e12e379c6.tar.gz vmime-a530f25c79c2da9483caa6b7c0f3c17e12e379c6.zip |
Renamed 'vmime::messaging' to 'vmime::net'.
Diffstat (limited to 'src/messaging/serviceFactory.cpp')
-rw-r--r-- | src/messaging/serviceFactory.cpp | 124 |
1 files changed, 0 insertions, 124 deletions
diff --git a/src/messaging/serviceFactory.cpp b/src/messaging/serviceFactory.cpp deleted file mode 100644 index a706b0ba..00000000 --- a/src/messaging/serviceFactory.cpp +++ /dev/null @@ -1,124 +0,0 @@ -// -// VMime library (http://www.vmime.org) -// Copyright (C) 2002-2005 Vincent Richard <[email protected]> -// -// 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., 675 Mass Ave, Cambridge, MA 02139, USA. -// - -#include "vmime/messaging/serviceFactory.hpp" -#include "vmime/messaging/service.hpp" - -#include "vmime/exception.hpp" -#include "vmime/config.hpp" - -#include "src/messaging/builtinServices.inl" - - -namespace vmime { -namespace messaging { - - -serviceFactory::serviceFactory() -{ -} - - -serviceFactory::~serviceFactory() -{ -} - - -serviceFactory* serviceFactory::getInstance() -{ - static serviceFactory instance; - return (&instance); -} - - -ref <service> serviceFactory::create - (ref <session> sess, const string& protocol, ref <authenticator> auth) -{ - return (getServiceByProtocol(protocol)->create(sess, auth)); -} - - -ref <service> serviceFactory::create - (ref <session> sess, const utility::url& u, ref <authenticator> auth) -{ - ref <service> serv = create(sess, u.getProtocol(), auth); - - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.address"] = u.getHost(); - - if (u.getPort() != utility::url::UNSPECIFIED_PORT) - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.port"] = u.getPort(); - - // Path portion of the URL is used to point a specific folder (empty = root). - // In maildir, this is used to point to the root of the message repository. - if (!u.getPath().empty()) - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.rootpath"] = u.getPath(); - - if (!u.getUsername().empty()) - { - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "auth.username"] = u.getUsername(); - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "auth.password"] = u.getPassword(); - } - - return (serv); -} - - -ref <const serviceFactory::registeredService> serviceFactory::getServiceByProtocol(const string& protocol) const -{ - const string name(utility::stringUtils::toLower(protocol)); - - for (std::vector <ref <registeredService> >::const_iterator it = m_services.begin() ; - it != m_services.end() ; ++it) - { - if ((*it)->getName() == name) - return (*it); - } - - throw exceptions::no_service_available(name); -} - - -const int serviceFactory::getServiceCount() const -{ - return (m_services.size()); -} - - -ref <const serviceFactory::registeredService> serviceFactory::getServiceAt(const int pos) const -{ - return (m_services[pos]); -} - - -const std::vector <ref <const serviceFactory::registeredService> > serviceFactory::getServiceList() const -{ - std::vector <ref <const registeredService> > res; - - for (std::vector <ref <registeredService> >::const_iterator it = m_services.begin() ; - it != m_services.end() ; ++it) - { - res.push_back(*it); - } - - return (res); -} - - -} // messaging -} // vmime |