diff options
7 files changed, 60 insertions, 57 deletions
| diff --git a/id/server/doc/handbook/protocol/protocol.html b/id/server/doc/handbook/protocol/protocol.html index 8e0260a38..ff7921ad5 100644 --- a/id/server/doc/handbook/protocol/protocol.html +++ b/id/server/doc/handbook/protocol/protocol.html @@ -887,6 +887,10 @@ Redirect Binding</td>      <td>Fehler bei der Auswahl oder Initialisierung des gewünschten Anmeldeprozesses</td>    </tr>    <tr> +    <td>9105</td> +    <td>Fehler bei der Fortführung des Anmeldeprozesses</td> +  </tr> +  <tr>      <td>9199</td>      <td>Allgemeiner interner Fehler</td>    </tr> diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/exception/MOAIllegalStateException.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/exception/MOAIllegalStateException.java new file mode 100644 index 000000000..bc19a3f39 --- /dev/null +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/exception/MOAIllegalStateException.java @@ -0,0 +1,46 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.auth.exception; + +import at.gv.egovernment.moa.id.commons.api.exceptions.MOAIDException; + +/** + * @author tlenz + * + */ +public class MOAIllegalStateException extends MOAIDException { + +	/** +	 *  +	 */ +	private static final long serialVersionUID = 613582783125887683L; +	 +	/** +	 *  +	 */ +	public MOAIllegalStateException(String code, Object[] params) { +		super(code, params); +		 +	} + +} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractProcessEngineSignalController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractProcessEngineSignalController.java index a23938f97..f22c82e95 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractProcessEngineSignalController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractProcessEngineSignalController.java @@ -9,6 +9,7 @@ import org.apache.commons.lang.StringEscapeUtils;  import org.springframework.beans.factory.annotation.Autowired;
  import at.gv.egovernment.moa.id.advancedlogging.TransactionIDUtils;
 +import at.gv.egovernment.moa.id.auth.exception.MOAIllegalStateException;
  import at.gv.egovernment.moa.id.commons.MOAIDAuthConstants;
  import at.gv.egovernment.moa.id.commons.api.IRequest;
  import at.gv.egovernment.moa.id.commons.api.exceptions.MOAIDException;
 @@ -30,7 +31,8 @@ public abstract class AbstractProcessEngineSignalController extends AbstractCont  		try {	
  			if (pendingRequestID == null) {
 -				throw new IllegalStateException("Unable to determine MOA pending-request id.");
 +				throw new MOAIllegalStateException("process.03", new Object[]{"Unable to determine MOA pending-request id."});
 +				
  			}
  			IRequest pendingReq = requestStorage.getPendingRequest(pendingRequestID);
 @@ -49,7 +51,8 @@ public abstract class AbstractProcessEngineSignalController extends AbstractCont  			// process instance is mandatory
  			if (pendingReq.getProcessInstanceId() == null) {
 -				throw new IllegalStateException("MOA session does not provide process instance id.");
 +				throw new MOAIllegalStateException("process.03", new Object[]{"MOA session does not provide process instance id."});
 +				
  			}
  			// wake up next task
 diff --git a/id/server/idserverlib/src/main/resources/resources/properties/id_messages_de.properties b/id/server/idserverlib/src/main/resources/resources/properties/id_messages_de.properties index 9986d5679..a579dd80b 100644 --- a/id/server/idserverlib/src/main/resources/resources/properties/id_messages_de.properties +++ b/id/server/idserverlib/src/main/resources/resources/properties/id_messages_de.properties @@ -315,3 +315,4 @@ slo.02=Es wurde keine aktive SSO Session gefunden oder Sie sind bei keiner Onlin  process.01=Fehler beim Ausf\u00FChren des Prozesses.
  process.02=Fehler beim Erstellen eines geeigneten Prozesses f\u00FCr die SessionID {0}.
 +process.03=Fehler beim Weiterführen es Prozesses. Msg:{0}
 diff --git a/id/server/idserverlib/src/main/resources/resources/properties/protocol_response_statuscodes_de.properties b/id/server/idserverlib/src/main/resources/resources/properties/protocol_response_statuscodes_de.properties index f97ebeeca..653e073a2 100644 --- a/id/server/idserverlib/src/main/resources/resources/properties/protocol_response_statuscodes_de.properties +++ b/id/server/idserverlib/src/main/resources/resources/properties/protocol_response_statuscodes_de.properties @@ -102,6 +102,7 @@ service.10=4500  process.01=9104  process.02=9104 +process.03=9105  sp.pvp2.00=4501  sp.pvp2.01=4501 diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/api/exceptions/MOAIDException.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/api/exceptions/MOAIDException.java index 955b0f5ea..6841be92b 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/api/exceptions/MOAIDException.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/api/exceptions/MOAIDException.java @@ -49,16 +49,7 @@ package at.gv.egovernment.moa.id.commons.api.exceptions;  import java.io.PrintStream;  import java.io.PrintWriter; -import javax.xml.parsers.DocumentBuilder; -import javax.xml.parsers.DocumentBuilderFactory; -import javax.xml.parsers.ParserConfigurationException; - -import org.w3c.dom.DOMImplementation; -import org.w3c.dom.Document; -import org.w3c.dom.Element; -  import at.gv.egovernment.moa.id.commons.utils.MOAIDMessageProvider; -import at.gv.egovernment.moa.util.Constants;  /**   * Base class of technical MOA exceptions. @@ -176,47 +167,4 @@ public Object[] getParameters() {  	return parameters;  } -/** -   * Convert this <code>MOAIDException</code> to an <code>ErrorResponse</code> -   * element from the MOA namespace. -   *  -   * @return An <code>ErrorResponse</code> element, containing the subelements -   * <code>ErrorCode</code> and <code>Info</code> required by the MOA schema. -   */ -  public Element toErrorResponse() { -    DocumentBuilder builder; -    DOMImplementation impl; -    Document doc; -    Element errorResponse; -    Element errorCode; -    Element info; - -    // create a new document -    try { -      builder = DocumentBuilderFactory.newInstance().newDocumentBuilder(); -      impl = builder.getDOMImplementation(); -    } catch (ParserConfigurationException e) { -      return null; -    } - -    // build the ErrorResponse element -    doc = impl.createDocument(Constants.MOA_NS_URI, "ErrorResponse", null); -    errorResponse = doc.getDocumentElement(); - -    // add MOA namespace declaration -    errorResponse.setAttributeNS( -      Constants.XMLNS_NS_URI, -      "xmlns", -      Constants.MOA_NS_URI); - -    // build the child elements     -    errorCode = doc.createElementNS(Constants.MOA_NS_URI, "ErrorCode"); -    errorCode.appendChild(doc.createTextNode(messageId)); -    info = doc.createElementNS(Constants.MOA_NS_URI, "Info"); -    info.appendChild(doc.createTextNode(toString())); -    errorResponse.appendChild(errorCode); -    errorResponse.appendChild(info); -    return errorResponse; -  } -  } diff --git a/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/exceptions/OAuth20Exception.java b/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/exceptions/OAuth20Exception.java index d7fecd1b5..5dc36868b 100644 --- a/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/exceptions/OAuth20Exception.java +++ b/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/exceptions/OAuth20Exception.java @@ -22,9 +22,9 @@   *******************************************************************************/  package at.gv.egovernment.moa.id.protocols.oauth20.exceptions; -import at.gv.egovernment.moa.id.commons.utils.MOAIDMessageProvider; +import at.gv.egovernment.moa.id.commons.api.exceptions.MOAIDException; -public class OAuth20Exception extends RuntimeException { +public class OAuth20Exception extends MOAIDException {  	private static final long serialVersionUID = 1L; @@ -33,7 +33,7 @@ public class OAuth20Exception extends RuntimeException {  	private String errorCode;  	public OAuth20Exception(final String errorCode, final String messageId, final Object[] parameters) { -		super(MOAIDMessageProvider.getInstance().getMessage(messageId, parameters)); +		super(messageId, parameters);  		this.errorCode = errorCode;  		this.messageId = messageId;  	} | 
