version 1.22, 2004/08/16 14:03:43
|
version 1.23, 2004/08/26 17:04:01
|
|
|
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
} | } |
| |
|
Uint32 CIMListenerService::getOutstandingRequestCount() |
|
{ |
|
return _acceptor->getOutstandingRequestCount(); |
|
} |
| |
CIMListenerIndicationDispatcher* CIMListenerService::getIndicationDispatcher() const | CIMListenerIndicationDispatcher* CIMListenerService::getIndicationDispatcher() const |
{ | { |
|
|
#endif | #endif |
svc->runForever(); | svc->runForever(); |
} | } |
|
|
delete svc; | delete svc; |
| |
return 0; | return 0; |
|
|
Boolean removeConsumer(CIMIndicationConsumer* consumer); | Boolean removeConsumer(CIMIndicationConsumer* consumer); |
| |
private: | private: |
|
Boolean waitForPendingRequests(Uint32 shutdownTimeout); |
|
|
Uint32 _portNumber; | Uint32 _portNumber; |
SSLContext* _sslContext; | SSLContext* _sslContext; |
| |
|
|
// Block incoming export requests and unbind the port | // Block incoming export requests and unbind the port |
_svc->stopClientConnection(); | _svc->stopClientConnection(); |
| |
|
// Wait until pending export requests in the server are done. |
|
waitForPendingRequests(10); |
|
|
// Shutdown the CIMListenerService | // Shutdown the CIMListenerService |
_svc->shutdown(); | _svc->shutdown(); |
} | } |
|
|
// Block incoming export requests and unbind the port | // Block incoming export requests and unbind the port |
_svc->stopClientConnection(); | _svc->stopClientConnection(); |
| |
|
// Wait until pending export requests in the server are done. |
|
if (!waitForPendingRequests(10)) |
|
{ |
|
// Pendings requests did not finish in time. |
|
MessageLoaderParms parms("Listener.CIMListenerRep.SHUTDOWN_TIMEOUT", |
|
"The CIMListener could not be stopped after $0 seconds because export requests have not finished.", |
|
10); |
|
throw Exception(parms); |
|
} |
|
|
// Shutdown the CIMListenerService | // Shutdown the CIMListenerService |
_svc->shutdown(); | _svc->shutdown(); |
| |
|
|
return _dispatcher->removeConsumer(consumer); | return _dispatcher->removeConsumer(consumer); |
} | } |
| |
|
Boolean CIMListenerRep::waitForPendingRequests(Uint32 shutdownTimeout) |
|
{ |
|
// Wait for 10 sec max |
|
Uint32 reqCount; |
|
Uint32 countDown = shutdownTimeout * 10; |
|
for (; countDown > 0; countDown--) |
|
{ |
|
reqCount = _svc->getOutstandingRequestCount(); |
|
if (reqCount > 0) |
|
pegasus_sleep(100); |
|
else |
|
return true; |
|
} |
|
|
|
return false; |
|
} |
|
|
///////////////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////////////// |
// CIMListener | // CIMListener |
///////////////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////////////// |