File: InlineLogoMetadataFilter.cpp

package info (click to toggle)
opensaml 3.3.1-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,480 kB
  • sloc: cpp: 27,961; sh: 4,593; xml: 1,004; makefile: 429; ansic: 18
file content (125 lines) | stat: -rw-r--r-- 4,690 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/**
 * Licensed to the University Corporation for Advanced Internet
 * Development, Inc. (UCAID) under one or more contributor license
 * agreements. See the NOTICE file distributed with this work for
 * additional information regarding copyright ownership.
 *
 * UCAID licenses this file to you under the Apache License,
 * Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the
 * License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied. See the License for the specific
 * language governing permissions and limitations under the License.
 */

/**
 * InlineLogoMetadataFilter.cpp
 * 
 * Removes inline logos from a metadata instance
 */

#include "internal.h"
#include "saml2/metadata/Metadata.h"
#include "saml2/metadata/MetadataFilter.h"

#include <boost/lambda/bind.hpp>
#include <boost/lambda/casts.hpp>
#include <boost/lambda/lambda.hpp>
#include <boost/scoped_ptr.hpp>
#include <xmltooling/logging.h>

using namespace opensaml::saml2md;
using namespace opensaml::saml2;
using namespace xmltooling::logging;
using namespace xmltooling;
using namespace boost::lambda;
using namespace boost;
using namespace std;

namespace opensaml {
    namespace saml2md {
        class SAML_DLLLOCAL InlineLogoMetadataFilter : public MetadataFilter
        {
        public:
            InlineLogoMetadataFilter(const DOMElement* e, bool deprecationSupport=true) {}
            ~InlineLogoMetadataFilter() {}
            
            const char* getId() const { return EXCLUDE_METADATA_FILTER; }
            void doFilter(const MetadataFilterContext* ctx, XMLObject& xmlObject) const;

        private:
            void filterGroup(EntitiesDescriptor*) const;
            void filterEntity(EntityDescriptor*) const;
        }; 

        MetadataFilter* SAML_DLLLOCAL InlineLogoMetadataFilterFactory(const DOMElement* const & e, bool deprecationSupport)
        {
            return new InlineLogoMetadataFilter(e);
        }
    };
};


void InlineLogoMetadataFilter::doFilter(const MetadataFilterContext* ctx, XMLObject& xmlObject) const
{
    EntitiesDescriptor* group = dynamic_cast<EntitiesDescriptor*>(&xmlObject);
    if (group) {
        filterGroup(group);
    }
    else {
        EntityDescriptor* entity = dynamic_cast<EntityDescriptor*>(&xmlObject);
        if (entity) {
            filterEntity(entity);
        }
        else {
            throw MetadataFilterException(INLINELOGO_METADATA_FILTER " MetadataFilter was given an improper metadata instance to filter.");
        }
    }
}

void InlineLogoMetadataFilter::filterGroup(EntitiesDescriptor* entities) const
{
    const vector<EntityDescriptor*>& v = const_cast<const EntitiesDescriptor*>(entities)->getEntityDescriptors();
    for_each(v.begin(), v.end(), lambda::bind(&InlineLogoMetadataFilter::filterEntity, this, _1));

    const vector<EntitiesDescriptor*>& v2 = const_cast<const EntitiesDescriptor*>(entities)->getEntitiesDescriptors();
    for_each(v2.begin(), v2.end(), lambda::bind(&InlineLogoMetadataFilter::filterGroup, this, _1));
}

void InlineLogoMetadataFilter::filterEntity(EntityDescriptor* entity) const
{
    static const XMLCh prefix[] = { chLatin_d, chLatin_a, chLatin_t, chLatin_a, chColon, chNull };

    const list<XMLObject*>& children = const_cast<const EntityDescriptor*>(entity)->getOrderedChildren();
    for (list<XMLObject*>::const_iterator child = children.begin(); child != children.end(); ++child) {
        if (dynamic_cast<const RoleDescriptor*>(*child)) {
            const Extensions* ext = dynamic_cast<const RoleDescriptor*>(*child)->getExtensions();
            if (!ext)
                continue;
            const vector<XMLObject*>& exts = ext->getUnknownXMLObjects();
            for (vector<XMLObject*>::const_iterator ext = exts.begin(); ext != exts.end(); ++ext) {
                UIInfo* info = dynamic_cast<UIInfo*>(*ext);
                if (info) {
                    VectorOf(Logo) v = info->getLogos();
                    for (VectorOf(Logo)::size_type i = 0; i < v.size(); ) {
                        const XMLCh* url = v[i]->getURL();
                        if (XMLString::startsWithI(url, prefix)) {
                            v.erase(v.begin() + i);
                        }
                        else {
                            i++;
                        }
                    }

                    break;
                }
            }
        }
    }
}