X-Git-Url: http://www.project-moonshot.org/gitweb/?p=shibboleth%2Fcpp-xmltooling.git;a=blobdiff_plain;f=xmltooling%2Finternal.h;h=c39bb8d269b8f1a8f957b44d89b06b52ec71bb45;hp=193f3ce527c5046a52d1bc712fc9f8779b553de3;hb=HEAD;hpb=1c23da3acf063ec4065209cb16fdff9302fb70ac diff --git a/xmltooling/internal.h b/xmltooling/internal.h index 193f3ce..c39bb8d 100644 --- a/xmltooling/internal.h +++ b/xmltooling/internal.h @@ -1,17 +1,21 @@ -/* - * Copyright 2001-2010 Internet2 - * - * Licensed 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 +/** + * 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 + * 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. + * 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. */ /* @@ -24,6 +28,7 @@ #ifdef WIN32 # define _CRT_SECURE_NO_DEPRECATE 1 # define _CRT_NONSTDC_NO_DEPRECATE 1 +# define _SCL_SECURE_NO_WARNINGS 1 #endif // Export public APIs. @@ -40,13 +45,18 @@ #include "XMLToolingConfig.h" #include "util/ParserPool.h" +#include +#include #include + #ifndef XMLTOOLING_NO_XMLSEC #include #endif #define XMLTOOLING_LOGCAT "XMLTooling" +#define XMLTOOLING_ENTITY_EXPANSION_LIMIT 100 + // Macros for path and directory separators. #if defined __CYGWIN32__ && !defined __CYGWIN__ /* For backwards compatibility with Cygwin b19 and @@ -75,16 +85,11 @@ namespace xmltooling { /// @cond OFF - class XMLToolingInternalConfig : public XMLToolingConfig + class XMLTOOL_DLLLOCAL XMLToolingInternalConfig : public XMLToolingConfig { public: - XMLToolingInternalConfig() - : m_lock(nullptr), m_parserPool(nullptr), m_validatingPool(nullptr) -#ifndef XMLTOOLING_NO_XMLSEC - ,m_xsecProvider(nullptr) -#endif - { - } + XMLToolingInternalConfig(); + ~XMLToolingInternalConfig(); static XMLToolingInternalConfig& getInternalConfig(); @@ -96,6 +101,9 @@ namespace xmltooling { Lockable* lock(); void unlock(); + // named mutexes to limit lock scope + Mutex& getNamedMutex(const char* name); + // configuration bool load_library(const char* path, void* context=nullptr); bool log_config(const char* config=nullptr); @@ -112,19 +120,23 @@ namespace xmltooling { #ifndef XMLTOOLING_NO_XMLSEC XSECCryptoX509CRL* X509CRL() const; std::pair mapXMLAlgorithmToKeyAlgorithm(const XMLCh* xmlAlgorithm) const; - void registerXMLAlgorithm(const XMLCh* xmlAlgorithm, const char* keyAlgorithm, unsigned int size=0); - bool isXMLAlgorithmSupported(const XMLCh* xmlAlgorithm); + void registerXMLAlgorithm( + const XMLCh* xmlAlgorithm, const char* keyAlgorithm, unsigned int size=0, XMLSecurityAlgorithmType type=ALGTYPE_UNK + ); + bool isXMLAlgorithmSupported(const XMLCh* xmlAlgorithm, XMLSecurityAlgorithmType type=ALGTYPE_UNK); void registerXMLAlgorithms(); XSECProvider* m_xsecProvider; private: - typedef std::map< xstring,std::pair > algmap_t; + typedef std::map > > algmap_t; algmap_t m_algorithmMap; #endif private: + int m_initCount; + std::auto_ptr m_lock; + std::map m_namedLocks; std::vector m_libhandles; - void* m_lock; ParserPool* m_parserPool; ParserPool* m_validatingPool; };