/*************************************************************************
 *
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 * 
 * Copyright 2000, 2010 Oracle and/or its affiliates.
 *
 * OpenOffice.org - a multi-platform office productivity suite
 *
 * This file is part of OpenOffice.org.
 *
 * OpenOffice.org is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License version 3
 * only, as published by the Free Software Foundation.
 *
 * OpenOffice.org is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License version 3 for more details
 * (a copy is included in the LICENSE file that accompanied this code).
 *
 * You should have received a copy of the GNU Lesser General Public License
 * version 3 along with OpenOffice.org.  If not, see
 * <http://www.openoffice.org/license.html>
 * for a copy of the LGPLv3 License.
 *
 ************************************************************************/

// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_xmlsecurity.hxx"

/*
 * Implementation of the I/O interfaces based on stream and URI binding
 */
#include "errorcallback.hxx"

#include <sal/types.h>
//For reasons that escape me, this is what xmlsec does when size_t is not 4
#if SAL_TYPES_SIZEOFPOINTER != 4
#    define XMLSEC_NO_SIZE_T
#endif
#include "xmlsec/xmlsec.h"
#include "xmlsec/errors.h"

using namespace ::com::sun::star::xml::crypto;

// ::com::sun::star::uno::Reference< XXMLSecurityTemplate > g_xErrorRecorder;
// bool g_bErrorRecorded;

// SecurityOperationStatus getOperationStatus(int reason)
// {
// 	switch (reason)
// 	{
// 	case XMLSEC_ERRORS_R_XMLSEC_FAILED:
// 		return SecurityOperationStatus_ENGINE_FAILED;
// 	case XMLSEC_ERRORS_R_MALLOC_FAILED:
// 		return SecurityOperationStatus_MALLOC_FAILED;
// 	case XMLSEC_ERRORS_R_STRDUP_FAILED:
// 		return SecurityOperationStatus_STRDUP_FAILED;
// 	case XMLSEC_ERRORS_R_CRYPTO_FAILED:
// 		return SecurityOperationStatus_CRYPTO_FAILED;
// 	case XMLSEC_ERRORS_R_XML_FAILED:
// 		return SecurityOperationStatus_XML_FAILED;
// 	case XMLSEC_ERRORS_R_XSLT_FAILED:
// 		return SecurityOperationStatus_XSLT_FAILED;
// 	case XMLSEC_ERRORS_R_IO_FAILED:
// 		return SecurityOperationStatus_IO_FAILED;
// 	case XMLSEC_ERRORS_R_DISABLED:
// 		return SecurityOperationStatus_DISABLED;
// 	case XMLSEC_ERRORS_R_NOT_IMPLEMENTED:
// 		return SecurityOperationStatus_NOT_IMPLEMENTED;
// 	case XMLSEC_ERRORS_R_INVALID_SIZE:
// 		return SecurityOperationStatus_INVALID_SIZE;
// 	case XMLSEC_ERRORS_R_INVALID_DATA:
// 		return SecurityOperationStatus_INVALID_DATA;
// 	case XMLSEC_ERRORS_R_INVALID_RESULT:
// 		return SecurityOperationStatus_INVALID_RESULT;
// 	case XMLSEC_ERRORS_R_INVALID_TYPE:
// 		return SecurityOperationStatus_INVALID_TYPE;
// 	case XMLSEC_ERRORS_R_INVALID_OPERATION:
// 		return SecurityOperationStatus_INVALID_OPERATION;
// 	case XMLSEC_ERRORS_R_INVALID_STATUS:
// 		return SecurityOperationStatus_INVALID_STATUS;
// 	case XMLSEC_ERRORS_R_INVALID_FORMAT:
// 		return SecurityOperationStatus_INVALID_FORMAT;
// 	case XMLSEC_ERRORS_R_DATA_NOT_MATCH:
// 		return SecurityOperationStatus_DATA_NOT_MATCH;
// 	case XMLSEC_ERRORS_R_INVALID_NODE:
// 		return SecurityOperationStatus_INVALID_NODE;
// 	case XMLSEC_ERRORS_R_INVALID_NODE_CONTENT:
// 		return SecurityOperationStatus_INVALID_NODE_CONTENT;
// 	case XMLSEC_ERRORS_R_INVALID_NODE_ATTRIBUTE:
// 		return SecurityOperationStatus_INVALID_NODE_ATTRIBUTE;
// 	case XMLSEC_ERRORS_R_MISSING_NODE_ATTRIBUTE:
// 		return SecurityOperationStatus_MISSING_NODE_ATTRIBUTE;
// 	case XMLSEC_ERRORS_R_NODE_ALREADY_PRESENT:
// 		return SecurityOperationStatus_NODE_ALREADY_PRESENT;
// 	case XMLSEC_ERRORS_R_UNEXPECTED_NODE:
// 		return SecurityOperationStatus_UNEXPECTED_NODE;
// 	case XMLSEC_ERRORS_R_NODE_NOT_FOUND:
// 		return SecurityOperationStatus_NODE_NOT_FOUND;
// 	case XMLSEC_ERRORS_R_INVALID_TRANSFORM:
// 		return SecurityOperationStatus_INVALID_TRANSFORM;
// 	case XMLSEC_ERRORS_R_INVALID_TRANSFORM_KEY:
// 		return SecurityOperationStatus_INVALID_TRANSFORM_KEY;
// 	case XMLSEC_ERRORS_R_INVALID_URI_TYPE:
// 		return SecurityOperationStatus_INVALID_URI_TYPE;
// 	case XMLSEC_ERRORS_R_TRANSFORM_SAME_DOCUMENT_REQUIRED:
// 		return SecurityOperationStatus_TRANSFORM_SAME_DOCUMENT_REQUIRED;
// 	case XMLSEC_ERRORS_R_TRANSFORM_DISABLED:
// 		return SecurityOperationStatus_TRANSFORM_DISABLED;
// 	case XMLSEC_ERRORS_R_INVALID_KEY_DATA:
// 		return SecurityOperationStatus_INVALID_KEY_DATA;
// 	case XMLSEC_ERRORS_R_KEY_DATA_NOT_FOUND:
// 		return SecurityOperationStatus_KEY_DATA_NOT_FOUND;
// 	case XMLSEC_ERRORS_R_KEY_DATA_ALREADY_EXIST:
// 		return SecurityOperationStatus_KEY_DATA_ALREADY_EXIST;
// 	case XMLSEC_ERRORS_R_INVALID_KEY_DATA_SIZE:
// 		return SecurityOperationStatus_INVALID_KEY_DATA_SIZE;
// 	case XMLSEC_ERRORS_R_KEY_NOT_FOUND:
// 		return SecurityOperationStatus_KEY_NOT_FOUND;
// 	case XMLSEC_ERRORS_R_KEYDATA_DISABLED:
// 		return SecurityOperationStatus_KEYDATA_DISABLED;
// 	case XMLSEC_ERRORS_R_MAX_RETRIEVALS_LEVEL:
// 		return SecurityOperationStatus_MAX_RETRIEVALS_LEVEL;
// 	case XMLSEC_ERRORS_R_MAX_RETRIEVAL_TYPE_MISMATCH:
// 		return SecurityOperationStatus_MAX_RETRIEVAL_TYPE_MISMATCH;
// 	case XMLSEC_ERRORS_R_MAX_ENCKEY_LEVEL:
// 		return SecurityOperationStatus_MAX_ENCKEY_LEVEL;
// 	case XMLSEC_ERRORS_R_CERT_VERIFY_FAILED:
// 		return SecurityOperationStatus_CERT_VERIFY_FAILED;
// 	case XMLSEC_ERRORS_R_CERT_NOT_FOUND:
// 		return SecurityOperationStatus_CERT_NOT_FOUND;
// 	case XMLSEC_ERRORS_R_CERT_REVOKED:
// 		return SecurityOperationStatus_CERT_REVOKED;
// 	case XMLSEC_ERRORS_R_CERT_ISSUER_FAILED:
// 		return SecurityOperationStatus_CERT_ISSUER_FAILED;
// 	case XMLSEC_ERRORS_R_CERT_NOT_YET_VALID:
// 		return SecurityOperationStatus_CERT_NOT_YET_VALID;
// 	case XMLSEC_ERRORS_R_CERT_HAS_EXPIRED:
// 		return SecurityOperationStatus_CERT_HAS_EXPIRED;
// 	case XMLSEC_ERRORS_R_DSIG_NO_REFERENCES:
// 		return SecurityOperationStatus_DSIG_NO_REFERENCES;
// 	case XMLSEC_ERRORS_R_DSIG_INVALID_REFERENCE:
// 		return SecurityOperationStatus_DSIG_INVALID_REFERENCE;
// 	case XMLSEC_ERRORS_R_ASSERTION:
// 		return SecurityOperationStatus_ASSERTION;
// 	default:
// 		return SecurityOperationStatus_RUNTIMEERROR_FAILED;
// 	}
// }


