X-Git-Url: http://www.project-moonshot.org/gitweb/?a=blobdiff_plain;f=xmltooling%2Finternal.h;h=d441ad43efae6df524661a8c095a25652d3f038e;hb=81b488b2790e7bdeb2f43560b1d4a7d22c3dfdf5;hp=02b2ada3e425789afb36425e1cb85e44fd2f9bba;hpb=5a4c9204dc299319e9ca7c18f44918a82892045a;p=shibboleth%2Fcpp-xmltooling.git diff --git a/xmltooling/internal.h b/xmltooling/internal.h index 02b2ada..d441ad4 100644 --- a/xmltooling/internal.h +++ b/xmltooling/internal.h @@ -1,17 +1,21 @@ -/* - * Copyright 2001-2007 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. */ /* @@ -75,14 +79,11 @@ namespace xmltooling { /// @cond OFF - class XMLToolingInternalConfig : public xmltooling::XMLToolingConfig + class XMLTOOL_DLLLOCAL XMLToolingInternalConfig : public XMLToolingConfig { public: - XMLToolingInternalConfig() : m_lock(NULL), m_parserPool(NULL), m_validatingPool(NULL) { -#ifndef XMLTOOLING_NO_XMLSEC - m_xsecProvider=NULL; -#endif - } + XMLToolingInternalConfig(); + ~XMLToolingInternalConfig(); static XMLToolingInternalConfig& getInternalConfig(); @@ -95,8 +96,8 @@ namespace xmltooling { void unlock(); // configuration - bool load_library(const char* path, void* context=NULL); - bool log_config(const char* config=NULL); + bool load_library(const char* path, void* context=nullptr); + bool log_config(const char* config=nullptr); // parser access ParserPool& getParser() const { @@ -109,43 +110,23 @@ namespace xmltooling { #ifndef XMLTOOLING_NO_XMLSEC XSECCryptoX509CRL* X509CRL() const; - - std::pair mapXMLAlgorithmToKeyAlgorithm(const XMLCh* xmlAlgorithm) const { -# ifdef HAVE_GOOD_STL - algmap_t::const_iterator i = m_algorithmMap.find(xmlAlgorithm); -# else - auto_ptr_char alg(xmlAlgorithm); - algmap_t::const_iterator i = m_algorithmMap.find(alg.get()); -# endif - if (i==m_algorithmMap.end()) - return std::pair(NULL,0); - return std::make_pair(i->second.first.c_str(), i->second.second); - } - - void registerXMLAlgorithm(const XMLCh* xmlAlgorithm, const char* keyAlgorithm, unsigned int size=0) { -# ifdef HAVE_GOOD_STL - m_algorithmMap[xmlAlgorithm] = std::pair(keyAlgorithm,size); -# else - auto_ptr_char alg(xmlAlgorithm); - m_algorithmMap[alg.get()] = std::pair(keyAlgorithm,size); -# endif - } - + std::pair mapXMLAlgorithmToKeyAlgorithm(const XMLCh* xmlAlgorithm) const; + 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: -# ifdef HAVE_GOOD_STL - typedef std::map< xstring,std::pair > algmap_t; -# else - typedef std::map< std::string,std::pair > algmap_t; -# endif + typedef std::map > > algmap_t; algmap_t m_algorithmMap; #endif private: + int m_initCount; + Mutex* m_lock; std::vector m_libhandles; - void* m_lock; ParserPool* m_parserPool; ParserPool* m_validatingPool; };