summaryrefslogtreecommitdiff
path: root/xmlsecurity/source/xmlsec/errorcallback.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'xmlsecurity/source/xmlsec/errorcallback.cxx')
-rw-r--r--xmlsecurity/source/xmlsec/errorcallback.cxx211
1 files changed, 211 insertions, 0 deletions
diff --git a/xmlsecurity/source/xmlsec/errorcallback.cxx b/xmlsecurity/source/xmlsec/errorcallback.cxx
new file mode 100644
index 000000000000..2c55bf1a4fad
--- /dev/null
+++ b/xmlsecurity/source/xmlsec/errorcallback.cxx
@@ -0,0 +1,211 @@
+/*************************************************************************
+ *
+ * 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;
+}
+