extern "C"
void errorCallback(const char * /*file*/,
                   int /*line*/,
                   const char * /*func*/,
                   const char * /*errorObject*/,
                   const char * /*errorSubject*/,
                   int /*reason*/,
                   const char  * /*msg*/)
{
#if OSL_DEBUG_LEVEL > 1
//     const char * afunc = func ? func : "";
//     const char * errObj = errorObject ? errorObject : "";
//     const char * errSub = errorSubject ? errorSubject : "";
//     const char * amsg = msg ? msg : "";
// 	fprintf(stdout, "xmlsec error: %s, %s,  %s, %i %s  \n", afunc, errObj, errSub, reason, amsg);
#endif
    //ToDo write log message
// 	if (g_xErrorRecorder.is() && !g_bErrorRecorded)
// 	{
// 		g_xErrorRecorder->setStatus(getOperationStatus(reason));

// 		if ( reason != XMLSEC_ERRORS_R_ASSERTION && reason!=XMLSEC_ERRORS_R_XMLSEC_FAILED)
// 		{
//             g_bErrorRecorded = true;
// 		}
// 	}
}

// void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate >& xTemplate)
// {
// 	g_xErrorRecorder = xTemplate;
// 	g_xErrorRecorder->setStatus(SecurityOperationStatus_OPERATION_SUCCEEDED);
// 	g_bErrorRecorded = false;
// 	xmlSecErrorsSetCallback(errorCallback);
// }

//void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSignatureTemplate >& xTemplate)

void setErrorRecorder()    
{
// 	::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate > 
// 		xSecurityTemplate(xTemplate, ::com::sun::star::uno::UNO_QUERY);
// 	setErrorRecorder( xSecurityTemplate );
    xmlSecErrorsSetCallback(errorCallback);
}

// void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLEncryptionTemplate >& xTemplate)
// {
// 	::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate > 
// 		xSecurityTemplate(xTemplate, ::com::sun::star::uno::UNO_QUERY);
// 	setErrorRecorder( xSecurityTemplate );
// }

void clearErrorRecorder()
{
	xmlSecErrorsSetCallback(NULL);
//	g_xErrorRecorder = NULL;
}