org.apache.ws.security.WSSecurityException Maven / Gradle / Ivy
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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
*
* 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.
*/
package org.apache.ws.security;
import java.rmi.RemoteException;
import java.text.MessageFormat;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
/**
* Exception class for WS-Security.
*
*
* @author Davanum Srinivas ([email protected]).
*/
public class WSSecurityException extends RemoteException {
public static final int FAILURE = 0;
public static final int UNSUPPORTED_SECURITY_TOKEN = 1;
public static final int UNSUPPORTED_ALGORITHM = 2;
public static final int INVALID_SECURITY = 3;
public static final int INVALID_SECURITY_TOKEN = 4;
public static final int FAILED_AUTHENTICATION = 5;
public static final int FAILED_CHECK = 6;
public static final int SECURITY_TOKEN_UNAVAILABLE = 7;
public static final int MESSAGE_EXPIRED = 8;
public static final int FAILED_ENCRYPTION = 9;
public static final int FAILED_SIGNATURE = 10;
private static ResourceBundle resources;
/*
* This is an Integer -> QName map. Its function is to map the integer error codes
* given above to the QName fault codes as defined in the SOAP Message Security 1.1
* specification. A client application can simply call getFaultCode rather than do
* any parsing of the error code. Note that there are no mappings for "FAILURE",
* "FAILED_ENCRYPTION" and "FAILED_SIGNATURE" as these are not standard error messages.
*/
private static final java.util.Map FAULT_CODE_MAP = new java.util.HashMap();
static {
try {
resources = ResourceBundle.getBundle("org.apache.ws.security.errors");
} catch (MissingResourceException e) {
throw new RuntimeException(e.getMessage(), e);
}
FAULT_CODE_MAP.put(
new Integer(WSSecurityException.UNSUPPORTED_SECURITY_TOKEN),
WSConstants.UNSUPPORTED_SECURITY_TOKEN
);
FAULT_CODE_MAP.put(
new Integer(UNSUPPORTED_ALGORITHM),
WSConstants.UNSUPPORTED_ALGORITHM
);
FAULT_CODE_MAP.put(
new Integer(INVALID_SECURITY),
WSConstants.INVALID_SECURITY
);
FAULT_CODE_MAP.put(
new Integer(INVALID_SECURITY_TOKEN),
WSConstants.INVALID_SECURITY_TOKEN
);
FAULT_CODE_MAP.put(
new Integer(FAILED_AUTHENTICATION),
WSConstants.FAILED_AUTHENTICATION
);
FAULT_CODE_MAP.put(
new Integer(FAILED_CHECK),
WSConstants.FAILED_CHECK
);
FAULT_CODE_MAP.put(
new Integer(SECURITY_TOKEN_UNAVAILABLE),
WSConstants.SECURITY_TOKEN_UNAVAILABLE
);
FAULT_CODE_MAP.put(
new Integer(MESSAGE_EXPIRED),
WSConstants.MESSAGE_EXPIRED
);
}
private int errorCode;
private Throwable cause;
/**
* Constructor.
*
*
* @param errorCode
* @param msgId
* @param args
* @param exception
*/
public WSSecurityException(int errorCode, String msgId, Object[] args, Throwable exception) {
super(getMessage(errorCode, msgId, args));
this.cause = exception;
this.errorCode = errorCode;
}
/**
* Constructor.
*
*
* @param errorCode
* @param msgId
* @param args
*/
public WSSecurityException(int errorCode, String msgId, Object[] args) {
super(getMessage(errorCode, msgId, args));
this.errorCode = errorCode;
}
/**
* Constructor.
*
*
* @param errorCode
* @param msgId
*/
public WSSecurityException(int errorCode, String msgId) {
this(errorCode, msgId, null);
}
/**
* Constructor.
*
*
* @param errorCode
*/
public WSSecurityException(int errorCode) {
this(errorCode, null, null);
}
/**
* Constructor.
*
*
* @param errorMessage
*/
public WSSecurityException(String errorMessage) {
super(errorMessage);
}
/**
* Constructor.
*
*
* @param errorMessage
*/
public WSSecurityException(String errorMessage, Throwable t) {
super(errorMessage);
this.cause = t;
}
/**
* Get the error code.
*
*
* @return error code of this exception See values above.
*/
public int getErrorCode() {
return this.errorCode;
}
/**
* Get the fault code QName for this associated error code.
*
*
* @return the fault code QName of this exception
*/
public javax.xml.namespace.QName getFaultCode() {
Object ret = FAULT_CODE_MAP.get(new Integer(this.errorCode));
if (ret != null) {
return (javax.xml.namespace.QName)ret;
}
return null;
}
public Throwable getCause() {
return this.cause != null ? this.cause : super.getCause();
}
/**
* Get message allowing for having cause's message included if verbose mode is on
*
*
* @param verbose
* @return the message
*/
public String getMessage(boolean verbose) {
if (verbose) {
return super.getMessage() + "; nested exception is: \n\t" + this.cause.toString();
} else {
return super.getMessage();
}
}
/**
* get the message from resource bundle.
*
*
* @param errorCode
* @param msgId
* @param args
* @return the message translated from the property (message) file.
*/
private static String getMessage(int errorCode, String msgId, Object[] args) {
String msg = null;
try {
msg = resources.getString(String.valueOf(errorCode));
if (msgId != null) {
return msg += (" (" + MessageFormat.format(resources.getString(msgId), args) + ")");
}
} catch (MissingResourceException e) {
throw new RuntimeException("Undefined '" + msgId + "' resource property", e);
}
return msg;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy