X-Git-Url: http://www.project-moonshot.org/gitweb/?p=shibboleth%2Fcpp-opensaml.git;a=blobdiff_plain;f=saml%2Finternal.h;h=a01701662d152a5e832670486861b0f32cdcc1bb;hp=aa0b8cee616bd5fc060d1fdfee291b5d37ab7103;hb=db44995ea6c326dcb51387a888da823c5d86c866;hpb=096d14037ebd2271f8e116d13f742be853435816 diff --git a/saml/internal.h b/saml/internal.h index aa0b8ce..a017016 100644 --- a/saml/internal.h +++ b/saml/internal.h @@ -1,17 +1,21 @@ -/* - * Copyright 2001-2005 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 @@ -39,26 +44,77 @@ #include "base.h" #include "SAMLConfig.h" +#include +#include +#include +#include + +using namespace xercesc; + +// C99 defines LLONG_MIN, LLONG_MAX and ULLONG_MAX, but this part of +// C99 is not yet included into the C++ standard. +// GCC defines LONG_LONG_MIN, LONG_LONG_MAX and ULONG_LONG_MAX. +// Some compilers (such as Comeau C++ up to and including version 4.3.3) +// define nothing. In this last case we make a reasonable guess. +#ifndef LLONG_MIN +#if defined(LONG_LONG_MIN) +#define LLONG_MIN LONG_LONG_MIN +#elif SIZEOF_LONG_LONG == 8 +#define LLONG_MIN 0x8000000000000000LL +#endif +#endif + +#ifndef LLONG_MAX +#if defined(LONG_LONG_MAX) +#define LLONG_MAX LONG_LONG_MAX +#elif SIZEOF_LONG_LONG == 8 +#define LLONG_MAX 0x7fffffffffffffffLL +#endif +#endif + +#ifndef ULLONG_MAX +#if defined(ULONG_LONG_MAX) +#define ULLONG_MAX ULONG_LONG_MAX +#elif SIZEOF_UNSIGNED_LONG_LONG == 8 +#define ULLONG_MAX 0xffffffffffffffffULL +#endif +#endif + +#define SAMLTIME_MAX (sizeof(time_t) == 8 ? LLONG_MAX : INT_MAX) + #define SAML_LOGCAT "OpenSAML" +namespace xmltooling { + class XMLTOOL_API Mutex; +}; + namespace opensaml { /// @cond OFF - class SAMLInternalConfig : public SAMLConfig + class SAML_DLLLOCAL SAMLInternalConfig : public SAMLConfig { public: - SAMLInternalConfig() {} + SAMLInternalConfig(); + ~SAMLInternalConfig(); static SAMLInternalConfig& getInternalConfig(); // global per-process setup and shutdown of runtime - bool init(); - void term(); + bool init(bool initXMLTooling=true); + void term(bool termXMLTooling=true); void generateRandomBytes(void* buf, unsigned int len); void generateRandomBytes(std::string& buf, unsigned int len); XMLCh* generateIdentifier(); + std::string hashSHA1(const char* data, bool toHex=false); + void setContactPriority(const XMLCh*); + const saml2md::ContactPerson* getContactPerson(const saml2md::EntityDescriptor&) const; + const saml2md::ContactPerson* getContactPerson(const saml2md::RoleDescriptor&) const; + private: + int m_initCount; + boost::scoped_ptr m_lock; + std::vector m_contactPriority; }; /// @endcond