1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_xmlsecurity.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski /*
28*b1cdbd2cSJim Jagielski  * Implementation of the I/O interfaces based on stream and URI binding
29*b1cdbd2cSJim Jagielski  */
30*b1cdbd2cSJim Jagielski #include "errorcallback.hxx"
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include <sal/types.h>
33*b1cdbd2cSJim Jagielski //For reasons that escape me, this is what xmlsec does when size_t is not 4
34*b1cdbd2cSJim Jagielski #if SAL_TYPES_SIZEOFPOINTER != 4
35*b1cdbd2cSJim Jagielski #    define XMLSEC_NO_SIZE_T
36*b1cdbd2cSJim Jagielski #endif
37*b1cdbd2cSJim Jagielski #include "xmlsec/xmlsec.h"
38*b1cdbd2cSJim Jagielski #include "xmlsec/errors.h"
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::xml::crypto;
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski // ::com::sun::star::uno::Reference< XXMLSecurityTemplate > g_xErrorRecorder;
43*b1cdbd2cSJim Jagielski // bool g_bErrorRecorded;
44*b1cdbd2cSJim Jagielski 
45*b1cdbd2cSJim Jagielski // SecurityOperationStatus getOperationStatus(int reason)
46*b1cdbd2cSJim Jagielski // {
47*b1cdbd2cSJim Jagielski // 	switch (reason)
48*b1cdbd2cSJim Jagielski // 	{
49*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_XMLSEC_FAILED:
50*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_ENGINE_FAILED;
51*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_MALLOC_FAILED:
52*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_MALLOC_FAILED;
53*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_STRDUP_FAILED:
54*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_STRDUP_FAILED;
55*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CRYPTO_FAILED:
56*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CRYPTO_FAILED;
57*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_XML_FAILED:
58*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_XML_FAILED;
59*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_XSLT_FAILED:
60*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_XSLT_FAILED;
61*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_IO_FAILED:
62*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_IO_FAILED;
63*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_DISABLED:
64*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_DISABLED;
65*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_NOT_IMPLEMENTED:
66*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_NOT_IMPLEMENTED;
67*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_SIZE:
68*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_SIZE;
69*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_DATA:
70*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_DATA;
71*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_RESULT:
72*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_RESULT;
73*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_TYPE:
74*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_TYPE;
75*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_OPERATION:
76*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_OPERATION;
77*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_STATUS:
78*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_STATUS;
79*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_FORMAT:
80*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_FORMAT;
81*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_DATA_NOT_MATCH:
82*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_DATA_NOT_MATCH;
83*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_NODE:
84*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_NODE;
85*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_NODE_CONTENT:
86*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_NODE_CONTENT;
87*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_NODE_ATTRIBUTE:
88*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_NODE_ATTRIBUTE;
89*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_MISSING_NODE_ATTRIBUTE:
90*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_MISSING_NODE_ATTRIBUTE;
91*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_NODE_ALREADY_PRESENT:
92*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_NODE_ALREADY_PRESENT;
93*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_UNEXPECTED_NODE:
94*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_UNEXPECTED_NODE;
95*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_NODE_NOT_FOUND:
96*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_NODE_NOT_FOUND;
97*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_TRANSFORM:
98*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_TRANSFORM;
99*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_TRANSFORM_KEY:
100*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_TRANSFORM_KEY;
101*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_URI_TYPE:
102*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_URI_TYPE;
103*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_TRANSFORM_SAME_DOCUMENT_REQUIRED:
104*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_TRANSFORM_SAME_DOCUMENT_REQUIRED;
105*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_TRANSFORM_DISABLED:
106*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_TRANSFORM_DISABLED;
107*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_KEY_DATA:
108*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_KEY_DATA;
109*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_KEY_DATA_NOT_FOUND:
110*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_KEY_DATA_NOT_FOUND;
111*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_KEY_DATA_ALREADY_EXIST:
112*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_KEY_DATA_ALREADY_EXIST;
113*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_INVALID_KEY_DATA_SIZE:
114*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_INVALID_KEY_DATA_SIZE;
115*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_KEY_NOT_FOUND:
116*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_KEY_NOT_FOUND;
117*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_KEYDATA_DISABLED:
118*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_KEYDATA_DISABLED;
119*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_MAX_RETRIEVALS_LEVEL:
120*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_MAX_RETRIEVALS_LEVEL;
121*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_MAX_RETRIEVAL_TYPE_MISMATCH:
122*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_MAX_RETRIEVAL_TYPE_MISMATCH;
123*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_MAX_ENCKEY_LEVEL:
124*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_MAX_ENCKEY_LEVEL;
125*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_VERIFY_FAILED:
126*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_VERIFY_FAILED;
127*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_NOT_FOUND:
128*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_NOT_FOUND;
129*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_REVOKED:
130*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_REVOKED;
131*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_ISSUER_FAILED:
132*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_ISSUER_FAILED;
133*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_NOT_YET_VALID:
134*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_NOT_YET_VALID;
135*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_CERT_HAS_EXPIRED:
136*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_CERT_HAS_EXPIRED;
137*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_DSIG_NO_REFERENCES:
138*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_DSIG_NO_REFERENCES;
139*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_DSIG_INVALID_REFERENCE:
140*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_DSIG_INVALID_REFERENCE;
141*b1cdbd2cSJim Jagielski // 	case XMLSEC_ERRORS_R_ASSERTION:
142*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_ASSERTION;
143*b1cdbd2cSJim Jagielski // 	default:
144*b1cdbd2cSJim Jagielski // 		return SecurityOperationStatus_RUNTIMEERROR_FAILED;
145*b1cdbd2cSJim Jagielski // 	}
146*b1cdbd2cSJim Jagielski // }
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski 
149*b1cdbd2cSJim Jagielski extern "C"
errorCallback(const char *,int,const char *,const char *,const char *,int,const char *)150*b1cdbd2cSJim Jagielski void errorCallback(const char * /*file*/,
151*b1cdbd2cSJim Jagielski                    int /*line*/,
152*b1cdbd2cSJim Jagielski                    const char * /*func*/,
153*b1cdbd2cSJim Jagielski                    const char * /*errorObject*/,
154*b1cdbd2cSJim Jagielski                    const char * /*errorSubject*/,
155*b1cdbd2cSJim Jagielski                    int /*reason*/,
156*b1cdbd2cSJim Jagielski                    const char  * /*msg*/)
157*b1cdbd2cSJim Jagielski {
158*b1cdbd2cSJim Jagielski #if OSL_DEBUG_LEVEL > 1
159*b1cdbd2cSJim Jagielski //     const char * afunc = func ? func : "";
160*b1cdbd2cSJim Jagielski //     const char * errObj = errorObject ? errorObject : "";
161*b1cdbd2cSJim Jagielski //     const char * errSub = errorSubject ? errorSubject : "";
162*b1cdbd2cSJim Jagielski //     const char * amsg = msg ? msg : "";
163*b1cdbd2cSJim Jagielski // 	fprintf(stdout, "xmlsec error: %s, %s,  %s, %i %s  \n", afunc, errObj, errSub, reason, amsg);
164*b1cdbd2cSJim Jagielski #endif
165*b1cdbd2cSJim Jagielski     //ToDo write log message
166*b1cdbd2cSJim Jagielski // 	if (g_xErrorRecorder.is() && !g_bErrorRecorded)
167*b1cdbd2cSJim Jagielski // 	{
168*b1cdbd2cSJim Jagielski // 		g_xErrorRecorder->setStatus(getOperationStatus(reason));
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski // 		if ( reason != XMLSEC_ERRORS_R_ASSERTION && reason!=XMLSEC_ERRORS_R_XMLSEC_FAILED)
171*b1cdbd2cSJim Jagielski // 		{
172*b1cdbd2cSJim Jagielski //             g_bErrorRecorded = true;
173*b1cdbd2cSJim Jagielski // 		}
174*b1cdbd2cSJim Jagielski // 	}
175*b1cdbd2cSJim Jagielski }
176*b1cdbd2cSJim Jagielski 
177*b1cdbd2cSJim Jagielski // void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate >& xTemplate)
178*b1cdbd2cSJim Jagielski // {
179*b1cdbd2cSJim Jagielski // 	g_xErrorRecorder = xTemplate;
180*b1cdbd2cSJim Jagielski // 	g_xErrorRecorder->setStatus(SecurityOperationStatus_OPERATION_SUCCEEDED);
181*b1cdbd2cSJim Jagielski // 	g_bErrorRecorded = false;
182*b1cdbd2cSJim Jagielski // 	xmlSecErrorsSetCallback(errorCallback);
183*b1cdbd2cSJim Jagielski // }
184*b1cdbd2cSJim Jagielski 
185*b1cdbd2cSJim Jagielski //void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSignatureTemplate >& xTemplate)
186*b1cdbd2cSJim Jagielski 
setErrorRecorder()187*b1cdbd2cSJim Jagielski void setErrorRecorder()
188*b1cdbd2cSJim Jagielski {
189*b1cdbd2cSJim Jagielski // 	::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate >
190*b1cdbd2cSJim Jagielski // 		xSecurityTemplate(xTemplate, ::com::sun::star::uno::UNO_QUERY);
191*b1cdbd2cSJim Jagielski // 	setErrorRecorder( xSecurityTemplate );
192*b1cdbd2cSJim Jagielski     xmlSecErrorsSetCallback(errorCallback);
193*b1cdbd2cSJim Jagielski }
194*b1cdbd2cSJim Jagielski 
195*b1cdbd2cSJim Jagielski // void setErrorRecorder(const ::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLEncryptionTemplate >& xTemplate)
196*b1cdbd2cSJim Jagielski // {
197*b1cdbd2cSJim Jagielski // 	::com::sun::star::uno::Reference< ::com::sun::star::xml::crypto::XXMLSecurityTemplate >
198*b1cdbd2cSJim Jagielski // 		xSecurityTemplate(xTemplate, ::com::sun::star::uno::UNO_QUERY);
199*b1cdbd2cSJim Jagielski // 	setErrorRecorder( xSecurityTemplate );
200*b1cdbd2cSJim Jagielski // }
201*b1cdbd2cSJim Jagielski 
clearErrorRecorder()202*b1cdbd2cSJim Jagielski void clearErrorRecorder()
203*b1cdbd2cSJim Jagielski {
204*b1cdbd2cSJim Jagielski 	xmlSecErrorsSetCallback(NULL);
205*b1cdbd2cSJim Jagielski //	g_xErrorRecorder = NULL;
206*b1cdbd2cSJim Jagielski }
207*b1cdbd2cSJim Jagielski 
208