3 kumpf 1.3 // Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Company, IBM,
|
4 mike 1.2 // The Open Group, Tivoli Systems
5 //
6 // Permission is hereby granted, free of charge, to any person obtaining a copy
7 // of this software and associated documentation files (the "Software"), to
8 // deal in the Software without restriction, including without limitation the
9 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 // sell copies of the Software, and to permit persons to whom the Software is
11 // furnished to do so, subject to the following conditions:
12 //
13 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
14 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
15 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
16 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
17 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
18 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
19 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21 //
22 //==============================================================================
23 //
24 // Author: Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com)
25 mike 1.2 //
26 // Modified By:
27 //
28 //%/////////////////////////////////////////////////////////////////////////////
29
30 #ifndef PegasusHandler_Handler_h
31 #define PegasusHandler_Handler_h
32
33 #include <Pegasus/Common/Config.h>
34 #include <Pegasus/Common/CIMObject.h>
35 #include <Pegasus/Repository/CIMRepository.h>
|
37 mike 1.2
38 PEGASUS_NAMESPACE_BEGIN
39
40 class PEGASUS_HANDLER_LINKAGE CIMHandler
41 {
42 public:
43
44 CIMHandler() { };
45
46 virtual ~CIMHandler() { };
47
48 // Abstract method which each and every handler needs to be implemented.
49 // Indication processing will instantiate IndicationDispatcher which
50 // will look into Handler Table to load the appropriate handler. If
51 // handler is already loaded then IndicationDispatcher will call this
52 // method implemented in handler.
53
54 virtual void handleIndication(
55 CIMInstance& indicationHandlerInstance,
56 CIMInstance& indicationInstance,
57 String nameSpace) = 0;
58 mike 1.2
59 // These are the method to initialize and terminate handler. Actual need and
60 // implementation way these methods are yet to be finalized.
61
62 virtual void initialize(CIMRepository* repository) = 0;
63 virtual void terminate() = 0;
64 };
65
66 PEGASUS_NAMESPACE_END
67
68 #endif /* PegasusHandler_Handler_h */
|