From a9a7014cc6e06792d03890ad956d1222e245b8f1 Mon Sep 17 00:00:00 2001
From: Thomas Lenz <thomas.lenz@egiz.gv.at>
Date: Mon, 6 May 2019 13:08:28 +0200
Subject: update error message generation to add msg parameters into GUI model

---
 .../services/IProtocolAuthenticationService.java   |  6 +++
 .../services/ProtocolAuthenticationService.java    | 57 ++++++++++++++--------
 2 files changed, 42 insertions(+), 21 deletions(-)

(limited to 'eaaf_core/src/main/java')

diff --git a/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/api/idp/auth/services/IProtocolAuthenticationService.java b/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/api/idp/auth/services/IProtocolAuthenticationService.java
index f6f8e576..de5eb036 100644
--- a/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/api/idp/auth/services/IProtocolAuthenticationService.java
+++ b/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/api/idp/auth/services/IProtocolAuthenticationService.java
@@ -33,6 +33,12 @@ import at.gv.egiz.eaaf.core.exceptions.EAAFException;
 
 public interface IProtocolAuthenticationService {
 
+	public String PARAM_GUI_ERROMSG = "errorMsg";
+	public String PARAM_GUI_ERRORCODE = "errorCode";
+	public String PARAM_GUI_ERRORCODEPARAMS = "errorParams";
+	public String PARAM_GUI_ERRORSTACKTRACE = "stacktrace";
+	
+	
 	/**
 	 * Initialize an authentication process for this protocol request
 	 * 
diff --git a/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/impl/idp/auth/services/ProtocolAuthenticationService.java b/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/impl/idp/auth/services/ProtocolAuthenticationService.java
index 7d3ca2f8..5d3028bc 100644
--- a/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/impl/idp/auth/services/ProtocolAuthenticationService.java
+++ b/eaaf_core/src/main/java/at/gv/egiz/eaaf/core/impl/idp/auth/services/ProtocolAuthenticationService.java
@@ -25,17 +25,21 @@ package at.gv.egiz.eaaf.core.impl.idp.auth.services;
 import java.io.IOException;
 import java.io.PrintWriter;
 import java.io.StringWriter;
+import java.util.Arrays;
 
 import javax.naming.ConfigurationException;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 
+import org.apache.commons.lang3.ArrayUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.apache.commons.text.StringEscapeUtils;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.context.ApplicationContext;
+import org.springframework.lang.NonNull;
+import org.springframework.lang.Nullable;
 import org.springframework.stereotype.Service;
 
 import at.gv.egiz.components.eventlog.api.EventConstants;
@@ -247,7 +251,7 @@ public class ProtocolAuthenticationService implements IProtocolAuthenticationSer
 		else {
 			//write generic message for general exceptions
 			final String msg = statusMessager.getMessage(IStatusMessenger.CODES_INTERNAL_ERROR_GENERIC, null);			
-			writeHTMLErrorResponse(req, resp, msg, "9199", (Exception) throwable);
+			writeHTMLErrorResponse(req, resp, msg, "9199", null, (Exception) throwable);
 			
 		}
 			
@@ -372,24 +376,31 @@ public class ProtocolAuthenticationService implements IProtocolAuthenticationSer
 		
 	}
 	
-	private void writeHTMLErrorResponse(final HttpServletRequest httpReq, final HttpServletResponse httpResp, final String msg, final String errorCode, final Exception error) throws IOException, EAAFException {
+	private void writeHTMLErrorResponse(@NonNull final HttpServletRequest httpReq, @NonNull final HttpServletResponse httpResp, 
+			@NonNull final String msg, @NonNull  final String errorCode, @Nullable final Object[] params, @NonNull final Exception error) throws IOException, EAAFException {
 
 		try {
 			final IGUIBuilderConfiguration config 
 				= guiConfigFactory.getDefaultErrorGUI(HTTPUtils.extractAuthURLFromRequest(httpReq));
 
-//				HTTPUtils.extractAuthURLFromRequest(req), 
-//					DefaultGUIFormBuilderConfiguration.VIEW_ERRORMESSAGE, 
-//					null);
-							
+			
+			String[] errorCodeParams = null;
+			if (params == null)								
+				errorCodeParams = new String[] {};				
+			else				
+				errorCodeParams = Arrays.copyOf(params, params.length, String[].class);
+				
+				
+			
 			//add errorcode and errormessage
 			if (config instanceof ModifyableGuiBuilderConfiguration) {
-				((ModifyableGuiBuilderConfiguration)config).putCustomParameter("errorMsg", msg);
-				((ModifyableGuiBuilderConfiguration)config).putCustomParameter("errorCode", errorCode);
+				((ModifyableGuiBuilderConfiguration)config).putCustomParameter(PARAM_GUI_ERROMSG, msg);
+				((ModifyableGuiBuilderConfiguration)config).putCustomParameter(PARAM_GUI_ERRORCODE, errorCode);
+				((ModifyableGuiBuilderConfiguration)config).putCustomParameterWithOutEscaption(PARAM_GUI_ERRORCODEPARAMS, ArrayUtils.toString(errorCodeParams));
 				
 				//add stacktrace if debug is enabled
 				if (log.isTraceEnabled()) {
-					((ModifyableGuiBuilderConfiguration)config).putCustomParameter("stacktrace", getStacktraceFromException(error));
+					((ModifyableGuiBuilderConfiguration)config).putCustomParameter(PARAM_GUI_ERRORSTACKTRACE, getStacktraceFromException(error));
 				
 				}
 				
@@ -408,15 +419,7 @@ public class ProtocolAuthenticationService implements IProtocolAuthenticationSer
 		}
 		
 	}
-	
-	private void writeHTMLErrorResponse(final HttpServletRequest req, final HttpServletResponse httpResp, final Exception error) throws IOException, EAAFException {				
-		writeHTMLErrorResponse(req, httpResp, 
-				error.getMessage(), 
-				statusMessager.getResponseErrorCode(error), 
-				error);		
-	}
-	
-	
+		
 	private String getStacktraceFromException(final Exception ex) {
 		final StringWriter errors = new StringWriter();
 	    ex.printStackTrace(new PrintWriter(errors));
@@ -446,15 +449,27 @@ public class ProtocolAuthenticationService implements IProtocolAuthenticationSer
 			
 		} else if (e instanceof ConfigurationException) {
 			//send HTML formated error message
-			writeHTMLErrorResponse(req, resp, e);
+			writeHTMLErrorResponse(req, resp, 
+					e.getMessage(), 
+					statusMessager.getResponseErrorCode(e),
+					null,
+					e);	
 		
 		} else if (e instanceof EAAFException) {
 			//send HTML formated error message
-			writeHTMLErrorResponse(req, resp, e);
+			writeHTMLErrorResponse(req, resp, 
+					e.getMessage(), 
+					statusMessager.getResponseErrorCode(e),
+					((EAAFException) e).getParams(),
+					e);
 					
 		} else if (e instanceof ProcessExecutionException) {
 			//send HTML formated error message
-			writeHTMLErrorResponse(req, resp, e);
+			writeHTMLErrorResponse(req, resp, 
+					e.getMessage(), 
+					statusMessager.getResponseErrorCode(e),
+					null,
+					e);
 					
 		}
 		
-- 
cgit v1.2.3