a3847db2c0f39dcb479f3b74e2901d0d9c5c8fbf
[shibboleth/cpp-sp.git] / shibsp / security / SecurityPolicy.cpp
1 /*
2  *  Copyright 2001-2009 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  * SecurityPolicy.cpp
19  *
20  * SP-specific SecurityPolicy subclass.
21  */
22
23 #include "internal.h"
24 #include "Application.h"
25 #include "ServiceProvider.h"
26 #include "metadata/MetadataProviderCriteria.h"
27 #include "security/SecurityPolicy.h"
28
29 using namespace opensaml::saml2;
30 using namespace shibsp;
31
32 SecurityPolicy::SecurityPolicy(const Application& application, const xmltooling::QName* role, bool validate, const char* policyId)
33     : opensaml::SecurityPolicy(application.getMetadataProvider(), role, application.getTrustEngine(), validate), m_application(application) {
34
35     const std::vector<const opensaml::SecurityPolicyRule*>& rules =
36         application.getServiceProvider().getPolicyRules(policyId ? policyId : application.getString("policyId").second);
37     getRules().assign(rules.begin(), rules.end());
38 }
39
40 opensaml::saml2md::MetadataProvider::Criteria& SecurityPolicy::getMetadataProviderCriteria() const
41 {
42     if (!m_metadataCriteria)
43         m_metadataCriteria=new MetadataProviderCriteria(m_application);
44     else
45         m_metadataCriteria->reset();
46     return *m_metadataCriteria;
47 }