summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/AdminSessionI.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/src/IceGrid/AdminSessionI.cpp')
-rw-r--r--cpp/src/IceGrid/AdminSessionI.cpp17
1 files changed, 11 insertions, 6 deletions
diff --git a/cpp/src/IceGrid/AdminSessionI.cpp b/cpp/src/IceGrid/AdminSessionI.cpp
index cfe57adc0db..e1b31d4e98f 100644
--- a/cpp/src/IceGrid/AdminSessionI.cpp
+++ b/cpp/src/IceGrid/AdminSessionI.cpp
@@ -58,11 +58,16 @@ AdminSessionI::setObservers(const RegistryObserverPrx& registryObserver,
throw ex;
}
- setupObserverSubscription(RegistryObserverTopicName, registryObserver);
- setupObserverSubscription(NodeObserverTopicName, nodeObserver);
- setupObserverSubscription(ApplicationObserverTopicName, appObserver);
- setupObserverSubscription(AdapterObserverTopicName, adapterObserver);
- setupObserverSubscription(ObjectObserverTopicName, objectObserver);
+ setupObserverSubscription(RegistryObserverTopicName,
+ registryObserver ? registryObserver->ice_timeout(_timeout * 1000) : 0);
+ setupObserverSubscription(NodeObserverTopicName,
+ nodeObserver ? nodeObserver->ice_timeout(_timeout * 1000) : 0);
+ setupObserverSubscription(ApplicationObserverTopicName,
+ appObserver ? appObserver->ice_timeout(_timeout * 1000) : 0);
+ setupObserverSubscription(AdapterObserverTopicName,
+ adapterObserver ? adapterObserver->ice_timeout(_timeout * 1000) : 0);
+ setupObserverSubscription(ObjectObserverTopicName,
+ objectObserver ? objectObserver->ice_timeout(_timeout * 1000) : 0);
}
void
@@ -286,7 +291,7 @@ AdminSessionI::setupObserverSubscription(TopicName name, const Ice::ObjectPrx& o
if(observer)
{
- _observers[name] = observer->ice_timeout(_timeout * 1000);
+ _observers[name] = observer;
_database->getObserverTopic(name)->subscribe(_observers[name]);
}
}