aboutsummaryrefslogtreecommitdiffstats
path: root/src/net/session.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/net/session.cpp')
-rw-r--r--src/net/session.cpp16
1 files changed, 8 insertions, 8 deletions
diff --git a/src/net/session.cpp b/src/net/session.cpp
index fcc5dd12..36b9f2c3 100644
--- a/src/net/session.cpp
+++ b/src/net/session.cpp
@@ -74,8 +74,8 @@ shared_ptr <transport> session::getTransport
shared_ptr <session> sess(dynamicCast <session>(shared_from_this()));
shared_ptr <service> sv = serviceFactory::getInstance()->create(sess, protocol, auth);
- if (sv->getType() != service::TYPE_TRANSPORT)
- throw exceptions::no_service_available();
+ if (!sv || sv->getType() != service::TYPE_TRANSPORT)
+ return null;
return dynamicCast <transport>(sv);
}
@@ -87,8 +87,8 @@ shared_ptr <transport> session::getTransport
shared_ptr <session> sess(dynamicCast <session>(shared_from_this()));
shared_ptr <service> sv = serviceFactory::getInstance()->create(sess, url, auth);
- if (sv->getType() != service::TYPE_TRANSPORT)
- throw exceptions::no_service_available();
+ if (!sv || sv->getType() != service::TYPE_TRANSPORT)
+ return null;
return dynamicCast <transport>(sv);
}
@@ -106,8 +106,8 @@ shared_ptr <store> session::getStore
shared_ptr <session> sess(dynamicCast <session>(shared_from_this()));
shared_ptr <service> sv = serviceFactory::getInstance()->create(sess, protocol, auth);
- if (sv->getType() != service::TYPE_STORE)
- throw exceptions::no_service_available();
+ if (!sv || sv->getType() != service::TYPE_STORE)
+ return null;
return dynamicCast <store>(sv);
}
@@ -119,8 +119,8 @@ shared_ptr <store> session::getStore
shared_ptr <session> sess(dynamicCast <session>(shared_from_this()));
shared_ptr <service> sv = serviceFactory::getInstance()->create(sess, url, auth);
- if (sv->getType() != service::TYPE_STORE)
- throw exceptions::no_service_available();
+ if (!sv || sv->getType() != service::TYPE_STORE)
+ return null;
return dynamicCast <store>(sv);
}