1 karl 1.18 //%2006////////////////////////////////////////////////////////////////////////
|
2 chip 1.1 //
|
3 karl 1.15 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
4 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
5 // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
|
6 karl 1.3 // IBM Corp.; EMC Corporation, The Open Group.
|
7 karl 1.15 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
8 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
|
9 karl 1.16 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 // EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.18 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 // EMC Corporation; Symantec Corporation; The Open Group.
|
13 chip 1.1 //
14 // Permission is hereby granted, free of charge, to any person obtaining a copy
15 // of this software and associated documentation files (the "Software"), to
16 // deal in the Software without restriction, including without limitation the
17 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
18 // sell copies of the Software, and to permit persons to whom the Software is
19 // furnished to do so, subject to the following conditions:
|
20 karl 1.15 //
|
21 chip 1.1 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
22 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
23 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
24 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
25 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
27 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 //
30 //==============================================================================
31 //
32 //%/////////////////////////////////////////////////////////////////////////////
33
34 #ifndef Pegasus_ProviderManager_h
35 #define Pegasus_ProviderManager_h
36
37 #include <Pegasus/Common/Config.h>
|
38 b.whiteley 1.23 #include <Pegasus/Common/PegasusVersion.h>
|
39 kumpf 1.12 #include <Pegasus/Common/CIMMessage.h>
|
40 chip 1.1
|
41 schuur 1.5 #include <Pegasus/ProviderManager2/Linkage.h>
|
42 chip 1.1
43 PEGASUS_NAMESPACE_BEGIN
44
|
45 kumpf 1.19 typedef void (*PEGASUS_INDICATION_CALLBACK_T)(
|
46 kumpf 1.12 CIMProcessIndicationRequestMessage*);
47
|
48 kumpf 1.19 typedef void (*PEGASUS_RESPONSE_CHUNK_CALLBACK_T)(
49 CIMRequestMessage* request, CIMResponseMessage* response);
50
|
51 schuur 1.5 class PEGASUS_PPM_LINKAGE ProviderManager
|
52 chip 1.1 {
53 public:
|
54 kumpf 1.21 ProviderManager();
55 virtual ~ProviderManager();
|
56 chip 1.1
|
57 kumpf 1.21 virtual Message* processMessage(Message* message) = 0;
|
58 chip 1.1
|
59 kumpf 1.13 virtual Boolean hasActiveProviders() = 0;
60 virtual void unloadIdleProviders() = 0;
|
61 schuur 1.4 static String _resolvePhysicalName(String physicalName);
|
62 chip 1.1
|
63 kumpf 1.12 /**
64 Sets the callback function to which indications generated by this
65 ProviderManager should be forwarded for processing.
66 */
67 virtual void setIndicationCallback(
|
68 kumpf 1.19 PEGASUS_INDICATION_CALLBACK_T indicationCallback);
69
70 /**
71 Sets the callback function to which response chunks generated by this
72 ProviderManager should be forwarded for processing.
73 */
74 virtual void setResponseChunkCallback(
75 PEGASUS_RESPONSE_CHUNK_CALLBACK_T responseChunkCallback);
|
76 kumpf 1.12
|
77 schuur 1.14 virtual Boolean supportsRemoteNameSpaces() { return false; }
78
|
79 carolann.graves 1.17 /**
80 Sets the SubscriptionInitComplete flag indicating whether the Indication
81 Service has completed its initialization.
82 */
|
83 kumpf 1.21 virtual void setSubscriptionInitComplete(Boolean subscriptionInitComplete);
|
84 carolann.graves 1.17
|
85 chip 1.1 protected:
|
86 kumpf 1.19 PEGASUS_INDICATION_CALLBACK_T _indicationCallback;
87 PEGASUS_RESPONSE_CHUNK_CALLBACK_T _responseChunkCallback;
|
88 kumpf 1.12
|
89 carolann.graves 1.17 /**
90 Indicates whether the Indication Service has completed initialization.
91
|
92 kumpf 1.21 For more information, please see the description of the
|
93 carolann.graves 1.17 ProviderManagerRouter::_subscriptionInitComplete member variable.
94 */
95 Boolean _subscriptionInitComplete;
96
|
97 chip 1.1 // ingredients for CIMOMHandle (binary message handler, repository, etc.)
98 };
99
100 PEGASUS_NAMESPACE_END
101
|
102 b.whiteley 1.23 #define PEGASUS_GET_VERSION_FUNC \
103 extern "C" PEGASUS_EXPORT Uint32 getPegasusVersion() \
104 { \
105 return PEGASUS_VERSION_NUMBER; \
106 }
107
|
108 chip 1.1 #endif
|