version 1.33, 2002/05/01 21:32:53
|
version 1.52, 2004/06/10 20:07:38
|
|
|
//%///-*-c++-*-///////////////////////////////////////////////////////////////// |
//%2003//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001 BMC Software, Hewlett-Packard Company, IBM, |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
// The Open Group, Tivoli Systems |
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// Mike Day (mdday@us.ibm.com) | // Mike Day (mdday@us.ibm.com) |
// Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) | // Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
// Arthur Pichlkostner (via Markus: sedgewick_de@yahoo.de) | // Arthur Pichlkostner (via Markus: sedgewick_de@yahoo.de) |
|
// Willis White (whiwill@us.ibm.com) |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
#include <iostream> | #include <iostream> |
#include <cstring> | #include <cstring> |
#include <Pegasus/Common/Exception.h> |
#include <Pegasus/Common/InternalException.h> |
#include <Pegasus/Common/IPC.h> | #include <Pegasus/Common/IPC.h> |
#include <Pegasus/Common/StatisticalData.h> | #include <Pegasus/Common/StatisticalData.h> |
|
#include <Pegasus/Common/Linkage.h> |
|
#include <Pegasus/Common/CIMDateTime.h> |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
|
|
class AsyncLegacyOperationStart; | class AsyncLegacyOperationStart; |
class AsyncLegacyOperationResult; | class AsyncLegacyOperationResult; |
| |
|
enum HttpMethod |
|
{ |
|
HTTP_METHOD__POST, |
|
HTTP_METHOD_M_POST |
|
}; |
|
|
/** The Message class and derived classes are used to pass messages between | /** The Message class and derived classes are used to pass messages between |
modules. Messages are passed between modules using the message queues | modules. Messages are passed between modules using the message queues |
(see MessageQueue class). Derived classes may add their own fields. | (see MessageQueue class). Derived classes may add their own fields. |
|
|
_key(key), | _key(key), |
_routing_code(routing_code), | _routing_code(routing_code), |
_mask(mask), | _mask(mask), |
|
_httpMethod (HTTP_METHOD__POST), |
|
_last_thread_id(pegasus_thread_self()), |
_next(0), | _next(0), |
_prev(0), | _prev(0), |
_async(0), | _async(0), |
|
|
| |
} | } |
| |
Message(const Message & msg) |
|
{ |
|
if( this != &msg) |
|
{ |
|
_type = msg._type; |
|
_key = msg._key; |
|
_routing_code = msg._routing_code; |
|
_mask = msg._mask; |
|
_next = _prev = _async = 0; |
|
dest = msg.dest; |
|
} |
|
} |
|
|
|
Message & operator = ( const Message & msg) | Message & operator = ( const Message & msg) |
{ | { |
if (this != &msg) | if (this != &msg) |
|
|
_key = msg._key; | _key = msg._key; |
_routing_code = msg._routing_code; | _routing_code = msg._routing_code; |
_mask = msg._mask; | _mask = msg._mask; |
|
_last_thread_id = msg._last_thread_id; |
_next = _prev = _async = 0; | _next = _prev = _async = 0; |
dest = msg.dest; | dest = msg.dest; |
|
_httpMethod = msg._httpMethod; |
|
|
} | } |
return *this; | return *this; |
} | } |
|
|
| |
void setMask(Uint32 mask) { _mask = mask; } | void setMask(Uint32 mask) { _mask = mask; } |
| |
|
HttpMethod getHttpMethod() const { return _httpMethod; } |
|
|
|
void setHttpMethod(HttpMethod httpMethod) {_httpMethod = httpMethod;} |
|
|
#ifdef PEGASUS_HAS_PERFINST | #ifdef PEGASUS_HAS_PERFINST |
// | // |
// Needed for performance measurement | // Needed for performance measurement |
|
|
| |
void endProvider(); | void endProvider(); |
| |
timeval getStartServerTime() const { return _timeServerStart; } |
CIMDateTime getStartServerTime() const { return _timeServerStart; } |
| |
void setStartServerTime(timeval timeServerStart) |
void setStartServerTime(CIMDateTime timeServerStart) |
{ | { |
_timeServerStart = timeServerStart; | _timeServerStart = timeServerStart; |
} | } |
| |
timeval getStartProviderTime() const { return _timeProviderStart; } |
CIMDateTime getStartProviderTime() const { return _timeProviderStart; } |
| |
void setStartProviderTime(timeval timeProviderStart) |
void setStartProviderTime(CIMDateTime timeProviderStart) |
{ | { |
_timeProviderStart = timeProviderStart; | _timeProviderStart = timeProviderStart; |
} | } |
| |
timeval getEndServerTime() const { return _timeServerEnd; } |
CIMDateTime getEndServerTime() const { return _timeServerEnd; } |
| |
void setEndServerTime (timeval timeServerEnd) |
void setEndServerTime (CIMDateTime timeServerEnd) |
{ | { |
_timeServerEnd = timeServerEnd; | _timeServerEnd = timeServerEnd; |
} | } |
| |
timeval getEndProviderTime() const { return _timeProviderEnd; } |
CIMDateTime getEndProviderTime() const { return _timeProviderEnd; } |
| |
void setEndProviderTime(timeval timeProviderEnd) |
void setEndProviderTime(CIMDateTime timeProviderEnd) |
{ | { |
_timeProviderEnd = timeProviderEnd; | _timeProviderEnd = timeProviderEnd; |
} | } |
| |
Uint32 getTotalTime() { return _totalTime; } |
CIMDateTime getProviderTime() { return _providerTime;} |
|
|
|
CIMDateTime getTotalTime() { return _totalTime; } |
|
|
|
CIMDateTime getServerTime() { return _serverTime; } |
// | // |
#endif | #endif |
| |
|
|
return ret; | return ret; |
} | } |
| |
virtual void print(PEGASUS_STD(ostream)& os) const; |
virtual void print( |
|
PEGASUS_STD(ostream)& os, |
|
Boolean printHeader = true) const; |
| |
// << Thu Dec 27 10:46:04 2001 mdd >> for use with DQueue container | // << Thu Dec 27 10:46:04 2001 mdd >> for use with DQueue container |
// as used by AsyncOpNode | // as used by AsyncOpNode |
|
|
_async = msg; | _async = msg; |
} | } |
| |
|
// << Tue Jul 1 11:02:49 2003 mdd >> pep_88 and helper for i18n and l10n |
|
Boolean thread_changed(void) |
|
{ |
|
if(_last_thread_id != pegasus_thread_self()) |
|
{ |
|
_last_thread_id = pegasus_thread_self(); |
|
return true; |
|
} |
|
|
|
return false; |
|
} |
|
|
|
// << Tue Jul 1 13:41:02 2003 mdd >> pep_88 - |
|
// assist in synchronizing responses with requests |
|
|
|
void synch_response(Message *req) |
|
{ |
|
_key = req->_key; |
|
_routing_code = req->_routing_code; |
|
} |
|
|
| |
private: | private: |
Uint32 _type; | Uint32 _type; |
Uint32 _key; | Uint32 _key; |
Uint32 _routing_code; | Uint32 _routing_code; |
Uint32 _mask; | Uint32 _mask; |
|
HttpMethod _httpMethod; |
// Needed for performance measurement | // Needed for performance measurement |
timeval _timeServerStart; |
CIMDateTime _timeServerStart; |
timeval _timeServerEnd; |
CIMDateTime _timeServerEnd; |
timeval _timeProviderStart; |
CIMDateTime _timeProviderStart; |
timeval _timeProviderEnd; |
CIMDateTime _timeProviderEnd; |
Uint64 _totalTime; |
CIMDateTime _providerTime; |
|
CIMDateTime _serverTime; |
|
CIMDateTime _totalTime; |
// | // |
|
|
|
// << Tue Jul 1 11:02:35 2003 mdd >> pep_88 and helper for i18n and l10n |
|
PEGASUS_THREAD_TYPE _last_thread_id; |
|
|
Message* _next; | Message* _next; |
Message* _prev; | Message* _prev; |
| |
|
|
MessageQueue* _owner; | MessageQueue* _owner; |
static Uint32 _nextKey; | static Uint32 _nextKey; |
static Mutex _mut; | static Mutex _mut; |
|
|
|
|
|
|
friend class cimom; | friend class cimom; |
friend class MessageQueue; | friend class MessageQueue; |
friend class MessageQueueService; | friend class MessageQueueService; |
|
|
CIM_DISABLE_MODULE_REQUEST_MESSAGE, | CIM_DISABLE_MODULE_REQUEST_MESSAGE, |
CIM_ENABLE_MODULE_REQUEST_MESSAGE, | CIM_ENABLE_MODULE_REQUEST_MESSAGE, |
| |
CIM_GET_CLASS_RESPONSE_MESSAGE, // 40 |
CIM_STOP_ALL_PROVIDERS_REQUEST_MESSAGE, // 40 |
|
|
|
CIM_GET_CLASS_RESPONSE_MESSAGE, |
CIM_GET_INSTANCE_RESPONSE_MESSAGE, | CIM_GET_INSTANCE_RESPONSE_MESSAGE, |
CIM_EXPORT_INDICATION_RESPONSE_MESSAGE, // 42 |
CIM_EXPORT_INDICATION_RESPONSE_MESSAGE, |
CIM_DELETE_CLASS_RESPONSE_MESSAGE, | CIM_DELETE_CLASS_RESPONSE_MESSAGE, |
CIM_DELETE_INSTANCE_RESPONSE_MESSAGE, | CIM_DELETE_INSTANCE_RESPONSE_MESSAGE, |
CIM_CREATE_CLASS_RESPONSE_MESSAGE, | CIM_CREATE_CLASS_RESPONSE_MESSAGE, |
CIM_CREATE_INSTANCE_RESPONSE_MESSAGE, | CIM_CREATE_INSTANCE_RESPONSE_MESSAGE, |
CIM_MODIFY_CLASS_RESPONSE_MESSAGE, | CIM_MODIFY_CLASS_RESPONSE_MESSAGE, |
CIM_MODIFY_INSTANCE_RESPONSE_MESSAGE, | CIM_MODIFY_INSTANCE_RESPONSE_MESSAGE, |
CIM_ENUMERATE_CLASSES_RESPONSE_MESSAGE, |
CIM_ENUMERATE_CLASSES_RESPONSE_MESSAGE, // 50 |
CIM_ENUMERATE_CLASS_NAMES_RESPONSE_MESSAGE, | CIM_ENUMERATE_CLASS_NAMES_RESPONSE_MESSAGE, |
CIM_ENUMERATE_INSTANCES_RESPONSE_MESSAGE, | CIM_ENUMERATE_INSTANCES_RESPONSE_MESSAGE, |
CIM_ENUMERATE_INSTANCE_NAMES_RESPONSE_MESSAGE, | CIM_ENUMERATE_INSTANCE_NAMES_RESPONSE_MESSAGE, |
|
|
CIM_REFERENCES_RESPONSE_MESSAGE, | CIM_REFERENCES_RESPONSE_MESSAGE, |
CIM_REFERENCE_NAMES_RESPONSE_MESSAGE, | CIM_REFERENCE_NAMES_RESPONSE_MESSAGE, |
CIM_GET_PROPERTY_RESPONSE_MESSAGE, | CIM_GET_PROPERTY_RESPONSE_MESSAGE, |
CIM_SET_PROPERTY_RESPONSE_MESSAGE, |
CIM_SET_PROPERTY_RESPONSE_MESSAGE, // 60 |
CIM_GET_QUALIFIER_RESPONSE_MESSAGE, | CIM_GET_QUALIFIER_RESPONSE_MESSAGE, |
CIM_SET_QUALIFIER_RESPONSE_MESSAGE, | CIM_SET_QUALIFIER_RESPONSE_MESSAGE, |
CIM_DELETE_QUALIFIER_RESPONSE_MESSAGE, | CIM_DELETE_QUALIFIER_RESPONSE_MESSAGE, |
|
|
CIM_MODIFY_INDICATION_SUBSCRIPTION_RESPONSE_MESSAGE, | CIM_MODIFY_INDICATION_SUBSCRIPTION_RESPONSE_MESSAGE, |
CIM_DISABLE_INDICATION_SUBSCRIPTION_RESPONSE_MESSAGE, | CIM_DISABLE_INDICATION_SUBSCRIPTION_RESPONSE_MESSAGE, |
CIM_PROCESS_INDICATION_RESPONSE_MESSAGE, | CIM_PROCESS_INDICATION_RESPONSE_MESSAGE, |
CIM_NOTIFY_PROVIDER_REGISTRATION_RESPONSE_MESSAGE, |
CIM_NOTIFY_PROVIDER_REGISTRATION_RESPONSE_MESSAGE, // 70 |
CIM_NOTIFY_PROVIDER_TERMINATION_RESPONSE_MESSAGE, | CIM_NOTIFY_PROVIDER_TERMINATION_RESPONSE_MESSAGE, |
CIM_HANDLE_INDICATION_RESPONSE_MESSAGE, | CIM_HANDLE_INDICATION_RESPONSE_MESSAGE, |
| |
|
|
CIM_DISABLE_MODULE_RESPONSE_MESSAGE, | CIM_DISABLE_MODULE_RESPONSE_MESSAGE, |
CIM_ENABLE_MODULE_RESPONSE_MESSAGE, | CIM_ENABLE_MODULE_RESPONSE_MESSAGE, |
| |
|
CIM_STOP_ALL_PROVIDERS_RESPONSE_MESSAGE, // 80 |
|
|
// Monitor-related messages: | // Monitor-related messages: |
| |
SOCKET_MESSAGE, | SOCKET_MESSAGE, |
|
|
ASYNC_DEREGISTER_CIM_SERVICE, | ASYNC_DEREGISTER_CIM_SERVICE, |
ASYNC_UPDATE_CIM_SERVICE, | ASYNC_UPDATE_CIM_SERVICE, |
ASYNC_IOCTL, | ASYNC_IOCTL, |
ASYNC_CIMSERVICE_START, |
ASYNC_CIMSERVICE_START, // 90 |
ASYNC_CIMSERVICE_STOP, | ASYNC_CIMSERVICE_STOP, |
ASYNC_CIMSERVICE_PAUSE, | ASYNC_CIMSERVICE_PAUSE, |
ASYNC_CIMSERVICE_RESUME, | ASYNC_CIMSERVICE_RESUME, |
|
|
| |
ASYNC_FIND_SERVICE_Q, | ASYNC_FIND_SERVICE_Q, |
ASYNC_FIND_SERVICE_Q_RESULT, | ASYNC_FIND_SERVICE_Q_RESULT, |
ASYNC_ENUMERATE_SERVICE, |
ASYNC_ENUMERATE_SERVICE, // 100 |
ASYNC_ENUMERATE_SERVICE_RESULT, | ASYNC_ENUMERATE_SERVICE_RESULT, |
| |
ASYNC_REGISTERED_MODULE, | ASYNC_REGISTERED_MODULE, |
|
|
ASYNC_ASYNC_MODULE_OP_START, | ASYNC_ASYNC_MODULE_OP_START, |
ASYNC_ASYNC_MODULE_OP_RESULT, | ASYNC_ASYNC_MODULE_OP_RESULT, |
| |
|
CIM_INITIALIZE_PROVIDER_REQUEST_MESSAGE, |
|
CIM_INITIALIZE_PROVIDER_RESPONSE_MESSAGE, |
|
|
|
|
|
CIM_NOTIFY_PROVIDER_ENABLE_REQUEST_MESSAGE, |
|
CIM_NOTIFY_PROVIDER_ENABLE_RESPONSE_MESSAGE, |
|
|
NUMBER_OF_MESSAGES | NUMBER_OF_MESSAGES |
}; | }; |
| |