// ********************************************************************** // // Copyright (c) 2003-2014 ZeroC, Inc. All rights reserved. // // This copy of Ice is licensed to you under the terms described in the // ICE_LICENSE file included in this distribution. // // ********************************************************************** #include #include #include using namespace std; using namespace IceGrid; WellKnownObjectsManager::WellKnownObjectsManager(const DatabasePtr& database) : _database(database), _initialized(false) { } void WellKnownObjectsManager::add(const Ice::ObjectPrx& proxy, const string& type) { assert(!_initialized); ObjectInfo info; info.type = type; info.proxy = proxy; _wellKnownObjects.push_back(info); } void WellKnownObjectsManager::addEndpoint(const string& name, const Ice::ObjectPrx& proxy) { _endpoints.insert(make_pair(name, proxy)); } void WellKnownObjectsManager::finish() { Lock sync(*this); _initialized = true; } void WellKnownObjectsManager::registerAll(const ReplicaSessionPrx& session) { if(!initialized()) { return; } assert(session); // // If initialized, the endpoints and well known objects are immutable. // session->setEndpoints(_endpoints); session->registerWellKnownObjects(_wellKnownObjects); } void WellKnownObjectsManager::registerAll() { if(!initialized()) { return; } // // If initialized, the endpoints and well known objects are immutable. // updateReplicatedWellKnownObjects(); _database->addOrUpdateRegistryWellKnownObjects(_wellKnownObjects); } void WellKnownObjectsManager::updateReplicatedWellKnownObjects() { if(!initialized()) { return; } // // Update replicated objects. // Ice::Identity id; id.category = _database->getInstanceName(); ObjectInfo info; ObjectInfoSeq objects; Lock sync(*this); Ice::ObjectPrx replicatedClientProxy = _database->getReplicaCache().getEndpoints("Client", _endpoints["Client"]); id.name = "Query"; info.type = Query::ice_staticId(); info.proxy = replicatedClientProxy->ice_identity(id); objects.push_back(info); id.name = "Locator"; info.type = Ice::Locator::ice_staticId(); info.proxy = replicatedClientProxy->ice_identity(id); objects.push_back(info); id.name = "LocatorRegistry"; info.type = Ice::Locator::ice_staticId(); info.proxy = _database->getReplicaCache().getEndpoints("Server", _endpoints["Server"])->ice_identity(id); objects.push_back(info); _database->addOrUpdateRegistryWellKnownObjects(objects); } bool WellKnownObjectsManager::initialized() const { Lock sync(*this); return _initialized; } Ice::ObjectPrx WellKnownObjectsManager::getEndpoints(const string& name) { Lock sync(*this); return _endpoints[name]; } LocatorPrx WellKnownObjectsManager::getLocator() { Ice::Identity id; id.name = "Locator"; id.category = _database->getInstanceName(); return LocatorPrx::uncheckedCast(getWellKnownObjectReplicatedProxy(id, "Client")); } Ice::LocatorRegistryPrx WellKnownObjectsManager::getLocatorRegistry() { Ice::Identity id; id.name = "LocatorRegistry"; id.category = _database->getInstanceName(); return Ice::LocatorRegistryPrx::uncheckedCast(getWellKnownObjectReplicatedProxy(id, "Server")); } Ice::ObjectPrx WellKnownObjectsManager::getWellKnownObjectReplicatedProxy(const Ice::Identity& id, const string& endpt) { try { Ice::ObjectPrx proxy = _database->getObjectProxy(id); Ice::EndpointSeq registryEndpoints = getEndpoints(endpt)->ice_getEndpoints(); // // Re-order the endpoints to return first the endpoint for this // registry replica. // Ice::EndpointSeq endpoints = proxy->ice_getEndpoints(); Ice::EndpointSeq newEndpoints = registryEndpoints; for(Ice::EndpointSeq::const_iterator p = endpoints.begin(); p != endpoints.end(); ++p) { if(find(registryEndpoints.begin(), registryEndpoints.end(), *p) == registryEndpoints.end()) { newEndpoints.push_back(*p); } } return proxy->ice_endpoints(newEndpoints); } catch(const ObjectNotRegisteredException&) { // // If for some reasons the object isn't registered, we compute // the endpoints with the replica cache. For slaves, this will // however only return the slave endpoints. // return _database->getReplicaCache().getEndpoints(endpt, getEndpoints(endpt))->ice_identity(id); } }