X-Git-Url: http://www.project-moonshot.org/gitweb/?p=shibboleth%2Fcpp-opensaml.git;a=blobdiff_plain;f=saml%2Fsaml2%2Fbinding%2Fimpl%2FSAML2SOAPClient.cpp;h=a78b8b209ca9b621f62a472f5b1c7886f8ca2f5f;hp=2da5a0d55631ef8d6f8b4bd71b924018a4ab04ec;hb=1462057b3b9ae7e165d34d988e30b14c213672ca;hpb=c072b75e6f6e05e24a1c35b952008b38d0d375c1 diff --git a/saml/saml2/binding/impl/SAML2SOAPClient.cpp b/saml/saml2/binding/impl/SAML2SOAPClient.cpp index 2da5a0d..a78b8b2 100644 --- a/saml/saml2/binding/impl/SAML2SOAPClient.cpp +++ b/saml/saml2/binding/impl/SAML2SOAPClient.cpp @@ -1,17 +1,21 @@ -/* - * Copyright 2001-2009 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. */ /** @@ -41,6 +45,16 @@ using namespace xmltooling::logging; using namespace xmltooling; using namespace std; +SAML2SOAPClient::SAML2SOAPClient(opensaml::SOAPClient& soaper, bool fatalSAMLErrors) + : m_soaper(soaper), m_fatal(fatalSAMLErrors), m_correlate(nullptr) +{ +} + +SAML2SOAPClient::~SAML2SOAPClient() +{ + XMLString::release(&m_correlate); +} + void SAML2SOAPClient::sendSAML(RequestAbstractType* request, const char* from, MetadataCredentialCriteria& to, const char* endpoint) { auto_ptr env(EnvelopeBuilder::buildEnvelope()); @@ -82,7 +96,7 @@ StatusResponseType* SAML2SOAPClient::receiveSAML() // Check Status. Status* status = response->getStatus(); if (status) { - const XMLCh* code = status->getStatusCode() ? status->getStatusCode()->getValue() : NULL; + const XMLCh* code = status->getStatusCode() ? status->getStatusCode()->getValue() : nullptr; if (code && !XMLString::equals(code,StatusCode::SUCCESS) && handleError(*status)) { BindingException ex("SAML response contained an error."); annotateException(&ex, policy.getIssuerMetadata(), status); // throws it @@ -102,14 +116,14 @@ StatusResponseType* SAML2SOAPClient::receiveSAML() else ex.raise(); } - return NULL; + return nullptr; } -bool SAML2SOAPClient::handleError(const Status& status) +bool SAML2SOAPClient::handleError(const saml2p::Status& status) { - auto_ptr_char code((status.getStatusCode() ? status.getStatusCode()->getValue() : NULL)); - auto_ptr_char str((status.getStatusMessage() ? status.getStatusMessage()->getMessage() : NULL)); - Category::getInstance(SAML_LOGCAT".SOAPClient").error( + auto_ptr_char code((status.getStatusCode() ? status.getStatusCode()->getValue() : nullptr)); + auto_ptr_char str((status.getStatusMessage() ? status.getStatusMessage()->getMessage() : nullptr)); + Category::getInstance(SAML_LOGCAT ".SOAPClient").error( "SOAP client detected a SAML error: (%s) (%s)", (code.get() ? code.get() : "no code"), (str.get() ? str.get() : "no message")