Major revamp of credential and trust handling code, PKIX engine still needs work.
[shibboleth/cpp-opensaml.git] / saml / saml2 / metadata / ObservableMetadataProvider.h
1 /*
2  *  Copyright 2001-2007 Internet2
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 /**
18  * @file saml/saml2/metadata/ObservableMetadataProvider.h
19  * 
20  * A metadata provider that notifies interested parties of changes.
21  */
22
23 #ifndef __saml2_obsmetadataprov_h__
24 #define __saml2_obsmetadataprov_h__
25
26 #include <saml/saml2/metadata/MetadataProvider.h>
27
28 namespace opensaml {
29     
30     namespace saml2md {
31         
32 #if defined (_MSC_VER)
33         #pragma warning( push )
34         #pragma warning( disable : 4251 )
35 #endif
36         /**
37          * A metadata provider that notifies interested parties of changes.
38          */
39         class SAML_API ObservableMetadataProvider : public MetadataProvider
40         {
41         protected:
42             /**
43              * Constructor.
44              * 
45              * @param e DOM to supply configuration for provider
46              */
47             ObservableMetadataProvider(const DOMElement* e=NULL) : MetadataProvider(e) {}
48             
49             /**
50              * Convenience method for notifying every registered Observer of an event.
51              */
52             virtual void emitChangeEvent();
53
54         public:
55             /**
56              * Destructor will delete any installed filters.
57              */
58             virtual ~ObservableMetadataProvider();
59             
60             /**
61              * An observer of metadata provider changes.
62              */
63             class SAML_API Observer {
64                 MAKE_NONCOPYABLE(Observer);
65             protected:
66                 Observer() {}
67             public:
68                 virtual ~Observer() {}
69         
70                 /**
71                  * Called when a provider signals an event has occured.
72                  * The provider is already locked. 
73                  * 
74                  * @param provider the provider being observed
75                  */
76                 virtual void onEvent(MetadataProvider& provider)=0;
77             };
78             
79             /**
80              * Adds a metadata observer.
81              * 
82              * @param newObserver metadata observer to add
83              */
84             virtual void addObserver(Observer* newObserver) {
85                 m_observers.push_back(newObserver);
86             }
87
88             /**
89              * Removes a metadata observer. The caller must delete the observer if necessary.
90              * 
91              * @param oldObserver metadata observer to remove
92              * @return  the old observer
93              */
94             virtual Observer* removeObserver(Observer* oldObserver) {
95                 for (std::vector<Observer*>::iterator i=m_observers.begin(); i!=m_observers.end(); i++) {
96                     if (oldObserver==(*i)) {
97                         m_observers.erase(i);
98                         return oldObserver;
99                     }
100                 }
101                 return NULL;
102             }
103
104         private:
105             std::vector<Observer*> m_observers;
106         };
107
108 #if defined (_MSC_VER)
109         #pragma warning( pop )
110 #endif
111
112     };
113 };
114
115 #endif /* __saml2_obsmetadataprov_h__ */