diff options
33 files changed, 1438 insertions, 2252 deletions
| diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/GUILayoutBuilder.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/GUILayoutBuilder.java new file mode 100644 index 000000000..b95cbbc16 --- /dev/null +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/GUILayoutBuilder.java @@ -0,0 +1,157 @@ +/* + * 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.builder; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.IOException; +import java.io.InputStream; +import java.io.StringWriter; +import java.net.URI; + +import org.apache.commons.io.IOUtils; + +import at.gv.egovernment.moa.id.config.auth.AuthConfigurationProviderFactory; +import at.gv.egovernment.moa.id.config.auth.IOAAuthParameters; +import at.gv.egovernment.moa.id.moduls.IRequest; +import at.gv.egovernment.moa.id.util.FormBuildUtils; +import at.gv.egovernment.moa.logging.Logger; + +/** + * @author tlenz + * + */ +public class GUILayoutBuilder { +	private static final String CSS_LAYOUTTEMPLATE = "css_template.css"; +	private static final String JS_LAYOUTTEMPLATE = "javascript_tempalte.js";	 +	private static final String HTMLTEMPLATESDIR = "htmlTemplates/"; + +	private static String CONTEXTPATH = "#CONTEXTPATH#"; +	private static String MOASESSIONID = "#SESSIONID#"; +	private static String AUTH_URL = "#AUTH_URL#"; +	private static String BKU_ONLINE = "#ONLINE#"; +	private static String BKU_HANDY =  "#HANDY#";  +	private static String BKU_LOCAL =  "#LOCAL#";  +	 +	 +	public static String buildCSS(IRequest pendingReq, String authURL) { +		return buildForm(pendingReq, authURL, CSS_LAYOUTTEMPLATE); +		 +	} +	 +	public static String buildJS(IRequest pendingReq, String authURL) { +		return buildForm(pendingReq, authURL, JS_LAYOUTTEMPLATE); +		 +	} +	 +	 +	 +	private static String getTemplate(String templateName) {		 +		String pathLocation; +		InputStream input = null; +		try { +			String rootconfigdir = AuthConfigurationProviderFactory.getInstance().getRootConfigFileDir();	 +			pathLocation = rootconfigdir + HTMLTEMPLATESDIR + templateName; +		 +			try { +				File file = new File(new URI(pathLocation)); +				input = new  FileInputStream(file); +			 +			} catch (FileNotFoundException e)  {				 +				Logger.warn("No LoginFormTempaltes found. Use Generic Templates from package.");			 +				pathLocation = "resources/templates/" + templateName;			 +				input = Thread.currentThread() +						.getContextClassLoader() +						.getResourceAsStream(pathLocation); +			 +			} +			 +			return getTemplate(input); +			 +		} catch (Exception e) {			 +			return null; +			 +		} finally { +			try { +				if (input != null) +					input.close(); +				 +			} catch (IOException e) { +				Logger.warn("SendAssertionTemplate inputstream can not be closed.", e); +				 +			} +		}		 +	} +	 +	private static String getTemplate(InputStream input) { +			String template = null;			 +		try {				 + +			StringWriter writer = new StringWriter(); +			IOUtils.copy(input, writer); +			template = writer.toString(); +							 +		} catch (Exception e) { +			Logger.error("Failed to read template", e); +			 +		}			 +		return template; +	} +	 +	private static String buildForm(IRequest pendingReq, String authURL, String templateName) { +		//load default GUI-Layout template template +		String value = getTemplate(templateName); + +		if (pendingReq != null) { +			IOAAuthParameters oaParam = pendingReq.getOnlineApplicationConfiguration(); +				 +			if(value != null) { +				//only for BKU-Selection step and JavaScript generation +				value = value.replace(AUTH_URL, LoginFormBuilder.SERVLET); +				 +				value = value.replace(CONTEXTPATH, pendingReq.getAuthURL()); +				value = value.replace(MOASESSIONID, pendingReq.getRequestID()); +								 +				value = value.replace(BKU_ONLINE, IOAAuthParameters.ONLINEBKU); +				value = value.replace(BKU_HANDY, IOAAuthParameters.HANDYBKU); +				value = value.replace(BKU_LOCAL, IOAAuthParameters.LOCALBKU); +				 +				 +				value = FormBuildUtils.customiceLayoutBKUSelection(value,  +						oaParam.isShowMandateCheckBox(), +						oaParam.isOnlyMandateAllowed(), +						oaParam.getFormCustomizaten(), +						oaParam.isShowStorkLogin());			 +			} +						 +		} else { +			value = FormBuildUtils.defaultLayoutBKUSelection(value); +			value = value.replace(CONTEXTPATH, authURL); +								 +		} +		 +		return value;		 +	} +	 +} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/LoginFormBuilder.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/LoginFormBuilder.java index 4bcda3517..e1aa41ce2 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/LoginFormBuilder.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/builder/LoginFormBuilder.java @@ -47,8 +47,6 @@ public class LoginFormBuilder {  	private static final String HTMLTEMPLATEFULL = "loginFormFull.html";  	private static String AUTH_URL = "#AUTH_URL#"; -	private static String MODUL = "#MODUL#"; -	private static String ACTION = "#ACTION#";  	private static String OANAME = "#OAName#";  	private static String BKU_ONLINE = "#ONLINE#";  	private static String BKU_HANDY =  "#HANDY#";  @@ -57,7 +55,7 @@ public class LoginFormBuilder {  	private static String MOASESSIONID = "#SESSIONID#";  	private static String PEPSLIST = "#PEPSLIST#"; -	private static String SERVLET = CONTEXTPATH+"/GenerateIframeTemplate"; +	public static String SERVLET = CONTEXTPATH+"/GenerateIframeTemplate";  	private static String getTemplate() {  		String pathLocation =""; diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/modules/internal/tasks/EvaluateSSOConsentsTaskImpl.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/modules/internal/tasks/EvaluateSSOConsentsTaskImpl.java index d52b76ebd..5b53a43bd 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/modules/internal/tasks/EvaluateSSOConsentsTaskImpl.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/modules/internal/tasks/EvaluateSSOConsentsTaskImpl.java @@ -90,19 +90,21 @@ public class EvaluateSSOConsentsTaskImpl extends AbstractAuthServletTask {  			if (ssoConsents) {  				//authenticate pending-request  				pendingReq.setAuthenticated(true); -				 -				//store pending-request -				requestStoreage.storePendingRequest(pendingReq); -				 -				//redirect to auth. protocol finalization -				performRedirectToProtocolFinialization(pendingReq, response); -				 +				pendingReq.setAbortedByUser(false); +								  			} else {  				//user deny single sign-on authentication -				throw new AuthenticationException("auth.21", new Object[] {}); -				 +				Logger.debug("User deny the Single Sign-On authentication for SP: " + pendingReq.getOAURL()); +				pendingReq.setAbortedByUser(true); +			  			} -						 +			 +			//store pending-request			 +			requestStoreage.storePendingRequest(pendingReq); + +			//redirect to auth. protocol finalization +			performRedirectToProtocolFinialization(pendingReq, response); +			  		} catch (MOAIDException e) {  			throw new TaskExecutionException(pendingReq, e.getMessage(), e); diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java index 8567d7834..36390ba62 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java @@ -56,6 +56,7 @@ import at.gv.egovernment.moa.id.protocols.AbstractAuthProtocolModulController;  import at.gv.egovernment.moa.id.protocols.pvp2x.exceptions.AuthnRequestValidatorException;  import at.gv.egovernment.moa.id.storage.ITransactionStorage;  import at.gv.egovernment.moa.id.util.ErrorResponseUtils; +import at.gv.egovernment.moa.id.util.HTTPUtils;  import at.gv.egovernment.moa.id.util.MOAIDMessageProvider;  import at.gv.egovernment.moa.id.util.Random;  import at.gv.egovernment.moa.id.util.ServletUtils; @@ -73,6 +74,7 @@ public abstract class AbstractController extends MOAIDAuthConstants {  	private static final String HTMLTEMPLATESDIR = "htmlTemplates/";  	private static final String HTMLTEMPLATEFULL = "error_message.html"; +	private static String CONTEXTPATH = "#CONTEXTPATH#";  	@Autowired protected StatisticLogger statisticLogger;  	@Autowired protected IRequestStorage requestStorage; @@ -185,7 +187,7 @@ public abstract class AbstractController extends MOAIDAuthConstants {  		else {  			//write generic message for general exceptions  			String msg = MOAIDMessageProvider.getInstance().getMessage("internal.00", null);			 -			writeHTMLErrorResponse(resp, msg, "9199", (Exception) throwable); +			writeHTMLErrorResponse(req, resp, msg, "9199", (Exception) throwable);  		} @@ -197,15 +199,16 @@ public abstract class AbstractController extends MOAIDAuthConstants {  	 * @param loggedException Exception to log  	 */	  	protected void logExceptionToTechnicalLog(Throwable loggedException) { -		if (!(loggedException instanceof MOAIDException)) { +		if (!( loggedException instanceof MOAIDException  +				 || loggedException instanceof ProcessExecutionException )) {  			Logger.error("Receive an internal error: Message=" + loggedException.getMessage(), loggedException);  		} else {  			if (Logger.isDebugEnabled() || Logger.isTraceEnabled()) { -				Logger.error(loggedException.getMessage(), loggedException); +				Logger.warn(loggedException.getMessage(), loggedException);  			} else { -				Logger.error(loggedException.getMessage()); +				Logger.info(loggedException.getMessage());  			}			  		}		 @@ -223,7 +226,7 @@ public abstract class AbstractController extends MOAIDAuthConstants {  	} -	private void writeHTMLErrorResponse(HttpServletResponse httpResp, String msg, String errorCode, Exception error) throws IOException { +	private void writeHTMLErrorResponse(HttpServletRequest req, HttpServletResponse httpResp, String msg, String errorCode, Exception error) throws IOException {  		VelocityContext context = new VelocityContext();  		//add errorcode and errormessage @@ -236,11 +239,11 @@ public abstract class AbstractController extends MOAIDAuthConstants {  		} -		writeHTMLErrorResponse(httpResp, context); +		writeHTMLErrorResponse(req, httpResp, context);  	} -	private void writeHTMLErrorResponse(HttpServletResponse httpResp, Exception error) throws IOException {		 +	private void writeHTMLErrorResponse(HttpServletRequest req, HttpServletResponse httpResp, Exception error) throws IOException {		  		VelocityContext context = new VelocityContext();  		//add errorcode and errormessage @@ -253,11 +256,14 @@ public abstract class AbstractController extends MOAIDAuthConstants {  		} -		writeHTMLErrorResponse(httpResp, context); +		writeHTMLErrorResponse(req, httpResp, context);  	} -	private void writeHTMLErrorResponse(HttpServletResponse httpResp, VelocityContext context) throws IOException { -		try {						 +	private void writeHTMLErrorResponse(HttpServletRequest req, HttpServletResponse httpResp, VelocityContext context) throws IOException { +		try { +			String authURL = HTTPUtils.extractAuthURLFromRequest(req); +			context.put(CONTEXTPATH, authURL); +			  			InputStream is = null;  			String pathLocation = null;  			try { @@ -361,15 +367,15 @@ public abstract class AbstractController extends MOAIDAuthConstants {  		} else if (e instanceof ConfigurationException) {  			//send HTML formated error message -			writeHTMLErrorResponse(resp, (MOAIDException) e); +			writeHTMLErrorResponse(req, resp, (MOAIDException) e);  		} else if (e instanceof MOAIDException) {  			//send HTML formated error message -			writeHTMLErrorResponse(resp, e); +			writeHTMLErrorResponse(req, resp, e);  		} else if (e instanceof ProcessExecutionException) {  			//send HTML formated error message -			writeHTMLErrorResponse(resp, e); +			writeHTMLErrorResponse(req, resp, e);  		} 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 8b96b884e..6be0fce90 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 @@ -23,7 +23,7 @@ import at.gv.egovernment.moa.logging.Logger;   */
  public abstract class AbstractProcessEngineSignalController extends AbstractController {
 -	@Autowired ProcessEngine processEngine;
 +	@Autowired protected ProcessEngine processEngine;
  	protected void signalProcessManagement(HttpServletRequest req, HttpServletResponse resp) throws IOException {
  		String pendingRequestID = StringEscapeUtils.escapeHtml(getPendingRequestId(req));
 diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GUILayoutBuilderServlet.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GUILayoutBuilderServlet.java new file mode 100644 index 000000000..1d9a57b48 --- /dev/null +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GUILayoutBuilderServlet.java @@ -0,0 +1,126 @@ +/* + * 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.servlet; + +import java.io.IOException; +import java.io.PrintWriter; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + +import org.apache.commons.lang.StringEscapeUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RequestMethod; + +import at.gv.egovernment.moa.id.auth.MOAIDAuthConstants; +import at.gv.egovernment.moa.id.auth.builder.GUILayoutBuilder; +import at.gv.egovernment.moa.id.config.auth.AuthConfiguration; +import at.gv.egovernment.moa.id.moduls.IRequest; +import at.gv.egovernment.moa.id.moduls.IRequestStorage; +import at.gv.egovernment.moa.id.util.HTTPUtils; +import at.gv.egovernment.moa.logging.Logger; +import at.gv.egovernment.moa.util.MiscUtil; + +/** + * @author tlenz + * + */ +@Controller +public class GUILayoutBuilderServlet extends AbstractController { + +	public static final String ENDPOINT_CSS = "/css/buildCSS"; +	public static final String ENDPOINT_JS = "/js/buildJS"; +	 +	@Autowired AuthConfiguration authConfig; +	@Autowired IRequestStorage requestStoreage; +	 +	public GUILayoutBuilderServlet() { +		super(); +		Logger.debug("Registering servlet " + getClass().getName()  +				+ " with mappings '" + ENDPOINT_CSS  +				+ "' and '" + ENDPOINT_JS + "'."); +		 +	} +	 +	@RequestMapping(value = "/css/buildCSS", method = {RequestMethod.GET}) +	public void buildCSS(HttpServletRequest req, HttpServletResponse resp) throws IOException {		 +		IRequest pendingReq = extractPendingRequest(req); + +		//build Service-Provider specific CSS +		String css = GUILayoutBuilder.buildCSS(pendingReq, HTTPUtils.extractAuthURLFromRequest(req)); + +		resp.setContentType("text/css;charset=UTF-8"); +		writeResponse(resp, css, "CSS"); +							 +	} +	 +	@RequestMapping(value = "/js/buildJS", method = {RequestMethod.GET}) +	public void buildJavaScript(HttpServletRequest req, HttpServletResponse resp) throws IOException { +		IRequest pendingReq = extractPendingRequest(req); +		 +		//build Service-Provider specific CSS +		String js = GUILayoutBuilder.buildJS(pendingReq, HTTPUtils.extractAuthURLFromRequest(req)); +			 +		resp.setContentType("text/javascript;charset=UTF-8");			 +		writeResponse(resp, js, "JavaScript"); +					 +	} +	 +	private void writeResponse(HttpServletResponse resp, String value, String ressourceID) throws IOException { +		if (MiscUtil.isNotEmpty(value)) { +			PrintWriter out = new PrintWriter(resp.getOutputStream());  +			out.print(value); +			out.flush(); +			 +		} else { +			Logger.warn("GUI ressource: " + ressourceID + " generation FAILED."); +			resp.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR, "Created resource failed"); +			 +		} +		 +	} +	 +	private IRequest extractPendingRequest(HttpServletRequest req) { +		try { +			String authURL = HTTPUtils.extractAuthURLFromRequest(req);		 +			String pendingReqID = StringEscapeUtils.escapeHtml( +					req.getParameter(MOAIDAuthConstants.PARAM_TARGET_PENDINGREQUESTID)); +		 +			if (MiscUtil.isNotEmpty(pendingReqID) && authConfig.getPublicURLPrefix().contains(authURL)) {		 +				IRequest pendingReq = requestStorage.getPendingRequest(pendingReqID); +				if (pendingReq != null) +					return pendingReq; +			 +			} +			 +			Logger.info("Prohibit GUI-Layout builder-request. No pending-request or wrong auth-URL."); +			 +		} catch (Exception e) { +			Logger.warn("GUI-Layout builder-servlet has an error during request-preprocessing.", e); +		}	 +		 +		return null; +	} +} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GeneralProcessEngineSignalController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GeneralProcessEngineSignalController.java index 6bccd5b88..26a0488ca 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GeneralProcessEngineSignalController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/GeneralProcessEngineSignalController.java @@ -39,6 +39,8 @@ import org.springframework.web.bind.annotation.RequestMethod;  public class GeneralProcessEngineSignalController extends AbstractProcessEngineSignalController { +	 +	  	@RequestMapping(value = {"/GenerateIframeTemplate",   							 "/SSOSendAssertionServlet",  							 "/signalProcess" diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/IDPSingleLogOutServlet.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/IDPSingleLogOutServlet.java index 307b668b7..427bb9464 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/IDPSingleLogOutServlet.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/IDPSingleLogOutServlet.java @@ -62,7 +62,7 @@ import at.gv.egovernment.moa.util.URLEncoder;   */  @Controller  public class IDPSingleLogOutServlet extends AbstractController { - +	  	@Autowired SSOManager ssoManager;  	@Autowired AuthenticationManager authManager;  	@Autowired IAuthenticationSessionStoreage authenicationStorage; @@ -71,7 +71,7 @@ public class IDPSingleLogOutServlet extends AbstractController {  	@RequestMapping(value = "/idpSingleLogout", method = {RequestMethod.GET})  	public void doGet(HttpServletRequest req, HttpServletResponse resp)  			    throws ServletException, IOException { -		Logger.debug("receive IDP SingleLogOut Request"); +		Logger.debug("Receive IDP-initiated SingleLogOut");  		String authURL = HTTPUtils.extractAuthURLFromRequest(req);  		try { @@ -111,7 +111,9 @@ public class IDPSingleLogOutServlet extends AbstractController {  				else  					context.put("errorMsg",   							MOAIDMessageProvider.getInstance().getMessage("slo.01", null)); -	                	 + +				context.put(SSOManager.CONTEXTPATH, authURL); +				  				ssoManager.printSingleLogOutInfo(context, resp);				  			} catch (MOAIDException e) { @@ -139,13 +141,9 @@ public class IDPSingleLogOutServlet extends AbstractController {  						}  					}  				} -			} catch (MOADatabaseException e) { -				//TODO: insert error Handling -				e.printStackTrace(); +			} catch (Exception e) { +				handleErrorNoRedirect(e, req, resp, false); -			} catch (MOAIDException e) { -				// TODO Auto-generated catch block -				e.printStackTrace();  			}				  		} else if (restartProcessObj != null && restartProcessObj instanceof String) { diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/LogOutServlet.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/LogOutServlet.java index 4ed276814..4fcf166c9 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/LogOutServlet.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/LogOutServlet.java @@ -76,7 +76,7 @@ public class LogOutServlet {  	@RequestMapping(value = "/LogOut", method = {RequestMethod.POST, RequestMethod.GET})  	public void performLogOut(HttpServletRequest req, HttpServletResponse resp) throws IOException { -		Logger.debug("receive LogOut Request");   +		Logger.debug("Receive simple LogOut Request");    		String redirectUrl = (String) req.getParameter(REDIRECT_URL); diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/interceptor/WebFrontEndSecurityInterceptor.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/interceptor/WebFrontEndSecurityInterceptor.java index c5a9ad34b..ce384d1a0 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/interceptor/WebFrontEndSecurityInterceptor.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/interceptor/WebFrontEndSecurityInterceptor.java @@ -50,7 +50,7 @@ public class WebFrontEndSecurityInterceptor implements HandlerInterceptor {  	@Override  	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)  			throws Exception { -		 +				  		//only for SAML1 GetAuthenticationData webService functionality  		String requestedServlet = request.getServletPath();		  		if (MiscUtil.isNotEmpty(requestedServlet) && requestedServlet.startsWith("/services/GetAuthenticationData")) { @@ -61,7 +61,9 @@ public class WebFrontEndSecurityInterceptor implements HandlerInterceptor {  		//check AuthURL  	    String authURL = HTTPUtils.extractAuthURLFromRequest(request); -		if (!authURL.startsWith("https:") && !authConfig.isHTTPAuthAllowed()) { +		if (!authURL.startsWith("https:") && !authConfig.isHTTPAuthAllowed() &&  +				!authConfig.getPublicURLPrefix().contains(authURL)) { +			Logger.info("Receive request, which is not in IDP URL-Prefix whitelist.");  			String errorMsg = MOAIDMessageProvider.getInstance().getMessage("auth.07", new Object[] { authURL + "*" });  			Logger.info(errorMsg);  			response.sendError( diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationContainer.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationContainer.java index ba7f33821..fd1749129 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationContainer.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationContainer.java @@ -41,10 +41,20 @@ public class SLOInformationContainer implements Serializable, ISLOInformationCon  	private static final long serialVersionUID = 7148730740582881862L;  	private PVPTargetConfiguration sloRequest = null; -	private LinkedHashMap<String, SLOInformationImpl> activeFrontChannalOAs = null; -	private LinkedHashMap<String, SLOInformationImpl> activeBackChannelOAs = null; +	private LinkedHashMap<String, SLOInformationImpl> activeFrontChannalOAs; +	private LinkedHashMap<String, SLOInformationImpl> activeBackChannelOAs;  	private List<String> sloFailedOAs = null; +	/** +	 *  +	 */ +	public SLOInformationContainer() { +		this.activeBackChannelOAs = new LinkedHashMap<String, SLOInformationImpl>();  +		this.activeFrontChannalOAs = new LinkedHashMap<String, SLOInformationImpl>();  +		this.sloFailedOAs = new ArrayList<String>(); +		 +	} +	  	/**  	 * @return the activeFrontChannalOAs diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationImpl.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationImpl.java index 55a56056d..2d84bf472 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationImpl.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationImpl.java @@ -40,16 +40,18 @@ public class SLOInformationImpl implements SLOInformationInterface, Serializable  	private String binding = null;  	private String serviceURL = null;  	private String authURL = null; +	private String spEntityID = null; -	public SLOInformationImpl(String authURL, String sessionID, String nameID, String nameIDFormat, String protocolType) { -		new SLOInformationImpl(authURL, sessionID, nameID, nameIDFormat, protocolType, null); +	public SLOInformationImpl(String authURL, String spEntityID, String sessionID, String nameID, String nameIDFormat, String protocolType) { +		new SLOInformationImpl(authURL, spEntityID, sessionID, nameID, nameIDFormat, protocolType, null);  	} -	public SLOInformationImpl(String authURL, String sessionID, String nameID, String nameIDFormat, String protocolType, SingleLogoutService sloService) { +	public SLOInformationImpl(String authURL, String spEntityID, String sessionID, String nameID, String nameIDFormat, String protocolType, SingleLogoutService sloService) {  		this.sessionIndex = sessionID;  		this.nameID = nameID;  		this.nameIDFormat = nameIDFormat;  		this.protocolType = protocolType; +		this.spEntityID = spEntityID;  		if (authURL.endsWith("/"))  			this.authURL = authURL.substring(0, authURL.length()-1); @@ -72,6 +74,14 @@ public class SLOInformationImpl implements SLOInformationInterface, Serializable  	} +	 +	/** +	 * @return the spEntityID +	 */ +	public String getSpEntityID() { +		return spEntityID; +	} +  	/* (non-Javadoc)  	 * @see at.gv.egovernment.moa.id.data.SLOInformationInterface#getSessionIndex()  	 */ @@ -161,6 +171,14 @@ public class SLOInformationImpl implements SLOInformationInterface, Serializable  	public String getAuthURL() {  		return authURL;  	} + +	/** +	 * @param spEntityID the spEntityID to set +	 */ +	public void setSpEntityID(String spEntityID) { +		this.spEntityID = spEntityID; +	} +	 diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationInterface.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationInterface.java index b2241f8ed..31fdaacfd 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationInterface.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/data/SLOInformationInterface.java @@ -59,5 +59,12 @@ public interface SLOInformationInterface{  	 */  	public String getUserNameIDFormat(); +	/** +	 * Get the unique entityID of this Service-Provider +	 *  +	 * @return unique identifier, but never null +	 */ +	public String getSpEntityID(); +	  } diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/AuthenticationManager.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/AuthenticationManager.java index 22561e435..73d682c21 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/AuthenticationManager.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/AuthenticationManager.java @@ -115,7 +115,7 @@ public class AuthenticationManager extends MOAIDAuthConstants {  	public void performOnlyIDPLogOut(HttpServletRequest request,  			HttpServletResponse response, String moaSessionID) { -		Logger.info("Logout"); +		Logger.info("Remove active user-session");  		if(moaSessionID == null) {  			moaSessionID = (String) request.getParameter(PARAM_SESSIONID); @@ -440,6 +440,8 @@ public class AuthenticationManager extends MOAIDAuthConstants {  		String pvpSLOIssuer = null;  		String inboundRelayState = null; +		Logger.debug("Start technical Single LogOut process ... "); +		  		if (pvpReq != null) {  			MOARequest samlReq = (MOARequest) pvpReq.getRequest();  			LogoutRequest logOutReq = (LogoutRequest) samlReq.getSamlRequest(); @@ -455,18 +457,25 @@ public class AuthenticationManager extends MOAIDAuthConstants {  		sloContainer.setSloRequest(pvpReq);		  		sloBuilder.parseActiveIDPs(sloContainer, dbIDPs, pvpSLOIssuer);  		sloBuilder.parseActiveOAs(sloContainer, dbOAs, pvpSLOIssuer); -						 +			 +		Logger.debug("Active SSO Service-Provider: "  +				 + " BackChannel:" + sloContainer.getActiveBackChannelOAs().size() +				 + " FrontChannel:" + sloContainer.getActiveFrontChannalOAs().size() +				 + " NO_SLO_Support:" + sloContainer.getSloFailedOAs().size()); +		  		//terminate MOASession  		try {  			authenticatedSessionStore.destroySession(session.getSessionID()); -			ssoManager.deleteSSOSessionID(httpReq, httpResp); -			 +			ssoManager.deleteSSOSessionID(httpReq, httpResp);			 +			Logger.debug("Active SSO Session on IDP is remove."); +						  		} catch (MOADatabaseException e) {  			Logger.warn("Delete MOASession FAILED.");  			sloContainer.putFailedOA(pvpReq.getAuthURL());  		} +		Logger.trace("Starting Service-Provider logout process ... ");  		//start service provider back channel logout process  		Iterator<String> nextOAInterator = sloContainer.getNextBackChannelOA();	  		while (nextOAInterator.hasNext()) { @@ -474,6 +483,7 @@ public class AuthenticationManager extends MOAIDAuthConstants {  			LogoutRequest sloReq = sloBuilder.buildSLORequestMessage(sloDescr);  			try { +				Logger.trace("Send backchannel SLO Request to " + sloDescr.getSpEntityID());  				List<XMLObject> soapResp = MOASAMLSOAPClient.send(sloDescr.getServiceURL(), sloReq);  				LogoutResponse sloResp = null;						 @@ -483,9 +493,9 @@ public class AuthenticationManager extends MOAIDAuthConstants {  				}  				if (sloResp == null) { -					Logger.warn("Single LogOut for OA " + sloReq.getIssuer().getValue() +					Logger.warn("Single LogOut for OA " + sloDescr.getSpEntityID()  							+ " FAILED. NO LogOut response received."); -					sloContainer.putFailedOA(sloReq.getIssuer().getValue()); +					sloContainer.putFailedOA(sloDescr.getSpEntityID());  				} else {  					samlVerificationEngine.verifySLOResponse(sloResp,  @@ -496,14 +506,14 @@ public class AuthenticationManager extends MOAIDAuthConstants {  				sloBuilder.checkStatusCode(sloContainer, sloResp);  			} catch (SOAPException e) { -				Logger.warn("Single LogOut for OA " + sloReq.getIssuer().getValue() +				Logger.warn("Single LogOut for OA " + sloDescr.getSpEntityID()  						+ " FAILED.", e); -				sloContainer.putFailedOA(sloReq.getIssuer().getValue()); +				sloContainer.putFailedOA(sloDescr.getSpEntityID());  			} catch (SecurityException | InvalidProtocolRequestException e) { -				Logger.warn("Single LogOut for OA " + sloReq.getIssuer().getValue() +				Logger.warn("Single LogOut for OA " + sloDescr.getSpEntityID()  						+ " FAILED.", e); -				sloContainer.putFailedOA(sloReq.getIssuer().getValue()); +				sloContainer.putFailedOA(sloDescr.getSpEntityID());  			}					  		} @@ -516,6 +526,8 @@ public class AuthenticationManager extends MOAIDAuthConstants {  				Collection<Entry<String, SLOInformationImpl>> sloDescr = sloContainer.getFrontChannelOASessionDescriptions();  				List<String> sloReqList = new ArrayList<String>();  				for (Entry<String, SLOInformationImpl> el : sloDescr) { +					Logger.trace("Build frontChannel SLO Request for " + el.getValue().getSpEntityID()); +					  					LogoutRequest sloReq = sloBuilder.buildSLORequestMessage(el.getValue());  					try {  						sloReqList.add(sloBuilder.getFrontChannelSLOMessageURL(el.getValue().getServiceURL(), el.getValue().getBinding(),  @@ -542,6 +554,7 @@ public class AuthenticationManager extends MOAIDAuthConstants {  		        context.put("redirectURLs", sloReqList);  		        context.put("timeoutURL", timeOutURL);  		        context.put("timeout", SLOTIMEOUT); +		        context.put(SSOManager.CONTEXTPATH, authURL);  		        ssoManager.printSingleLogOutInfo(context, httpResp); diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/IRequest.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/IRequest.java index f5d381e42..e1edb6b77 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/IRequest.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/IRequest.java @@ -175,4 +175,18 @@ public interface IRequest {  	 * @return Service-Provider configuration  	 */  	public IOAAuthParameters getOnlineApplicationConfiguration(); + +	/** +	 * Indicates, if this pending-request is aborted by the user +	 *  +	 * @return true, if it is aborted, otherwise false +	 */ +	public boolean isAbortedByUser(); + +	/** +	 * Set the 'isAboredByUser' flag of this pending-request +	 *  +	 * @param b true, if the user has abort the authentication process, otherwise false +	 */ +	public void setAbortedByUser(boolean isAborted);  } diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/RequestImpl.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/RequestImpl.java index 961700651..4dade61fa 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/RequestImpl.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/RequestImpl.java @@ -69,13 +69,17 @@ public abstract class RequestImpl implements IRequest, Serializable{  	private boolean passiv = false;  	private boolean force = false; -	 -	private boolean needAuthentication = true; -	private boolean isAuthenticated = false;  	private boolean needSSO = false; +	private boolean isAbortedByUser = false; +	//every request needs authentication by default +	private boolean needAuthentication = true; +	//every request is not authenticated by default +	private boolean isAuthenticated = false; +		  	private Map<String, Object> genericDataStorage = new HashMap<String, Object>(); +	  	/**  	 * @throws ConfigurationException  @@ -324,6 +328,15 @@ public abstract class RequestImpl implements IRequest, Serializable{  	} +	public boolean isAbortedByUser() { +		return this.isAbortedByUser; +	} + +	public void setAbortedByUser(boolean isAborted) { +		this.isAbortedByUser = isAborted; +		 +	} +	  	public Object getGenericData(String key) {  		if (MiscUtil.isNotEmpty(key)) {  			return genericDataStorage.get(key); diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/SSOManager.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/SSOManager.java index 89d50425b..856410d7b 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/SSOManager.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/moduls/SSOManager.java @@ -61,10 +61,10 @@ import at.gv.egovernment.moa.logging.Logger;  import at.gv.egovernment.moa.util.MiscUtil;  @Service("MOAID_SSOManager") -public class SSOManager { -	 +public class SSOManager {	  	private static final String HTMLTEMPLATESDIR = "htmlTemplates/";  	private static final String HTMLTEMPLATEFULL = "slo_template.html"; +	public static String CONTEXTPATH = "#CONTEXTPATH#";  	private static final String SSOCOOKIE = "MOA_ID_SSO";  	private static final String SSOINTERFEDERATION = "MOA_INTERFEDERATION_SSO"; diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/AbstractAuthProtocolModulController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/AbstractAuthProtocolModulController.java index e6f08abd9..bf00cadaf 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/AbstractAuthProtocolModulController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/AbstractAuthProtocolModulController.java @@ -34,6 +34,7 @@ import at.gv.egovernment.moa.id.auth.builder.AuthenticationDataBuilder;  import at.gv.egovernment.moa.id.auth.data.AuthenticationSession;  import at.gv.egovernment.moa.id.auth.exception.AuthenticationException;  import at.gv.egovernment.moa.id.auth.servlet.AbstractController; +import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException;  import at.gv.egovernment.moa.id.config.auth.IOAAuthParameters;  import at.gv.egovernment.moa.id.data.IAuthData;  import at.gv.egovernment.moa.id.data.SLOInformationInterface; @@ -99,9 +100,32 @@ public abstract class AbstractAuthProtocolModulController extends AbstractContro  		} catch (Exception e) {  			buildProtocolSpecificErrorResponse(e, req, resp, pendingReq); +			removeUserSession(pendingReq, req, resp); +						  		}		  	} +	 +	protected String createNewSSOSessionCookie(HttpServletRequest req, HttpServletResponse resp,  +			IRequest pendingReq, AuthenticationSession moaSession) { +		Logger.debug("Add SSO information to MOASession."); +		 +		//Store SSO information into database +		String newSSOSessionId = ssomanager.createSSOSessionInformations(moaSession.getSessionID(),  +				pendingReq.getOAURL()); + +		//set SSO cookie to response +		if (MiscUtil.isNotEmpty(newSSOSessionId)) { +			ssomanager.setSSOSessionID(req, resp, newSSOSessionId); +	 +		} else { +			ssomanager.deleteSSOSessionID(req, resp); +		 +		} +		 +		return newSSOSessionId; +	} +	  	/**  	 * Finalize the requested protocol operation  	 *  @@ -118,21 +142,7 @@ public abstract class AbstractAuthProtocolModulController extends AbstractContro  		//if Single Sign-On functionality is enabled for this request  		if (pendingReq.needSingleSignOnFunctionality()) { -			 -			Logger.debug("Add SSO information to MOASession."); -			 -			//Store SSO information into database -			newSSOSessionId = ssomanager.createSSOSessionInformations(moaSession.getSessionID(),  -					pendingReq.getOAURL()); -	 -			//set SSO cookie to response -			if (MiscUtil.isNotEmpty(newSSOSessionId)) { -				ssomanager.setSSOSessionID(req, resp, newSSOSessionId); -		 -			} else { -				ssomanager.deleteSSOSessionID(req, resp); -			 -			} +			newSSOSessionId = createNewSSOSessionCookie(req, resp, pendingReq, moaSession);  		} @@ -202,6 +212,23 @@ public abstract class AbstractAuthProtocolModulController extends AbstractContro  	} +	protected void removeUserSession(IRequest pendingReq, HttpServletRequest req,  +			HttpServletResponse resp) {		 +		try { +			AuthenticationSession moaSession = authenticatedSessionStorage.getSession( +					pendingReq.getMOASessionIdentifier()); +			 +			if (moaSession != null) +				authmanager.performOnlyIDPLogOut(req, resp, moaSession.getSessionID()); + +		} catch (MOADatabaseException e) { +			Logger.error("Remove user-session FAILED." , e); +			 +		} +		 +		 +	} +	  	protected void buildProtocolSpecificErrorResponse(Throwable throwable, HttpServletRequest req,   			HttpServletResponse resp, IRequest protocolRequest) throws IOException {  		try { @@ -226,12 +253,6 @@ public abstract class AbstractAuthProtocolModulController extends AbstractContro  				//log Error Message  				statisticLogger.logErrorOperation(throwable, protocolRequest); -				//remove MOASession -				AuthenticationSession moaSession = authenticatedSessionStorage.getSession( -						protocolRequest.getMOASessionIdentifier()); -				if (moaSession != null) -					authmanager.performOnlyIDPLogOut(req, resp, moaSession.getSessionID()); -				  				return;  			} else { diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/ProtocolFinalizationController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/ProtocolFinalizationController.java index 8c3f2c946..a9fc994ec 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/ProtocolFinalizationController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/ProtocolFinalizationController.java @@ -33,6 +33,7 @@ import org.springframework.web.bind.annotation.RequestMethod;  import at.gv.egovernment.moa.id.advancedlogging.MOAIDEventConstants;  import at.gv.egovernment.moa.id.auth.data.AuthenticationSession; +import at.gv.egovernment.moa.id.auth.exception.AuthenticationException;  import at.gv.egovernment.moa.id.auth.exception.MOAIDException;  import at.gv.egovernment.moa.id.auth.exception.WrongParametersException;  import at.gv.egovernment.moa.id.moduls.IRequest; @@ -74,18 +75,9 @@ public class ProtocolFinalizationController extends AbstractAuthProtocolModulCon  						//build protocol-specific error message if possible  						buildProtocolSpecificErrorResponse(throwable, req, resp, pendingReq); -						 -						//log Error Message -						statisticLogger.logErrorOperation(throwable, pendingReq); -						 -						//get MOASession for this pendingRequest -						AuthenticationSession moaSession =  -								authenticatedSessionStorage.getSession( -										pendingReq.getMOASessionIdentifier()); -						 -						//remove MOASession if someone is found -						if (moaSession != null) -							authmanager.performOnlyIDPLogOut(req, resp, moaSession.getSessionID()); +																 +						//remove active user-session +						removeUserSession(pendingReq, req, resp);  						return; @@ -132,31 +124,48 @@ public class ProtocolFinalizationController extends AbstractAuthProtocolModulCon  				if (moaSession == null) {  					Logger.error("No MOASession with ID " + sessionID + " found.!");		  					handleErrorNoRedirect(new MOAIDException("auth.02", new Object[]{sessionID}), req, resp, true);							 -					return; -				} -								 -				//check if MOASession and pending-request are authenticated -				if (moaSession.isAuthenticated() && pendingReq.isAuthenticated()) {				 -					finalizeAuthenticationProcess(req, resp, pendingReq, moaSession); -									  				} else { -					Logger.error("MOASession oder Pending-Request are not authenticated --> Abort authentication process!");		 -					handleErrorNoRedirect(new MOAIDException("auth.20", null), req, resp, true);							 -					return; -									 +					 +						//check if pending-request has 'abortedByUser' flag set +					if (pendingReq.isAbortedByUser()) { +						//send authentication aborted error to Service Provider +						buildProtocolSpecificErrorResponse( +								new AuthenticationException("auth.21", new Object[] {}),  +								req, resp, pendingReq); +						 +						//do not remove the full active SSO-Session  +						// in case of only one Service-Provider authentication request is aborted    +						if ( !(moaSession.isAuthenticated()  +								&& pendingReq.needSingleSignOnFunctionality()) ) { +							removeUserSession(pendingReq, req, resp); +							 +						}							 +	 +						//check if MOASession and pending-request are authenticated					 +					} else if (moaSession.isAuthenticated() && pendingReq.isAuthenticated()) {				 +						finalizeAuthenticationProcess(req, resp, pendingReq, moaSession); +	 +					} else { +						//suspect state: pending-request is not aborted but also are not authenticated  +						Logger.error("MOASession oder Pending-Request are not authenticated --> Abort authentication process!");		 +						handleErrorNoRedirect(new MOAIDException("auth.20", null), req, resp, true);							 +										 +					}  				}  			} catch (Exception e) {  				Logger.error("Finalize authentication protocol FAILED." , e);  				buildProtocolSpecificErrorResponse(e, req, resp, pendingReq); +				removeUserSession(pendingReq, req, resp); +				  			}		  		}  		//remove pending-request  		if (pendingReq != null) -		requestStorage.removePendingRequest(pendingReq.getRequestID()); +			requestStorage.removePendingRequest(pendingReq.getRequestID());  	} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/AuthenticationAction.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/AuthenticationAction.java index 21f505bf1..2882f20e1 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/AuthenticationAction.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/AuthenticationAction.java @@ -76,6 +76,7 @@ public class AuthenticationAction implements IAction {  		DateTime date = new DateTime();  		SLOInformationImpl sloInformation = new SLOInformationImpl(); +  		//build Assertion  		Assertion assertion = PVP2AssertionBuilder.buildAssertion(pvpRequest, authnRequest, authData,  @@ -106,6 +107,7 @@ public class AuthenticationAction implements IAction {  			//set protocol type  			sloInformation.setProtocolType(req.requestedModule()); +			sloInformation.setSpEntityID(req.getOnlineApplicationConfiguration().getPublicURLPrefix());  			return sloInformation;  		} catch (MessageEncodingException e) { diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/builder/SingleLogOutBuilder.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/builder/SingleLogOutBuilder.java index a7fc8295a..63452bee0 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/builder/SingleLogOutBuilder.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/pvp2x/builder/SingleLogOutBuilder.java @@ -439,7 +439,7 @@ public class SingleLogOutBuilder {  				if (!oa.getOaurlprefix().equals(removeOAID)) {  					//Actually only PVP 2.1 support Single LogOut -					if (PVP2XProtocol.PATH.equals(oa.getProtocolType())) {					 +					if (PVP2XProtocol.NAME.equals(oa.getProtocolType())) {					  						SingleLogoutService sloDesc;  						try {  							sloDesc = getRequestSLODescriptor(oa.getOaurlprefix()); @@ -447,7 +447,8 @@ public class SingleLogOutBuilder {  							if (sloDesc.getBinding().equals(SAMLConstants.SAML2_SOAP11_BINDING_URI))										  								container.getActiveBackChannelOAs().put(oa.getOaurlprefix(),   										new SLOInformationImpl( -											oa.getAuthURL(),	 +											oa.getAuthURL(), +											oa.getOaurlprefix(),  											oa.getAssertionSessionID(),   											oa.getUserNameID(),   											oa.getUserNameIDFormat(),  @@ -458,6 +459,7 @@ public class SingleLogOutBuilder {  								container.getActiveFrontChannalOAs().put(oa.getOaurlprefix(),   										new SLOInformationImpl(  											oa.getAuthURL(), +											oa.getOaurlprefix(),  											oa.getAssertionSessionID(),   											oa.getUserNameID(),   											oa.getUserNameIDFormat(),  @@ -498,10 +500,11 @@ public class SingleLogOutBuilder {  						container.getActiveFrontChannalOAs().put(el.getIdpurlprefix(),   								new SLOInformationImpl(  										el.getAuthURL(), +										el.getIdpurlprefix(),  										el.getSessionIndex(),   										el.getUserNameID(),   										NameID.TRANSIENT,  -										PVP2XProtocol.PATH, +										PVP2XProtocol.NAME,  										sloDesc));  					} catch (NOSLOServiceDescriptorException e) { diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/util/FormBuildUtils.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/util/FormBuildUtils.java index d3ac574f8..9a1237b80 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/util/FormBuildUtils.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/util/FormBuildUtils.java @@ -26,7 +26,6 @@ import java.util.HashMap;  import java.util.Map;  import java.util.Set; -import at.gv.egovernment.moa.id.config.auth.OAAuthParameter;  import at.gv.egovernment.moa.util.MiscUtil;  public class FormBuildUtils { @@ -123,6 +122,15 @@ public class FormBuildUtils {  	public static Map<String, String> getDefaultMap() {  		return defaultmap;  	} + +	/** +	 * @param value +	 * @return +	 */ +	public static String defaultLayoutBKUSelection(String value) { +		return customiceLayoutBKUSelection(value, false, false, getDefaultMap(), false); +		 +	}  } diff --git a/id/server/idserverlib/src/main/resources/resources/templates/css_template.css b/id/server/idserverlib/src/main/resources/resources/templates/css_template.css new file mode 100644 index 000000000..4a771fcac --- /dev/null +++ b/id/server/idserverlib/src/main/resources/resources/templates/css_template.css @@ -0,0 +1,623 @@ +@charset "utf-8"; +	@media screen and (min-width: 650px) { +			 +				body { +					margin:0; +					padding:0; +					color : #000; +					background-color : #fff; +			  	text-align: center; +			  	background-color: #6B7B8B; +				} +                 +                .browserInfoButton{ +         color: rgb(128, 128, 128);  +        } +				 +        #localBKU p { +          font-size: 0.7em; +        }  +         +        #localBKU input{ +          font-size: 0.85em; +          /*border-radius: 5px;*/ +        } +         +         #bkuselectionarea input[type=button] { +          font-size: 0.85em; +          /*border-radius: 7px;*/ +          margin-bottom: 25px; +          min-width: 80px; +         } +         +        #mandateLogin { +          font-size: 0.85em; +        } +         +        #bku_header h2 { +          font-size: 0.8em; +        }  +         +         +			  #page { +			    display: block; +			    border: 2px solid rgb(0,0,0); +			    width: 650px; +			    height: 460px; +			    margin: 0 auto; +			    margin-top: 5%; +			    position: relative; +			    border-radius: 25px; +			    background: rgb(255,255,255); +			  } +			   +			  #page1 { +			    text-align: center; +			  } +			   +			  #main { +			    /*	clear:both; */ +				  position:relative; +			    margin: 0 auto; +			    width: 250px; +			    text-align: center; +			  } +			   +			  .OA_header { +			/*	  background-color: white;*/ +			    font-size: 20pt; +			    margin-bottom: 25px; +			    margin-top: 25px; +			  } +			 +			  #leftcontent { +			    /*float:left; */ +				  width:250px; +				  margin-bottom: 25px; +			    text-align: left; +			    border: 1px solid rgb(0,0,0); +			  } +			  			   +			  #selectArea { +				 font-size: 15px; +				 padding-bottom: 65px; +			  } +			 +			  #leftcontent { +				 width: 300px; +				 margin-top: 30px; +			  } +			 +        #bku_header { +          height: 5%; +          padding-bottom: 3px; +          padding-top: 3px; +        } +       +        #bkulogin { +				  overflow:hidden;	 +          min-width: 190px; +          min-height: 180px; +          /*height: 260px;*/	 +			  } +       +        h2#tabheader{ +				  font-size: 1.1em;  +          padding-left: 2%; +          padding-right: 2%; +          position: relative; +			  } +      	 +        #stork h2 { +          font-size: 1.0em; +          margin-bottom: 2%; +        } +        		   +			  .setAssertionButton_full { +			  	background: #efefef; +				  cursor: pointer; +				  margin-top: 15px; +			    width: 100px; +			    height: 30px +			  } +			 +			  #leftbutton  { +				 width: 30%;  +				 float:left;  +				 margin-left: 40px; +			  } +			 +			  #rightbutton { +				 width: 30%;  +				 float:right;  +				 margin-right: 45px;  +				 text-align: right; +			  } +         +        button { +          height: 25px; +          width: 75px; +          margin-bottom: 10px; +        } +         +         +         +       #validation { +        position: absolute; +        bottom: 0px; +        margin-left: 270px; +        padding-bottom: 10px; +      } +			 +			} + +      @media screen and (max-width: 205px) { +        #localBKU p { +          font-size: 0.6em; +        } +       .browserInfoButton{ +         color: rgb(128, 128, 128);  +        } +         +        #localBKU input { +          font-size: 0.6em; +          min-width: 60px; +         /* max-width: 65px; */ +          min-height: 1.0em; +         /* border-radius: 5px; */ +        } +         +        #bkuselectionarea input[type=button] { +          font-size: 0.7em; +          min-width: 55px; +          /*min-height: 1.1em; +          border-radius: 5px;*/ +          margin-bottom: 2% +        } +         +        #mandateLogin { +          font-size: 0.65em; +        } +         +        #bku_header h2 { +          font-size: 0.8em; +          margin-top: -0.4em; +          padding-top: 0.4em; +        } +         +        #bkulogin { +        min-height: 150px; +        }  +      } + +      @media screen and (max-width: 249px) and (min-width: 206px) { +        #localBKU p { +          font-size: 0.7em; +        }  +        .browserInfoButton{ +         color: rgb(128, 128, 128);  +        } +         +        #localBKU input { +          font-size: 0.7em; +          min-width: 70px; +       /*    max-width: 75px;    */ +          min-height: 0.95em; +        /*  border-radius: 6px;    */ +        } +         +        #bkuselectionarea input[type=button] { +          font-size: 0.75em; +          min-width: 60px; +      /*    min-height: 0.95em; +          border-radius: 6px;    */ +          margin-bottom: 5% +        } +         +        #mandateLogin { +          font-size: 0.75em; +        } +         +        #bku_header h2 { +          font-size: 0.9em; +          margin-top: -0.45em; +          padding-top: 0.45em; +        } +         +        #bkulogin { +          min-height: 180px; +        }   +      } + +      @media screen and (max-width: 299px) and (min-width: 250px) { +        #localBKU p { +          font-size: 0.9em; +        }  +        .browserInfoButton{ +         color: rgb(128, 128, 128);  +        } +         +        #localBKU input { +          font-size: 0.8em; +          min-width: 70px; +       /*    max-width: 75px;      */ +      /*    border-radius: 6px;  */ +        } +         +        #bkuselectionarea input[type=button] { +          font-size: 0.85em; +     /*     min-height: 1.05em; +          border-radius: 7px;        */ +          margin-bottom: 10%; +        } +         +        #mandateLogin { +          font-size: 1em; +        } +         +        #bku_header h2 { +          font-size: 1.0em; +          margin-top: -0.50em; +          padding-top: 0.50em; +        }  +      } + +      @media screen and (max-width: 399px) and (min-width: 300px) { +        #localBKU p { +          font-size: 0.9em; +        }  +        .browserInfoButton{ +         color: rgb(128, 128, 128);  +        } +        #localBKU input { +          font-size: 0.8em; +          min-width: 70px; +      /*     max-width: 75px;     */ +      /*    border-radius: 6px;       */ +        } +         +        #bkuselectionarea input[type=button] { +          font-size: 0.9em; +   /*       min-height: 1.2em; +          border-radius: 8px;          */ +          margin-bottom: 10%; +          max-width: 80px; +        } +         +        #mandateLogin { +          font-size: 1em; +        } +         +        #bku_header h2 { +          font-size: 1.1em; +          margin-top: -0.55em; +          padding-top: 0.55em; +        }  +      } +       +      @media screen and (max-width: 649px) and (min-width: 400px) { +        #localBKU p { +          font-size: 0.9em; +        }  +       .browserInfoButton{ +         color: rgb(128, 128, 128);  +        }  +        #localBKU input { +          font-size: 0.8em; +          min-width: 70px; +      /*     max-width: 80px;       */ +     /*     border-radius: 6px;          */ +        } +         +        #bkuselectionarea input[type=button] { +          font-size: 1.0em; +     /*      min-height: 1.3em; +         border-radius: 10px;         */ +          margin-bottom: 10%; +          max-width: 85px; +        } +         +        #mandateLogin { +          font-size: 1.2em; +        } +         +        #bku_header h2 { +          font-size: 1.3em; +          margin-top: -0.65em; +          padding-top: 0.65em; +        }  +      } + + +			 +			@media screen and (max-width: 649px) { +				 +        body { +					margin:0; +					padding:0; +					color : #000; +			  	text-align: center; +          font-size: 100%; +			  	background-color: #MAIN_BACKGOUNDCOLOR#; +				} +        		.browserInfoButton{ +                    color: rgb(128, 128, 128);  +                }		 +			  #page { +			     visibility: hidden; +			     margin-top: 0%; +			  } +			   +			  #page1 { +			    visibility: hidden; +			  } +			   +			  #main { +			    visibility: hidden; +			  } +         +        #validation { +          visibility: hidden; +          display: none; +        } +			   +			  .OA_header { +			    margin-bottom: 0px; +			    margin-top: 0px; +			    font-size: 0pt; +			    visibility: hidden; +			  } +			 +			  #leftcontent { +			    visibility: visible; +			    margin-bottom: 0px; +			    text-align: left; +			    border:none; +          vertical-align: middle; +          min-height: 173px; +          min-width: 204px; +           +			  } +			   +        #bku_header { +          height: 10%; +          min-height: 1.2em; +          margin-top: 1%; +        } +         +        h2#tabheader{ +          padding-left: 2%; +          padding-right: 2%; +          position: relative; +          top: 50%; +			  } +         +        #stork h2 { +          font-size: 0.9em; +          margin-bottom: 2%; +        } +         +       	#bkulogin {	 +          min-width: 190px; +          min-height: 155px;	 +			 } +         +			 .setAssertionButton_full { +			     	background: #efefef; +				    cursor: pointer; +				    margin-top: 15px; +			      width: 70px; +			      height: 25px; +			 } +        +        input[type=button] { +/*          height: 11%;  */ +          width: 70%; +        } +			} +			       +			* { +				margin: 0; +				padding: 0; +        font-family: #FONTTYPE#; +			} +							      			 +			#selectArea { +				padding-top: 10px; +				padding-bottom: 55px; +				padding-left: 10px; +			} +			 +			.setAssertionButton { +				background: #efefef; +				cursor: pointer; +				margin-top: 15px; +			  width: 70px; +			  height: 25px; +			} +			 +			#leftbutton  { +				width: 35%;  +				float:left;  +				margin-left: 15px; +			} +			 +			#rightbutton { +				width: 35%;  +				float:right;  +				margin-right: 25px;  +				text-align: right; +			} +			 +			#stork { +			    /*margin-bottom: 10px;*/ +			   /* margin-top: 5px; */ +			} +      			 +      #mandateLogin { +        padding-bottom: 4%; +        padding-top: 4%; +        height: 10%; +        position: relative; +        text-align: center; +			} +       +      .verticalcenter { +        vertical-align: middle; +      } +       +      #mandateLogin div { +        clear: both; +        margin-top: -1%; +        position: relative; +        top: 50%; +      } +       +      #bkuselectionarea { +          position: relative; +          display: block; +      } +       +      #localBKU { +        padding-bottom: 4%; +        /*padding-top: 4%;*/ +        position: relative; +        clear: both;      +        text-align: center; +			} +          			 +			#bkukarte { +				float:left; +				text-align:center; +				width:40%; +        min-height: 70px; +        padding-left: 5%; +        padding-top: 2%; +			} +			 +			#bkuhandy { +				float:right; +				text-align:center; +				width:40%; +        min-height: 90px; +        padding-right: 5%; +        padding-top: 2%; +			} +			 +      .bkuimage { +        width: 90%; +        height: auto; +      } +       +			#mandate{ +				text-align:center; +				padding : 5px 5px 5px 5px; +			} +       +/*		input[type=button], .sendButton { +				background: #BUTTON_BACKGROUNDCOLOR#; +        color: #BUTTON_COLOR#; +/*				border:1px solid #000;  */ +/*				cursor: pointer; +/*        box-shadow: 3px 3px 3px #222222;  */ +/*			} +			 +/*      button:hover, button:focus, button:active,  +      .sendButton:hover , .sendButton:focus, .sendButton:active, +      #mandateCheckBox:hover, #mandateCheckBox:focus, #mandateCheckBox:active { +				background: #BUTTON_BACKGROUNDCOLOR_FOCUS#; +        color: #BUTTON_COLOR#; +/*				border:1px solid #000;                */ +/*				cursor: pointer; +/*        box-shadow: -1px -1px 3px #222222;  */ +/*			} +       +*/       +			input { +				/*border:1px solid #000;*/ +				cursor: pointer; +			} +       +      #localBKU input { +/*        color: #BUTTON_COLOR#;  */ +        /*border: 0px;*/ +        display: inline-block; +         +      } +			 +      #localBKU input:hover, #localBKU input:focus, #localBKU input:active { +        /*text-decoration: underline;*/ +      } +       +			#installJava, #BrowserNOK { +				clear:both; +				font-size:0.8em; +				padding:4px; +			} +						 +			.selectText{ +			 +			} +			 +			.selectTextHeader{ +			 +			} +			 +			.sendButton { +        width: 30%; +        margin-bottom: 1%;	 +			} +			 +			#leftcontent a { +				text-decoration:none;  +				color: #000; +			/*	display:block;*/ +				padding:4px;	 +			} +			 +			#leftcontent a:hover, #leftcontent a:focus, #leftcontent a:active { +				text-decoration:underline; +				color: #000;	 +			} +						 +			.infobutton { +				background-color: #005a00; +				color: white; +				font-family: serif; +				text-decoration: none; +				padding-top: 2px; +				padding-right: 4px; +				padding-bottom: 2px; +				padding-left: 4px; +				font-weight: bold; +			} +			 +			.hell { +				background-color : #MAIN_BACKGOUNDCOLOR#; +        color: #MAIN_COLOR#;	 +			} +			 +			.dunkel { +				background-color: #HEADER_BACKGROUNDCOLOR#; +        color: #HEADER_COLOR#; +			} +			       +			.main_header { +			   color: black; +			    font-size: 32pt; +			    position: absolute; +			    right: 10%; +			    top: 40px; +				 +			} +       +      #ssoSessionTransferBlock { +        font-size: 0.8em; +        margin-left: 5px; +        margin-bottom: 5px; +      } +       +      #alert_area { +        width: 500px; +        padding-left: 80px; +      }
\ No newline at end of file diff --git a/id/server/idserverlib/src/main/resources/resources/templates/error_message.html b/id/server/idserverlib/src/main/resources/resources/templates/error_message.html index 8e6751656..6cc8b99e2 100644 --- a/id/server/idserverlib/src/main/resources/resources/templates/error_message.html +++ b/id/server/idserverlib/src/main/resources/resources/templates/error_message.html @@ -1,380 +1,8 @@  <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">  <head>    <meta content="text/html; charset=utf-8" http-equiv="Content-Type"> +  <link rel="stylesheet" href="#CONTEXTPATH#/css/buildCSS" /> -   <!-- MOA-ID 2.x BKUSelection Layout CSS -->                -    <style type="text/css"> -			@media screen and (min-width: 650px) { -			 -				body { -					margin:0; -					padding:0; -					color : #000; -					background-color : #fff; -			  	text-align: center; -			  	background-color: #6B7B8B; -				} -   -			  #page { -			    display: block; -			    border: 2px solid rgb(0,0,0); -			    width: 650px; -			    height: 460px; -			    margin: 0 auto; -			    margin-top: 5%; -			    position: relative; -			    border-radius: 25px; -			    background: rgb(255,255,255); -			  } -			   -			  #page1 { -			    text-align: center; -			  } -			   -			  #main { -			    /*	clear:both; */ -				  position:relative; -			    margin: 0 auto; -			    width: 250px; -			    text-align: center; -			  } -			   -			  .OA_header { -			/*	  background-color: white;*/ -			    font-size: 20pt; -			    margin-bottom: 25px; -			    margin-top: 25px; -			  } -			 -			  #leftcontent { -			    /*float:left; */ -				  width:250px; -				  margin-bottom: 25px; -			    text-align: left; -			    /*border: 1px solid rgb(0,0,0);*/ -			  } -			 -			  #leftcontent { -				 width: 300px; -				 margin-top: 30px; -			  } -       -        h2#tabheader{ -				  font-size: 1.1em;  -          padding-left: 2%; -          padding-right: 2%; -          position: relative; -			  } -        		   -			  .setAssertionButton_full { -			  	background: #efefef; -				  cursor: pointer; -				  margin-top: 15px; -			    width: 100px; -			    height: 30px -			  } -			 -			  #leftbutton  { -				 width: 30%;  -				 float:left;  -				 margin-left: 40px; -			  } -			 -			  #rightbutton { -				 width: 30%;  -				 float:right;  -				 margin-right: 45px;  -				 text-align: right; -			  } -         -        button { -          height: 25px; -          width: 75px; -          margin-bottom: 10px; -        } -         -       #validation { -        position: absolute; -        bottom: 0px; -        margin-left: 270px; -        padding-bottom: 10px; -      } -			 -			} - -      @media screen and (max-width: 205px) { -        #localBKU p { -          font-size: 0.6em; -        }  -         -        #localBKU input { -          font-size: 0.6em; -          min-width: 60px; -         /* max-width: 65px; */ -          min-height: 1.0em; -         /* border-radius: 5px; */ -        } -         -      } - -      @media screen and (max-width: 249px) and (min-width: 206px) { -        #localBKU p { -          font-size: 0.7em; -        }  -         -        #localBKU input { -          font-size: 0.7em; -          min-width: 70px; -       /*    max-width: 75px;    */ -          min-height: 0.95em; -        /*  border-radius: 6px;    */ -        } -          -      } - -      @media screen and (max-width: 299px) and (min-width: 250px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -       /*    max-width: 75px;      */ -      /*    border-radius: 6px;  */ -        } - -      } - -      @media screen and (max-width: 399px) and (min-width: 300px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 75px;     */ -      /*    border-radius: 6px;       */ -        } - -      } -       -      @media screen and (max-width: 649px) and (min-width: 400px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 80px;       */ -     /*     border-radius: 6px;          */ -        } - -      } - - -			 -			@media screen and (max-width: 649px) { -				 -        body { -					margin:0; -					padding:0; -					color : #000; -			  	text-align: center; -          font-size: 100%; -			  	background-color: #MAIN_BACKGOUNDCOLOR#; -				} -        				 -			  #page { -			     visibility: hidden; -			     margin-top: 0%; -			  } -			   -			  #page1 { -			    visibility: hidden; -			  } -			   -			  #main { -			    visibility: hidden; -			  } -         -        #validation { -          visibility: hidden; -          display: none; -        } -			   -			  .OA_header { -			    margin-bottom: 0px; -			    margin-top: 0px; -			    font-size: 0pt; -			    visibility: hidden; -			  } -			 -			  #leftcontent { -			    visibility: visible; -			    margin-bottom: 0px; -			    text-align: left; -			    border:none; -          vertical-align: middle; -          min-height: 173px; -          min-width: 204px; -           -			  } -         -        input[type=button] { -/*          height: 11%;  */ -          width: 70%; -        } -			} -			       -			* { -				margin: 0; -				padding: 0; -        font-family: #FONTTYPE#; -			} -							      			 -			#selectArea { -				padding-top: 10px; -				padding-bottom: 55px; -				padding-left: 10px; -			} -			 -			.setAssertionButton { -				background: #efefef; -				cursor: pointer; -				margin-top: 15px; -			  width: 70px; -			  height: 25px; -			} -			 -			#leftbutton  { -				width: 35%;  -				float:left;  -				margin-left: 15px; -			} -			 -			#rightbutton { -				width: 35%;  -				float:right;  -				margin-right: 25px;  -				text-align: right; -			} - -/*		input[type=button], .sendButton { -				background: #BUTTON_BACKGROUNDCOLOR#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;  */ -/*				cursor: pointer; -/*        box-shadow: 3px 3px 3px #222222;  */ -/*			} -			 -/*      button:hover, button:focus, button:active,  -      .sendButton:hover , .sendButton:focus, .sendButton:active, -      #mandateCheckBox:hover, #mandateCheckBox:focus, #mandateCheckBox:active { -				background: #BUTTON_BACKGROUNDCOLOR_FOCUS#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;                */ -/*				cursor: pointer; -/*        box-shadow: -1px -1px 3px #222222;  */ -/*			} -       -*/       -			input { -				/*border:1px solid #000;*/ -				cursor: pointer; -			} -       -      #localBKU input { -/*        color: #BUTTON_COLOR#;  */ -        border: 0px; -        display: inline-block; -         -      } -			 -      #localBKU input:hover, #localBKU input:focus, #localBKU input:active { -        text-decoration: underline; -      } -       -			#installJava, #BrowserNOK { -				clear:both; -				font-size:0.8em; -				padding:4px; -			} -						 -			.selectText{ -			 -			} -			 -			.selectTextHeader{ -			 -			} -			 -			.sendButton { -        width: 30%; -        margin-bottom: 1%;	 -			} -			 -			#leftcontent a { -				text-decoration:none;  -				color: #000; -			/*	display:block;*/ -				padding:4px;	 -			} -			 -			#leftcontent a:hover, #leftcontent a:focus, #leftcontent a:active { -				text-decoration:underline; -				color: #000;	 -			} -						 -			.infobutton { -				background-color: #005a00; -				color: white; -				font-family: serif; -				text-decoration: none; -				padding-top: 2px; -				padding-right: 4px; -				padding-bottom: 2px; -				padding-left: 4px; -				font-weight: bold; -			} -			 -			.hell { -				background-color : #MAIN_BACKGOUNDCOLOR#; -        color: #MAIN_COLOR#;	 -			} -			 -			.dunkel { -				background-color: #HEADER_BACKGROUNDCOLOR#; -        color: #HEADER_COLOR#; -			} -			       -			.main_header { -			   color: black; -			    font-size: 32pt; -			    position: absolute; -			    right: 10%; -			    top: 40px; -				 -			} -       -     	#alert { -		    margin: 100px 250px; -		    font-family: Verdana, Arial, Helvetica, sans-serif; -		    font-size: 14px; -		    font-weight: normal; -		    color: red; -	    } -	 -	    .reqframe { -		    /*display: none;*/ -        visibility: hidden; -		   -	    } -      			                         -    </style>  -    <title>An error arise ...  </title>  </head> @@ -382,12 +10,14 @@    <div id="page">  		<div id="page1" class="case selected-case" role="main">  			<h2 class="OA_header" role="heading">Authentication error arise</h2> -			<div id="main"> -				<div id="leftcontent" class="hell" role="application"> +			<!--div id="main"--> +				<!--div id="leftcontent" class="hell" role="application"--> +           -          <p>The authentication stops on account of a process error:</p> -	        <div class="alert"> +	        <div id="alert_area" class="hell" role="application" > +            <p>The authentication stops on account of a process error:</p> +            <br/>  		        <p><b>Error    Code:</b> $errorCode</p>   		        <p><b>Error Message:</b >$errorMsg</p>  	        </div>	 @@ -399,8 +29,8 @@  	         </div>	  	        #end -				</div> -			</div> +				<!--/div---> +			<!--/div-->  		</div>  	</div>  </body> diff --git a/id/server/idserverlib/src/main/resources/resources/templates/javascript_tempalte.js b/id/server/idserverlib/src/main/resources/resources/templates/javascript_tempalte.js new file mode 100644 index 000000000..ae621f0cb --- /dev/null +++ b/id/server/idserverlib/src/main/resources/resources/templates/javascript_tempalte.js @@ -0,0 +1,196 @@ +function isIE() { +			return (/MSIE (\d+\.\d+);/.test(navigator.userAgent)); +		} +		function isFullscreen() { +			try { +				return ((top.innerWidth == screen.width) && (top.innerHeight == screen.height)); +			} catch (e) { +				return false; +			} +		} +		function isActivexEnabled() { +			var supported = null; +			try { +				supported = !!new ActiveXObject("htmlfile"); +			} catch (e) { +				supported = false; +			} +			return supported; +		} +		function isMetro() { +			if (!isIE()) +				return false; +			return !isActivexEnabled() && isFullscreen(); +		} +		window.onload=function() { +			document.getElementById("localBKU").style.display="block"; +			return; +		} +    function bkuLocalClicked() { +       setMandateSelection(); +    } +     +		function bkuOnlineClicked() { +			if (isMetro()) +				document.getElementById("metroDetected").style.display="block"; +			document.getElementById("localBKU").style.display="block"; +/* 			if (checkMandateSSO()) +				return; */ +			 +			setMandateSelection(); +/* 			setSSOSelection(); */ +						 +			var iFrameURL = "#AUTH_URL#" + "?"; +			iFrameURL += "bkuURI=" + "#ONLINE#"; +			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; +/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ +			iFrameURL += "&pendingid=" + "#SESSIONID#"; +			generateIFrame(iFrameURL); +		} +		function bkuHandyClicked() { +			document.getElementById("localBKU").style.display="none"; +/* 			if (checkMandateSSO()) +				return; */ +			 +			setMandateSelection(); +/* 			setSSOSelection(); */ +			 +			var iFrameURL = "#AUTH_URL#" + "?"; +			iFrameURL += "bkuURI=" + "#HANDY#"; +			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; +/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ +			iFrameURL += "&pendingid=" + "#SESSIONID#"; +			generateIFrame(iFrameURL); +		} +		function storkClicked() { +			document.getElementById("localBKU").style.display="none";  +/* 			if (checkMandateSSO()) +				return; */ +			 +			setMandateSelection(); +/* 			setSSOSelection(); */ +			 +			var ccc = "AT"; +			var countrySelection = document.getElementById("cccSelection"); +			if (countrySelection !=  null) { +				ccc = document.getElementById("cccSelection").value; +			} +			var iFrameURL = "#AUTH_URL#" + "?"; +			iFrameURL += "bkuURI=" + "#ONLINE#"; +			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; +			iFrameURL += "&CCC=" + ccc; +/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ +			iFrameURL += "&MODUL=" + "#MODUL#"; +			iFrameURL += "&ACTION=" + "#ACTION#"; +			iFrameURL += "&pendingid=" + "#SESSIONID#"; +			generateIFrame(iFrameURL); +		} +		function generateIFrame(iFrameURL) { +			var el = document.getElementById("bkulogin"); +      var width = el.clientWidth; +      var heigth = el.clientHeight - 20; +			var parent = el.parentNode; +             +      iFrameURL += "&heigth=" + heigth; +      iFrameURL += "&width=" + width; +       +			var iframe = document.createElement("iframe"); +			iframe.setAttribute("src", iFrameURL); +			iframe.setAttribute("width", el.clientWidth - 1); +			iframe.setAttribute("height", el.clientHeight - 1); +			iframe.setAttribute("frameborder", "0"); +			iframe.setAttribute("scrolling", "no"); +			iframe.setAttribute("title", "Login"); +			parent.replaceChild(iframe, el); +		} +		function setMandateSelection() { +			document.getElementById("useMandate").value = "false"; +			var checkbox = document.getElementById("mandateCheckBox"); +			if (checkbox !=  null) { +				if (document.getElementById("mandateCheckBox").checked) { +					document.getElementById("useMandate").value = "true"; +				} +			} +		} +		function onChangeChecks() { +      if (self.innerWidth < 650) { +         document.getElementById("moaidform").setAttribute("target","_parent"); +      } else { +         document.getElementById("moaidform").removeAttribute("target"); +      } +       +    } +     +     function checkIfBrowserSupportsJava(){ +        console.log("Browser is Chrome: "+checkIfBrowserIsChrome()); +        console.log("Browser is Safari: "+checkIfBrowserIsSafari()); +        console.log("Browser is Edge: "+checkIfBrowserIsEdge()); +         +        var cnt = 0; +         +        if(checkIfBrowserIsChrome())cnt++; +        if(checkIfBrowserIsEdge())cnt++; +        if(checkIfBrowserIsSafari())cnt++; +            +        if(cnt==0 || cnt>1)//cnt>1 means perhaps wrong detection +            return true; +         +        var image = document.getElementById("bkuimage"); +        var srcatt = image.getAttribute("src"); +        var last = srcatt.substring(srcatt.lastIndexOf('/')+1); +        srcatt = srcatt.replace(last,'online-bku-deactivated.png');     +        image.setAttribute("src",srcatt); +          +          +        var button = document.getElementsByName("bkuButtonOnline")[0];                +        button.setAttribute("class","browserInfoButton"); +        button.setAttribute("title","Java wird nicht unterstützt, klicken für mehr Informationen."); +        button.setAttribute("onClick","alert('Java wird von Ihrem Browser nicht unterstützt, ist jedoch für den Betrieb der Online Bürgerkartenumgebung notwendig.\\nWollen Sie dennoch die Online Bürgerkartenumgebung verwenden, wird zur Zeit Java noch von Firefox und MS Internet Explorer unterstützt. \\nAlternativ koennen Sie auch eine lokale Bürgerkartenumgebung verwenden, verfügbar unter www.buergerkarte.at.');"); +          +        return false; +    +    } +    function checkIfBrowserIsChrome(){ +        var chrome_defined = !!window.chrome;//chrome object defined +        var webstore_defined = false; +        if(window.chrome){ +            webstore_defined = !!window.chrome.webstore; +           } +        return chrome_defined && webstore_defined; +    } +    function checkIfBrowserIsEdge(){//edge also defines the chrome object, but not the webapp +        var chrome_defined = !!window.chrome;//chrome object defined +        var webstore_defined = true; +        if(window.chrome){ +            webstore_defined = !!window.chrome.webstore; +           } +        return chrome_defined && !webstore_defined; +    } +    function checkIfBrowserIsSafari(){ +        var cond1 = Object.prototype.toString.call(window.HTMLElement).indexOf('Constructor') > 0; +        return cond1; +    } +/* 		function setSSOSelection() { +			document.getElementById("useSSO").value = "false"; +			var checkbox = document.getElementById("SSOCheckBox"); +			if (checkbox !=  null) { +				if (document.getElementById("SSOCheckBox").checked) { +					document.getElementById("useSSO").value = "true"; +				} +			} +		} */ +		 +/* 		function checkMandateSSO() { +			var sso = document.getElementById("SSOCheckBox"); +			var mandate = document.getElementById("mandateCheckBox"); +			 +			 +			if (sso.checked && mandate.checked) { +				alert("Anmeldung in Vertretung in kombination mit Single Sign-On wird aktuell noch nicht unterstützt!") +				mandate.checked = false; +				sso.checked = false; +				return true; +			} else { +				return false; +			} +		} */
\ No newline at end of file diff --git a/id/server/idserverlib/src/main/resources/resources/templates/loginFormFull.html b/id/server/idserverlib/src/main/resources/resources/templates/loginFormFull.html index af133525e..53d04c282 100644 --- a/id/server/idserverlib/src/main/resources/resources/templates/loginFormFull.html +++ b/id/server/idserverlib/src/main/resources/resources/templates/loginFormFull.html @@ -4,830 +4,12 @@  <meta content="text/html; charset=utf-8" http-equiv="Content-Type">     <!-- MOA-ID 2.x BKUSelection Layout CSS -->                -    <style type="text/css"> -			@media screen and (min-width: 650px) { -			 -				body { -					margin:0; -					padding:0; -					color : #000; -					background-color : #fff; -			  	text-align: center; -			  	background-color: #6B7B8B; -				} -                 -                .browserInfoButton{ -         color: rgb(128, 128, 128);  -        } -				 -        #localBKU p { -          font-size: 0.7em; -        }  -         -        #localBKU input{ -          font-size: 0.85em; -          /*border-radius: 5px;*/ -        } -         -         #bkuselectionarea input[type=button] { -          font-size: 0.85em; -          /*border-radius: 7px;*/ -          margin-bottom: 25px; -          min-width: 80px; -         } -         -        #mandateLogin { -          font-size: 0.85em; -        } -         -        #bku_header h2 { -          font-size: 0.8em; -        }  -         -         -			  #page { -			    display: block; -			    border: 2px solid rgb(0,0,0); -			    width: 650px; -			    height: 460px; -			    margin: 0 auto; -			    margin-top: 5%; -			    position: relative; -			    border-radius: 25px; -			    background: rgb(255,255,255); -			  } -			   -			  #page1 { -			    text-align: center; -			  } -			   -			  #main { -			    /*	clear:both; */ -				  position:relative; -			    margin: 0 auto; -			    width: 250px; -			    text-align: center; -			  } -			   -			  .OA_header { -			/*	  background-color: white;*/ -			    font-size: 20pt; -			    margin-bottom: 25px; -			    margin-top: 25px; -			  } -			 -			  #leftcontent { -			    /*float:left; */ -				  width:250px; -				  margin-bottom: 25px; -			    text-align: left; -			    border: 1px solid rgb(0,0,0); -			  } -			  			   -			  #selectArea { -				 font-size: 15px; -				 padding-bottom: 65px; -			  } -			 -			  #leftcontent { -				 width: 300px; -				 margin-top: 30px; -			  } -			 -        #bku_header { -          height: 5%; -          padding-bottom: 3px; -          padding-top: 3px; -        } -       -        #bkulogin { -				  overflow:hidden;	 -          min-width: 190px; -          min-height: 180px; -          /*height: 260px;*/	 -			  } -       -        h2#tabheader{ -				  font-size: 1.1em;  -          padding-left: 2%; -          padding-right: 2%; -          position: relative; -			  } -      	 -        #stork h2 { -          font-size: 1.0em; -          margin-bottom: 2%; -        } -        		   -			  .setAssertionButton_full { -			  	background: #efefef; -				  cursor: pointer; -				  margin-top: 15px; -			    width: 100px; -			    height: 30px -			  } -			 -			  #leftbutton  { -				 width: 30%;  -				 float:left;  -				 margin-left: 40px; -			  } -			 -			  #rightbutton { -				 width: 30%;  -				 float:right;  -				 margin-right: 45px;  -				 text-align: right; -			  } -         -        button { -          height: 25px; -          width: 75px; -          margin-bottom: 10px; -        } -         -         -         -       #validation { -        position: absolute; -        bottom: 0px; -        margin-left: 270px; -        padding-bottom: 10px; -      } -			 -			} - -      @media screen and (max-width: 205px) { -        #localBKU p { -          font-size: 0.6em; -        } -       .browserInfoButton{ -         color: rgb(128, 128, 128);  -        } -         -        #localBKU input { -          font-size: 0.6em; -          min-width: 60px; -         /* max-width: 65px; */ -          min-height: 1.0em; -         /* border-radius: 5px; */ -        } -         -        #bkuselectionarea input[type=button] { -          font-size: 0.7em; -          min-width: 55px; -          /*min-height: 1.1em; -          border-radius: 5px;*/ -          margin-bottom: 2% -        } -         -        #mandateLogin { -          font-size: 0.65em; -        } -         -        #bku_header h2 { -          font-size: 0.8em; -          margin-top: -0.4em; -          padding-top: 0.4em; -        } -         -        #bkulogin { -        min-height: 150px; -        }  -      } - -      @media screen and (max-width: 249px) and (min-width: 206px) { -        #localBKU p { -          font-size: 0.7em; -        }  -        .browserInfoButton{ -         color: rgb(128, 128, 128);  -        } -         -        #localBKU input { -          font-size: 0.7em; -          min-width: 70px; -       /*    max-width: 75px;    */ -          min-height: 0.95em; -        /*  border-radius: 6px;    */ -        } -         -        #bkuselectionarea input[type=button] { -          font-size: 0.75em; -          min-width: 60px; -      /*    min-height: 0.95em; -          border-radius: 6px;    */ -          margin-bottom: 5% -        } -         -        #mandateLogin { -          font-size: 0.75em; -        } -         -        #bku_header h2 { -          font-size: 0.9em; -          margin-top: -0.45em; -          padding-top: 0.45em; -        } -         -        #bkulogin { -          min-height: 180px; -        }   -      } - -      @media screen and (max-width: 299px) and (min-width: 250px) { -        #localBKU p { -          font-size: 0.9em; -        }  -        .browserInfoButton{ -         color: rgb(128, 128, 128);  -        } -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -       /*    max-width: 75px;      */ -      /*    border-radius: 6px;  */ -        } -         -        #bkuselectionarea input[type=button] { -          font-size: 0.85em; -     /*     min-height: 1.05em; -          border-radius: 7px;        */ -          margin-bottom: 10%; -        } -         -        #mandateLogin { -          font-size: 1em; -        } -         -        #bku_header h2 { -          font-size: 1.0em; -          margin-top: -0.50em; -          padding-top: 0.50em; -        }  -      } - -      @media screen and (max-width: 399px) and (min-width: 300px) { -        #localBKU p { -          font-size: 0.9em; -        }  -        .browserInfoButton{ -         color: rgb(128, 128, 128);  -        } -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 75px;     */ -      /*    border-radius: 6px;       */ -        } -         -        #bkuselectionarea input[type=button] { -          font-size: 0.9em; -   /*       min-height: 1.2em; -          border-radius: 8px;          */ -          margin-bottom: 10%; -          max-width: 80px; -        } -         -        #mandateLogin { -          font-size: 1em; -        } -         -        #bku_header h2 { -          font-size: 1.1em; -          margin-top: -0.55em; -          padding-top: 0.55em; -        }  -      } -       -      @media screen and (max-width: 649px) and (min-width: 400px) { -        #localBKU p { -          font-size: 0.9em; -        }  -       .browserInfoButton{ -         color: rgb(128, 128, 128);  -        }  -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 80px;       */ -     /*     border-radius: 6px;          */ -        } -         -        #bkuselectionarea input[type=button] { -          font-size: 1.0em; -     /*      min-height: 1.3em; -         border-radius: 10px;         */ -          margin-bottom: 10%; -          max-width: 85px; -        } -         -        #mandateLogin { -          font-size: 1.2em; -        } -         -        #bku_header h2 { -          font-size: 1.3em; -          margin-top: -0.65em; -          padding-top: 0.65em; -        }  -      } - - -			 -			@media screen and (max-width: 649px) { -				 -        body { -					margin:0; -					padding:0; -					color : #000; -			  	text-align: center; -          font-size: 100%; -			  	background-color: #MAIN_BACKGOUNDCOLOR#; -				} -        		.browserInfoButton{ -                    color: rgb(128, 128, 128);  -                }		 -			  #page { -			     visibility: hidden; -			     margin-top: 0%; -			  } -			   -			  #page1 { -			    visibility: hidden; -			  } -			   -			  #main { -			    visibility: hidden; -			  } -         -        #validation { -          visibility: hidden; -          display: none; -        } -			   -			  .OA_header { -			    margin-bottom: 0px; -			    margin-top: 0px; -			    font-size: 0pt; -			    visibility: hidden; -			  } -			 -			  #leftcontent { -			    visibility: visible; -			    margin-bottom: 0px; -			    text-align: left; -			    border:none; -          vertical-align: middle; -          min-height: 173px; -          min-width: 204px; -           -			  } -			   -        #bku_header { -          height: 10%; -          min-height: 1.2em; -          margin-top: 1%; -        } -         -        h2#tabheader{ -          padding-left: 2%; -          padding-right: 2%; -          position: relative; -          top: 50%; -			  } -         -        #stork h2 { -          font-size: 0.9em; -          margin-bottom: 2%; -        } -         -       	#bkulogin {	 -          min-width: 190px; -          min-height: 170px;	 -			 } -         -			 .setAssertionButton_full { -			     	background: #efefef; -				    cursor: pointer; -				    margin-top: 15px; -			      width: 70px; -			      height: 25px; -			 } -        -        input[type=button] { -/*          height: 11%;  */ -          width: 70%; -        } -			} -			       -			* { -				margin: 0; -				padding: 0; -        font-family: #FONTTYPE#; -			} -							      			 -			#selectArea { -				padding-top: 10px; -				padding-bottom: 55px; -				padding-left: 10px; -			} -			 -			.setAssertionButton { -				background: #efefef; -				cursor: pointer; -				margin-top: 15px; -			  width: 70px; -			  height: 25px; -			} -			 -			#leftbutton  { -				width: 35%;  -				float:left;  -				margin-left: 15px; -			} -			 -			#rightbutton { -				width: 35%;  -				float:right;  -				margin-right: 25px;  -				text-align: right; -			} -			 -			#stork { -			    /*margin-bottom: 10px;*/ -			   /* margin-top: 5px; */ -			} -      			 -      #mandateLogin { -        padding-bottom: 4%; -        padding-top: 4%; -        height: 10%; -        position: relative; -        text-align: center; -			} -       -      .verticalcenter { -        vertical-align: middle; -      } -       -      #mandateLogin div { -        clear: both; -        margin-top: -1%; -        position: relative; -        top: 50%; -      } -       -      #bkuselectionarea { -          position: relative; -          display: block; -      } -       -      #localBKU { -        padding-bottom: 4%; -        /*padding-top: 4%;*/ -        position: relative; -        clear: both;      -        text-align: center; -			} -          			 -			#bkukarte { -				float:left; -				text-align:center; -				width:40%; -        min-height: 70px; -        padding-left: 5%; -        padding-top: 2%; -			} -			 -			#bkuhandy { -				float:right; -				text-align:center; -				width:40%; -        min-height: 90px; -        padding-right: 5%; -        padding-top: 2%; -			} -			 -      .bkuimage { -        width: 90%; -        height: auto; -      } -       -			#mandate{ -				text-align:center; -				padding : 5px 5px 5px 5px; -			} -       -/*		input[type=button], .sendButton { -				background: #BUTTON_BACKGROUNDCOLOR#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;  */ -/*				cursor: pointer; -/*        box-shadow: 3px 3px 3px #222222;  */ -/*			} -			 -/*      button:hover, button:focus, button:active,  -      .sendButton:hover , .sendButton:focus, .sendButton:active, -      #mandateCheckBox:hover, #mandateCheckBox:focus, #mandateCheckBox:active { -				background: #BUTTON_BACKGROUNDCOLOR_FOCUS#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;                */ -/*				cursor: pointer; -/*        box-shadow: -1px -1px 3px #222222;  */ -/*			} -       -*/       -			input { -				/*border:1px solid #000;*/ -				cursor: pointer; -			} -       -      #localBKU input { -/*        color: #BUTTON_COLOR#;  */ -        /*border: 0px;*/ -        display: inline-block; -         -      } -			 -      #localBKU input:hover, #localBKU input:focus, #localBKU input:active { -        /*text-decoration: underline;*/ -      } -       -			#installJava, #BrowserNOK { -				clear:both; -				font-size:0.8em; -				padding:4px; -			} -						 -			.selectText{ -			 -			} -			 -			.selectTextHeader{ -			 -			} -			 -			.sendButton { -        width: 30%; -        margin-bottom: 1%;	 -			} -			 -			#leftcontent a { -				text-decoration:none;  -				color: #000; -			/*	display:block;*/ -				padding:4px;	 -			} -			 -			#leftcontent a:hover, #leftcontent a:focus, #leftcontent a:active { -				text-decoration:underline; -				color: #000;	 -			} -						 -			.infobutton { -				background-color: #005a00; -				color: white; -				font-family: serif; -				text-decoration: none; -				padding-top: 2px; -				padding-right: 4px; -				padding-bottom: 2px; -				padding-left: 4px; -				font-weight: bold; -			} -			 -			.hell { -				background-color : #MAIN_BACKGOUNDCOLOR#; -        color: #MAIN_COLOR#;	 -			} -			 -			.dunkel { -				background-color: #HEADER_BACKGROUNDCOLOR#; -        color: #HEADER_COLOR#; -			} -			       -			.main_header { -			   color: black; -			    font-size: 32pt; -			    position: absolute; -			    right: 10%; -			    top: 40px; -				 -			} -       -      #ssoSessionTransferBlock { -        font-size: 0.8em; -        margin-left: 5px; -        margin-bottom: 5px; -      } -      			                         -    </style>        -<!-- MOA-ID 2.x BKUSelection JavaScript fucnctions--> -<script type="text/javascript"> -		function isIE() { -			return (/MSIE (\d+\.\d+);/.test(navigator.userAgent)); -		} -		function isFullscreen() { -			try { -				return ((top.innerWidth == screen.width) && (top.innerHeight == screen.height)); -			} catch (e) { -				return false; -			} -		} -		function isActivexEnabled() { -			var supported = null; -			try { -				supported = !!new ActiveXObject("htmlfile"); -			} catch (e) { -				supported = false; -			} -			return supported; -		} -		function isMetro() { -			if (!isIE()) -				return false; -			return !isActivexEnabled() && isFullscreen(); -		} -		window.onload=function() { -			document.getElementById("localBKU").style.display="block"; -			return; -		} -    function bkuLocalClicked() { -       setMandateSelection(); -    } -     -		function bkuOnlineClicked() { -			if (isMetro()) -				document.getElementById("metroDetected").style.display="block"; -			document.getElementById("localBKU").style.display="block"; -/* 			if (checkMandateSSO()) -				return; */ -			 -			setMandateSelection(); -/* 			setSSOSelection(); */ -						 -			var iFrameURL = "#AUTH_URL#" + "?"; -			iFrameURL += "bkuURI=" + "#ONLINE#"; -			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; -/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ -			iFrameURL += "&MODUL=" + "#MODUL#"; -			iFrameURL += "&ACTION=" + "#ACTION#"; -			iFrameURL += "&pendingid=" + "#SESSIONID#"; -			generateIFrame(iFrameURL); -		} -		function bkuHandyClicked() { -			document.getElementById("localBKU").style.display="none"; -/* 			if (checkMandateSSO()) -				return; */ -			 -			setMandateSelection(); -/* 			setSSOSelection(); */ -			 -			var iFrameURL = "#AUTH_URL#" + "?"; -			iFrameURL += "bkuURI=" + "#HANDY#"; -			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; -/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ -			iFrameURL += "&MODUL=" + "#MODUL#"; -			iFrameURL += "&ACTION=" + "#ACTION#"; -			iFrameURL += "&pendingid=" + "#SESSIONID#"; -			generateIFrame(iFrameURL); -		} -		function storkClicked() { -			document.getElementById("localBKU").style.display="none";  -/* 			if (checkMandateSSO()) -				return; */ -			 -			setMandateSelection(); -/* 			setSSOSelection(); */ -			 -			var ccc = "AT"; -			var countrySelection = document.getElementById("cccSelection"); -			if (countrySelection !=  null) { -				ccc = document.getElementById("cccSelection").value; -			} -			var iFrameURL = "#AUTH_URL#" + "?"; -			iFrameURL += "bkuURI=" + "#ONLINE#"; -			iFrameURL += "&useMandate=" + document.getElementById("useMandate").value; -			iFrameURL += "&CCC=" + ccc; -/* 			iFrameURL += "&SSO=" + document.getElementById("useSSO").value; */ -			iFrameURL += "&MODUL=" + "#MODUL#"; -			iFrameURL += "&ACTION=" + "#ACTION#"; -			iFrameURL += "&pendingid=" + "#SESSIONID#"; -			generateIFrame(iFrameURL); -		} -		function generateIFrame(iFrameURL) { -			var el = document.getElementById("bkulogin"); -      var width = el.clientWidth; -      var heigth = el.clientHeight - 20; -			var parent = el.parentNode; -             -      iFrameURL += "&heigth=" + heigth; -      iFrameURL += "&width=" + width; -       -			var iframe = document.createElement("iframe"); -			iframe.setAttribute("src", iFrameURL); -			iframe.setAttribute("width", el.clientWidth - 1); -			iframe.setAttribute("height", el.clientHeight - 1); -			iframe.setAttribute("frameborder", "0"); -			iframe.setAttribute("scrolling", "no"); -			iframe.setAttribute("title", "Login"); -			parent.replaceChild(iframe, el); -		} -		function setMandateSelection() { -			document.getElementById("moaidform").action = "#AUTH_URL#"; -			document.getElementById("useMandate").value = "false"; -			var checkbox = document.getElementById("mandateCheckBox"); -			if (checkbox !=  null) { -				if (document.getElementById("mandateCheckBox").checked) { -					document.getElementById("useMandate").value = "true"; -				} -			} -		} -		function onChangeChecks() { -      if (self.innerWidth < 650) { -         document.getElementById("moaidform").setAttribute("target","_parent"); -      } else { -         document.getElementById("moaidform").removeAttribute("target"); -      } -       -    } -     -     function checkIfBrowserSupportsJava(){ -        console.log("Browser is Chrome: "+checkIfBrowserIsChrome()); -        console.log("Browser is Safari: "+checkIfBrowserIsSafari()); -        console.log("Browser is Edge: "+checkIfBrowserIsEdge()); -         -        var cnt = 0; -         -        if(checkIfBrowserIsChrome())cnt++; -        if(checkIfBrowserIsEdge())cnt++; -        if(checkIfBrowserIsSafari())cnt++; -            -        if(cnt==0 || cnt>1)//cnt>1 means perhaps wrong detection -            return true; -         -        var image = document.getElementById("bkuimage"); -        var srcatt = image.getAttribute("src"); -        var last = srcatt.substring(srcatt.lastIndexOf('/')+1); -        srcatt = srcatt.replace(last,'online-bku-deactivated.png');     -        image.setAttribute("src",srcatt); -          -          -        var button = document.getElementsByName("bkuButtonOnline")[0];                -        button.setAttribute("class","browserInfoButton"); -        button.setAttribute("title","Java wird nicht unterstützt, klicken für mehr Informationen."); -        button.setAttribute("onClick","alert('Java wird von Ihrem Browser nicht unterstützt, ist jedoch für den Betrieb der Online Bürgerkartenumgebung notwendig.\\nWollen Sie dennoch die Online Bürgerkartenumgebung verwenden, wird zur Zeit Java noch von Firefox und MS Internet Explorer unterstützt. \\nAlternativ koennen Sie auch eine lokale Bürgerkartenumgebung verwenden, verfügbar unter www.buergerkarte.at.');"); -          -        return false; +   <link rel="stylesheet" href="#CONTEXTPATH#/css/buildCSS?pendingid=#SESSIONID#" /> -    } -    function checkIfBrowserIsChrome(){ -        var chrome_defined = !!window.chrome;//chrome object defined -        var webstore_defined = false; -        if(window.chrome){ -            webstore_defined = !!window.chrome.webstore; -           } -        return chrome_defined && webstore_defined; -    } -    function checkIfBrowserIsEdge(){//edge also defines the chrome object, but not the webapp -        var chrome_defined = !!window.chrome;//chrome object defined -        var webstore_defined = true; -        if(window.chrome){ -            webstore_defined = !!window.chrome.webstore; -           } -        return chrome_defined && !webstore_defined; -    } -    function checkIfBrowserIsSafari(){ -        var cond1 = Object.prototype.toString.call(window.HTMLElement).indexOf('Constructor') > 0; -        return cond1; -    } -/* 		function setSSOSelection() { -			document.getElementById("useSSO").value = "false"; -			var checkbox = document.getElementById("SSOCheckBox"); -			if (checkbox !=  null) { -				if (document.getElementById("SSOCheckBox").checked) { -					document.getElementById("useSSO").value = "true"; -				} -			} -		} */ -		 -/* 		function checkMandateSSO() { -			var sso = document.getElementById("SSOCheckBox"); -			var mandate = document.getElementById("mandateCheckBox"); -			 -			 -			if (sso.checked && mandate.checked) { -				alert("Anmeldung in Vertretung in kombination mit Single Sign-On wird aktuell noch nicht unterstützt!") -				mandate.checked = false; -				sso.checked = false; -				return true; -			} else { -				return false; -			} -		} */ -	</script> +   <!-- MOA-ID 2.x BKUSelection JavaScript fucnctions--> +   <script src="#CONTEXTPATH#/js/buildJS?pendingid=#SESSIONID#"></script> +    +  <title>Anmeldung mittels Bürgerkarte oder Handy-Signatur</title>  </head>  <body onload="onChangeChecks();checkIfBrowserSupportsJava();" onresize="onChangeChecks();"> @@ -840,7 +22,7 @@  						<h2 id="tabheader" class="dunkel" role="heading">#HEADER_TEXT#</h2>  					</div>  					<div id="bkulogin" class="hell" role="form"> -						<div id="mandateLogin" style="#MANDATEVISIBLE#"> +						<div id="mandateLogin" style="">  							<div>  								<input tabindex="1" type="checkbox" name="Mandate"  									id="mandateCheckBox" class="verticalcenter" role="checkbox" @@ -874,8 +56,6 @@  									type="hidden" name="useMandate" id="useMandate"> <input  									type="hidden" name="SSO" id="useSSO"> <input  									type="hidden" name="ccc" id="ccc"> <input type="hidden" -									name="MODUL" value="#MODUL#"> <input type="hidden" -									name="ACTION" value="#ACTION#"> <input type="hidden"  									name="pendingid" value="#SESSIONID#">                     <input type="submit" value=" Lokale Bürgerkartenumgebung " tabindex="4"  									role="button" onclick="setMandateSelection();"> @@ -884,7 +64,7 @@                <!-- Single Sign-On Session transfer functionality -->                <!--div id="ssoSessionTransferBlock"> -                <a href="#AUTH_URL#?MOASessionID=#SESSIONID#&restoreSSOSession=true">>Restore SSO Session from Smartphone</a> +                <a href="#AUTH_URL#?pendingid=#SESSIONID#&restoreSSOSession=true">>Restore SSO Session from Smartphone</a>                </div-->                <div id="stork" align="center" style="#STORKVISIBLE#"> @@ -907,16 +87,6 @@  				</div>  			</div>  		</div> -		<!--div id="validation"> -			<a href="http://validator.w3.org/check?uri="> <img -				style="border: 0; width: 88px; height: 31px" -				src="#CONTEXTPATH#/img/valid-html5-blue.png" alt="HTML5 ist valide!" /> -			</a> <a href="http://jigsaw.w3.org/css-validator/"> <img -				style="border: 0; width: 88px; height: 31px" -				src="http://jigsaw.w3.org/css-validator/images/vcss-blue" -				alt="CSS ist valide!" /> -			</a> -		</div-->  	</div>  </body>  </html> diff --git a/id/server/idserverlib/src/main/resources/resources/templates/sendAssertionFormFull.html b/id/server/idserverlib/src/main/resources/resources/templates/sendAssertionFormFull.html index 07d018a94..ecda6550b 100644 --- a/id/server/idserverlib/src/main/resources/resources/templates/sendAssertionFormFull.html +++ b/id/server/idserverlib/src/main/resources/resources/templates/sendAssertionFormFull.html @@ -3,556 +3,7 @@  <head>  	<meta content="text/html; charset=utf-8" http-equiv="Content-Type">      <!-- MOA-ID 2.x BKUSelection Layout CSS -->                -    <style type="text/css"> -			@media screen and (min-width: 650px) { -			 -				body { -					margin:0; -					padding:0; -					color : #000; -					background-color : #fff; -			  	text-align: center; -			  	background-color: #6B7B8B; -				} -				 -        #localBKU p { -          font-size: 0.7em; -        }  -         -        #localBKU input{ -          font-size: 0.7em; -          border-radius: 5px; -        } -         -         #bkuselectionarea button { -          font-size: 0.85em; -          border-radius: 7px; -          margin-bottom: 25px; -         } -         -        #mandateLogin { -          font-size: 0.85em; -        } -         -        #bku_header h2 { -          font-size: 0.8em; -        }  -         -         -			  #page { -			    display: block; -			    border: 2px solid rgb(0,0,0); -			    width: 650px; -			    height: 440px; -			    margin: 0 auto; -			    margin-top: 5%; -			    position: relative; -			    border-radius: 25px; -			    background: rgb(255,255,255); -			  } -			   -			  #page1 { -			    text-align: center; -			  } -			   -			  #main { -			    /*	clear:both; */ -				  position:relative; -			    margin: 0 auto; -			    width: 250px; -			    text-align: center; -			  } -			   -			  .OA_header { -			/*	  background-color: white;*/ -			    font-size: 20pt; -			    margin-bottom: 25px; -			    margin-top: 25px; -			  } -			 -			  #leftcontent { -        	width: 300px; -				  margin-top: 30px; -          padding-bottom: 15px; -				  margin-bottom: 25px; -			    text-align: left; -			    border: 1px solid rgb(0,0,0); -			  } -			  			   -			  #selectArea { -				 font-size: 15px; -				 padding-bottom: 65px; -			  } -			  -        #selectArea h3 { -          margin-bottom: 25px; -        } -       -        #bku_header { -          height: 5%; -          padding-bottom: 3px; -          padding-top: 3px; -        } -       -        #bkulogin { -				  overflow:hidden;	 -          min-width: 190px; -          min-height: 180px; -          /*height: 260px;*/	 -			  } -       -        h2#tabheader{ -				  font-size: 1.1em;  -          padding-left: 2%; -          padding-right: 2%; -          position: relative; -			  } -      			   -			  .setAssertionButton_full { -				  margin-top: 15px; -			    width: 100px; -			    height: 30px; -          font-size: 1.3em; -          min-height: 1.3em; -/*          border-radius: 10px;*/ -			  } -			 -			  #leftbutton  { -				 width: 30%;  -				 float:left;  -				 margin-left: 40px; -			  } -			 -			  #rightbutton { -				 width: 30%;  -				 float:right;  -				 margin-right: 45px;  -				 text-align: right; -			  } -         -        button { -          height: 25px; -          width: 90px; -          margin-bottom: 10px; -        } -         -       #validation { -        position: absolute; -        bottom: 0px; -        margin-left: 270px; -        padding-bottom: 10px; -      } -			 -			} - -      @media screen and (max-width: 205px) { -        #localBKU p { -          font-size: 0.6em; -        }  -         -        #localBKU input { -          font-size: 0.7em; -          min-width: 70px; -          min-height: 1.2em; -          border-radius: 5px; -        } -         -        #bkuselectionarea button, .setAssertionButton_full { -          font-size: 0.8em; -          min-width: 65px; -          min-height: 1.3em; -  /*        border-radius: 5px;         */ -          margin-bottom: 2% -        } -         -        #mandateLogin { -          font-size: 0.65em; -        } -         -        #bku_header h2, #selectArea h3 { -          font-size: 0.8em; -          margin-top: -0.4em; -        }  -      } - -      @media screen and (max-width: 249px) and (min-width: 206px) { -        #localBKU p { -          font-size: 0.7em; -        }  -         -        #localBKU input { -          font-size: 0.85em; -          min-width: 80px; -          min-height: 0.95em; -          border-radius: 6px; -        } -         -        #bkuselectionarea button, .setAssertionButton_full { -          font-size: 0.85em; -          min-width: 70px; -          min-height: 0.95em; -  /*        border-radius: 6px;        */ -          margin-bottom: 2% -        } -         -        #mandateLogin { -          font-size: 0.75em; -        } -         -        #bku_header h2, #selectArea h3 { -          font-size: 0.9em; -          margin-top: -0.45em; -        }  -      } - -      @media screen and (max-width: 299px) and (min-width: 250px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.9em; -          min-width: 100px; -          border-radius: 6px; -        } -         -        #bkuselectionarea button, .setAssertionButton_full { -          font-size: 1.0em; -          min-height: 1.05em; - /*         border-radius: 7px;          */ -          margin-bottom: 5%; -        } -         -        #mandateLogin { -          font-size: 1em; -        } -         -        #bku_header h2, #selectArea h3 { -          font-size: 1.0em; -          margin-top: -0.50em; -        }  -      } - -      @media screen and (max-width: 399px) and (min-width: 300px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.9em; -          min-width: 100px; -          border-radius: 6px; -        } -         -        #bkuselectionarea button, .setAssertionButton_full { -          font-size: 1.1em; -          min-height: 1.2em; -  /*        border-radius: 8px;     */ -          margin-bottom: 5%; -        } -         -        #mandateLogin { -          font-size: 1em; -        } -         -        #bku_header h2, #selectArea h3 { -          font-size: 1.1em; -          margin-top: -0.55em; -        }  -      } -       -      @media screen and (max-width: 649px) and (min-width: 400px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.9em; -          min-width: 100px; -          border-radius: 6px; -        } -         -        #bkuselectionarea button, .setAssertionButton_full { -          font-size: 1.3em; -          min-height: 1.3em; -/*          border-radius: 10px;  */ -          margin-bottom: 5%; -        } -         -        #mandateLogin { -          font-size: 1.2em; -        } -         -        #bku_header h2, #selectArea h3 { -          font-size: 1.3em; -          margin-top: -0.65em; -        }  -      } - - -			 -			@media screen and (max-width: 649px) { -				 -        body { -					margin:0; -					padding:0; -					color : #000; -			  	text-align: center; -          font-size: 100%; -			  	background-color: #MAIN_BACKGOUNDCOLOR#; -				} -        				 -			  #page { -			     visibility: hidden; -			     margin-top: 0%; -			  } -			   -			  #page1 { -			    visibility: hidden; -			  } -			   -			  #main { -			    visibility: hidden; -			  } -         -        #validation { -          visibility: hidden; -          display: none; -        } -			   -			  .OA_header { -			    margin-bottom: 0px; -			    margin-top: 0px; -			    font-size: 0pt; -			    visibility: hidden; -			  } -			 -			  #leftcontent { -			    visibility: visible; -			    margin-bottom: 0px; -			    text-align: left; -			    border:none; -          min-width: 190px; -/*          min-height: 190px;  */ -          vertical-align: middle; -           -			  } -			   -        #bku_header { -          height: 10%; -          min-height: 1.2em; -          margin-top: 1%; -        } -         -        h2#tabheader{ -          padding-left: 2%; -          padding-right: 2%; -          padding-top: 1%; -          position: relative; -          top: 50%; -			  } -         -       	#bkulogin {	 -          min-width: 190px; -          min-height: 150px;	 -			 } -         -			 .setAssertionButton_full { -				    margin-top: 15px; -			      width: 70%; -			      height: 11%; -            min-width: 60px; -            min-height: 25px; -			 } -        -       #selectArea h3 { -          margin-top: 2%; -       } -        -        button { -          height: 11%; -          width: 70%; -        } -			} -			       -			* { -				margin: 0; -				padding: 0; -/*				border: 0;  */ -        font-family: #FONTTYPE#; -			} -							      			 -			#selectArea { -				padding-top: 10px; -				padding-bottom: 55px; -				padding-left: 10px; -			} -			 -			.setAssertionButton { -				background: #efefef; -				cursor: pointer; -				margin-top: 15px; -			  width: 70px; -			  height: 25px; -			} -			 -			#leftbutton  { -				width: 35%;  -				float:left;  -				margin-left: 15px; -			} -			 -			#rightbutton { -				width: 35%;  -				float:right;  -				margin-right: 25px;  -				text-align: right; -			} -			 -			#stork { -			    margin-bottom: 10px; -			    margin-top: 5px; -			} -			 -      #mandateLogin { -        padding-bottom: 2%; -        padding-top: 2%; -        height: 10%; -        position: relative; -        text-align: center; -			} -       -      .verticalcenter { -        vertical-align: middle; -      } -       -      #mandateLogin > div { -        clear: both; -        margin-top: -1%; -        position: relative; -        top: 50%; -      } -       -      #bkuselectionarea { -          position: relative; -          display: block; -      } -       -      #localBKU { -        padding-left: 5%; -        padding-right: 2%; -        padding-bottom: 2%; -        position: relative; -        clear: both;         -			} -          			 -			#bkukarte { -				float:left; -				text-align:center; -				width:40%; -        min-height: 70px; -        padding-left: 5%; -        padding-top: 2%; -			} -			 -			#bkuhandy { -				float:right; -				text-align:center; -				width:40%; -        min-height: 90px; -        padding-right: 5%; -        padding-top: 2%; -			} -			 -      .bkuimage { -        width: 90%; -        height: auto; -      } -       -			#mandate{ -				text-align:center; -				padding : 5px 5px 5px 5px; -			} -			 -			button, .sendButton { -/*				background: #BUTTON_BACKGROUNDCOLOR#; -        color: #BUTTON_COLOR#;  */ -        cursor: pointer; -         -/*				border:1px solid #000; -        box-shadow: 3px 3px 3px #222222; */ -			} -			 -      button:hover, button:focus, button:active,  -      .sendButton:hover , .sendButton:focus, .sendButton:active, -      #mandateCheckBox:hover, #mandateCheckBox:focus, #mandateCheckBox:active { -/*				background: #BUTTON_BACKGROUNDCOLOR_FOCUS#; -        color: #BUTTON_COLOR#;  */         -        cursor: pointer; -         -/*				border:1px solid #000; -        box-shadow: -1px -1px 3px #222222;  */ -			} -      			 -			#installJava, #BrowserNOK { -				clear:both; -				font-size:0.8em; -				padding:4px; -			} -						 -			.selectText{ -			 -			} -			 -			.selectTextHeader{ -			 -			} -						 -			#leftcontent a { -				text-decoration:none;  -				color: #000; -			/*	display:block;*/ -				padding:4px;	 -			} -			 -			#leftcontent a:hover, #leftcontent a:focus, #leftcontent a:active { -				text-decoration:underline; -				color: #000;	 -			} -						 -			.infobutton { -				background-color: #005a00; -				color: white; -				font-family: serif; -				text-decoration: none; -				padding-top: 2px; -				padding-right: 4px; -				padding-bottom: 2px; -				padding-left: 4px; -				font-weight: bold; -			} -			 -			.hell { -				background-color : #MAIN_BACKGOUNDCOLOR#; -        color: #MAIN_COLOR#;	 -			} -			 -			.dunkel { -				background-color: #HEADER_BACKGROUNDCOLOR#; -        color: #HEADER_COLOR#; -			} -			       -			.main_header { -			   color: black; -			    font-size: 32pt; -			    position: absolute; -			    right: 10%; -			    top: 40px; -				 -			} -      			                         -    </style> -     +    <link rel="stylesheet" href="#CONTEXTPATH#/css/buildCSS?pendingid=#ID#" />      <title>Anmeldung an Online-Applikation</title>     </head> @@ -582,8 +33,8 @@  										<input type="hidden" name="value" value="true">  										<input type="hidden" name="mod" value="#MODUL#">  								    <input type="hidden" name="action" value="#ACTION#"> -                    <input type="hidden" name="identifier" value="#ID#"> -										<input type="submit" value="Ja" class="setAssertionButton_full sendButton" role="button"> +                    <input type="hidden" name="pendingid" value="#ID#"> +										<input type="submit" value="Ja" class="setAssertionButton_full" role="button">  									</form>  							</div>  							<div id="rightbutton"> @@ -591,8 +42,8 @@  										<input type="hidden" name="value" value="false">  										<input type="hidden" name="mod" value="#MODUL#">  								    <input type="hidden" name="action" value="#ACTION#"> -                    <input type="hidden" name="identifier" value="#ID#"> -										<input type="submit" value="Nein" class="setAssertionButton_full sendButton" role="button"> +                    <input type="hidden" name="pendingid" value="#ID#"> +										<input type="submit" value="Nein" class="setAssertionButton_full" role="button">  									</form>  							</div> diff --git a/id/server/idserverlib/src/main/resources/resources/templates/slo_template.html b/id/server/idserverlib/src/main/resources/resources/templates/slo_template.html index a9d73e0d3..220dd980a 100644 --- a/id/server/idserverlib/src/main/resources/resources/templates/slo_template.html +++ b/id/server/idserverlib/src/main/resources/resources/templates/slo_template.html @@ -3,377 +3,7 @@    <meta content="text/html; charset=utf-8" http-equiv="Content-Type">     <!-- MOA-ID 2.x BKUSelection Layout CSS -->                -    <style type="text/css"> -			@media screen and (min-width: 650px) { -			 -				body { -					margin:0; -					padding:0; -					color : #000; -					background-color : #fff; -			  	text-align: center; -			  	background-color: #6B7B8B; -				} -   -			  #page { -			    display: block; -			    border: 2px solid rgb(0,0,0); -			    width: 650px; -			    height: 460px; -			    margin: 0 auto; -			    margin-top: 5%; -			    position: relative; -			    border-radius: 25px; -			    background: rgb(255,255,255); -			  } -			   -			  #page1 { -			    text-align: center; -			  } -			   -			  #main { -			    /*	clear:both; */ -				  position:relative; -			    margin: 0 auto; -			    width: 250px; -			    text-align: center; -			  } -			   -			  .OA_header { -			/*	  background-color: white;*/ -			    font-size: 20pt; -			    margin-bottom: 25px; -			    margin-top: 25px; -			  } -			 -			  #leftcontent { -			    /*float:left; */ -				  width:250px; -				  margin-bottom: 25px; -			    text-align: left; -			    /*border: 1px solid rgb(0,0,0);*/ -			  } -			 -			  #leftcontent { -				 width: 300px; -				 margin-top: 30px; -			  } -       -        h2#tabheader{ -				  font-size: 1.1em;  -          padding-left: 2%; -          padding-right: 2%; -          position: relative; -			  } -        		   -			  .setAssertionButton_full { -			  	background: #efefef; -				  cursor: pointer; -				  margin-top: 15px; -			    width: 100px; -			    height: 30px -			  } -			 -			  #leftbutton  { -				 width: 30%;  -				 float:left;  -				 margin-left: 40px; -			  } -			 -			  #rightbutton { -				 width: 30%;  -				 float:right;  -				 margin-right: 45px;  -				 text-align: right; -			  } -         -        button { -          height: 25px; -          width: 75px; -          margin-bottom: 10px; -        } -         -       #validation { -        position: absolute; -        bottom: 0px; -        margin-left: 270px; -        padding-bottom: 10px; -      } -			 -			} - -      @media screen and (max-width: 205px) { -        #localBKU p { -          font-size: 0.6em; -        }  -         -        #localBKU input { -          font-size: 0.6em; -          min-width: 60px; -         /* max-width: 65px; */ -          min-height: 1.0em; -         /* border-radius: 5px; */ -        } -         -      } - -      @media screen and (max-width: 249px) and (min-width: 206px) { -        #localBKU p { -          font-size: 0.7em; -        }  -         -        #localBKU input { -          font-size: 0.7em; -          min-width: 70px; -       /*    max-width: 75px;    */ -          min-height: 0.95em; -        /*  border-radius: 6px;    */ -        } -          -      } - -      @media screen and (max-width: 299px) and (min-width: 250px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -       /*    max-width: 75px;      */ -      /*    border-radius: 6px;  */ -        } - -      } - -      @media screen and (max-width: 399px) and (min-width: 300px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 75px;     */ -      /*    border-radius: 6px;       */ -        } - -      } -       -      @media screen and (max-width: 649px) and (min-width: 400px) { -        #localBKU p { -          font-size: 0.9em; -        }  -         -        #localBKU input { -          font-size: 0.8em; -          min-width: 70px; -      /*     max-width: 80px;       */ -     /*     border-radius: 6px;          */ -        } - -      } - - -			 -			@media screen and (max-width: 649px) { -				 -        body { -					margin:0; -					padding:0; -					color : #000; -			  	text-align: center; -          font-size: 100%; -			  	background-color: #MAIN_BACKGOUNDCOLOR#; -				} -        				 -			  #page { -			     visibility: hidden; -			     margin-top: 0%; -			  } -			   -			  #page1 { -			    visibility: hidden; -			  } -			   -			  #main { -			    visibility: hidden; -			  } -         -        #validation { -          visibility: hidden; -          display: none; -        } -			   -			  .OA_header { -			    margin-bottom: 0px; -			    margin-top: 0px; -			    font-size: 0pt; -			    visibility: hidden; -			  } -			 -			  #leftcontent { -			    visibility: visible; -			    margin-bottom: 0px; -			    text-align: left; -			    border:none; -          vertical-align: middle; -          min-height: 173px; -          min-width: 204px; -           -			  } -         -        input[type=button] { -/*          height: 11%;  */ -          width: 70%; -        } -			} -			       -			* { -				margin: 0; -				padding: 0; -        font-family: #FONTTYPE#; -			} -							      			 -			#selectArea { -				padding-top: 10px; -				padding-bottom: 55px; -				padding-left: 10px; -			} -			 -			.setAssertionButton { -				background: #efefef; -				cursor: pointer; -				margin-top: 15px; -			  width: 70px; -			  height: 25px; -			} -			 -			#leftbutton  { -				width: 35%;  -				float:left;  -				margin-left: 15px; -			} -			 -			#rightbutton { -				width: 35%;  -				float:right;  -				margin-right: 25px;  -				text-align: right; -			} - -/*		input[type=button], .sendButton { -				background: #BUTTON_BACKGROUNDCOLOR#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;  */ -/*				cursor: pointer; -/*        box-shadow: 3px 3px 3px #222222;  */ -/*			} -			 -/*      button:hover, button:focus, button:active,  -      .sendButton:hover , .sendButton:focus, .sendButton:active, -      #mandateCheckBox:hover, #mandateCheckBox:focus, #mandateCheckBox:active { -				background: #BUTTON_BACKGROUNDCOLOR_FOCUS#; -        color: #BUTTON_COLOR#; -/*				border:1px solid #000;                */ -/*				cursor: pointer; -/*        box-shadow: -1px -1px 3px #222222;  */ -/*			} -       -*/       -			input { -				/*border:1px solid #000;*/ -				cursor: pointer; -			} -       -      #localBKU input { -/*        color: #BUTTON_COLOR#;  */ -        border: 0px; -        display: inline-block; -         -      } -			 -      #localBKU input:hover, #localBKU input:focus, #localBKU input:active { -        text-decoration: underline; -      } -       -			#installJava, #BrowserNOK { -				clear:both; -				font-size:0.8em; -				padding:4px; -			} -						 -			.selectText{ -			 -			} -			 -			.selectTextHeader{ -			 -			} -			 -			.sendButton { -        width: 30%; -        margin-bottom: 1%;	 -			} -			 -			#leftcontent a { -				text-decoration:none;  -				color: #000; -			/*	display:block;*/ -				padding:4px;	 -			} -			 -			#leftcontent a:hover, #leftcontent a:focus, #leftcontent a:active { -				text-decoration:underline; -				color: #000;	 -			} -						 -			.infobutton { -				background-color: #005a00; -				color: white; -				font-family: serif; -				text-decoration: none; -				padding-top: 2px; -				padding-right: 4px; -				padding-bottom: 2px; -				padding-left: 4px; -				font-weight: bold; -			} -			 -			.hell { -				background-color : #MAIN_BACKGOUNDCOLOR#; -        color: #MAIN_COLOR#;	 -			} -			 -			.dunkel { -				background-color: #HEADER_BACKGROUNDCOLOR#; -        color: #HEADER_COLOR#; -			} -			       -			.main_header { -			   color: black; -			    font-size: 32pt; -			    position: absolute; -			    right: 10%; -			    top: 40px; -				 -			} -       -     	#alert { -		    margin: 100px 250px; -		    font-family: Verdana, Arial, Helvetica, sans-serif; -		    font-size: 14px; -		    font-weight: normal; -		    color: red; -	    } -	 -	    .reqframe { -		    /*display: none;*/ -        visibility: hidden; -		   -	    } -      			                         -    </style>  +  <link rel="stylesheet" href="#CONTEXTPATH#/css/buildCSS" />  	#if($timeoutURL)  		<script type="text/javascript"> diff --git a/id/server/idserverlib/src/main/resources/resources/templates/sso_transfer_template.html b/id/server/idserverlib/src/main/resources/resources/templates/sso_transfer_template.html new file mode 100644 index 000000000..e9c2fae76 --- /dev/null +++ b/id/server/idserverlib/src/main/resources/resources/templates/sso_transfer_template.html @@ -0,0 +1,59 @@ +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> +<head> +  <meta content="text/html; charset=utf-8" http-equiv="Content-Type"> +   +   <!-- MOA-ID 2.x BKUSelection Layout CSS -->                +  <link rel="stylesheet" href="#CONTEXTPATH#/css/buildCSS" /> + +  <title>Single Sign-On Session Transfer</title> +</head> + +	<body> +  <noscript> +		<p> +			<strong>Note:</strong> Since your browser does not support +			JavaScript, you must press the Continue button once to proceed. +		</p> +	</noscript> + +  <div id="page"> +		<div id="page1" class="case selected-case" role="main"> +			<h2 class="OA_header" role="heading">MOA-ID Single Sign-On Session Transfer Service</h2> +			<div id="main"> +				<div id="leftcontent" class="hell" role="application"> +           +          #if($errorMsg) +	         <div class="alert"> +		        <p>$errorMsg</p>  +	         </div>	 +	        #end + +	        #if($successMsg) +	         <div> +		        <p>$successMsg</p>  +	         </div>	 +	        #end +           +          #if($QRImage) +	         <div> +	         	<img id="qrCode" src="data:image/gif;base64,$QRImage"> +	         </div>	 +	        #end +           +				</div> +			</div> +		</div> +		<!--div id="validation"> +			<a href="http://validator.w3.org/check?uri="> <img +				style="border: 0; width: 88px; height: 31px" +				src="$contextpath/img/valid-html5-blue.png" alt="HTML5 ist valide!" /> +			</a> <a href="http://jigsaw.w3.org/css-validator/"> <img +				style="border: 0; width: 88px; height: 31px" +				src="http://jigsaw.w3.org/css-validator/images/vcss-blue" +				alt="CSS ist valide!" /> +			</a> +		</div--> +	</div> + +</body> +</html>
\ No newline at end of file diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java index 3aefeba3e..6d43bcdc6 100644 --- a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java @@ -229,6 +229,24 @@ public class TestRequestImpl implements IRequest {  	public void setProcessInstanceID(String processInstanceID) {  		this.processInstanceID = processInstanceID;  	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.moduls.IRequest#isAbortedByUser() +	 */ +	@Override +	public boolean isAbortedByUser() { +		// TODO Auto-generated method stub +		return false; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.moduls.IRequest#setAbortedByUser(boolean) +	 */ +	@Override +	public void setAbortedByUser(boolean isAborted) { +		// TODO Auto-generated method stub +		 +	} diff --git a/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/protocol/OAuth20AuthAction.java b/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/protocol/OAuth20AuthAction.java index e7594954b..33d057fe9 100644 --- a/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/protocol/OAuth20AuthAction.java +++ b/id/server/modules/moa-id-module-openID/src/main/java/at/gv/egovernment/moa/id/protocols/oauth20/protocol/OAuth20AuthAction.java @@ -111,7 +111,7 @@ class OAuth20AuthAction implements IAction {  			//TODO: maybe add bPK / wbPK to SLO information -			SLOInformationInterface sloInformation = new SLOInformationImpl(req.getAuthURL(), accessToken, null, null, req.requestedModule()); +			SLOInformationInterface sloInformation = new SLOInformationImpl(req.getAuthURL(), req.getOnlineApplicationConfiguration().getPublicURLPrefix(), accessToken, null, null, req.requestedModule());  			return sloInformation;  		} diff --git a/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/GetArtifactAction.java b/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/GetArtifactAction.java index 61a73335c..b184aa4fe 100644 --- a/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/GetArtifactAction.java +++ b/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/GetArtifactAction.java @@ -117,7 +117,7 @@ public class GetArtifactAction implements IAction {  			}  			SLOInformationInterface sloInformation =  -					new SLOInformationImpl(req.getAuthURL(), authData.getAssertionID(), null, null, req.requestedModule()); +					new SLOInformationImpl(req.getAuthURL(), oaParam.getPublicURLPrefix(), authData.getAssertionID(), null, null, req.requestedModule());  			return sloInformation; diff --git a/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/SAML1Protocol.java b/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/SAML1Protocol.java index 1b1815b44..f3650065e 100644 --- a/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/SAML1Protocol.java +++ b/id/server/modules/moa-id-modules-saml1/src/main/java/at/gv/egovernment/moa/id/protocols/saml1/SAML1Protocol.java @@ -97,7 +97,7 @@ public class SAML1Protocol extends AbstractAuthProtocolModulController {  	@RequestMapping(value = "/StartAuthentication", method = {RequestMethod.POST, RequestMethod.GET}) -	public void PVPMetadataRequest(HttpServletRequest req, HttpServletResponse resp) throws MOAIDException, IOException {		 +	public void SAML1AuthnRequest(HttpServletRequest req, HttpServletResponse resp) throws MOAIDException, IOException {		  		if (!AuthConfigurationProviderFactory.getInstance().getAllowedProtocols().isSAML1Active()) {  			Logger.info("SAML1 is deaktivated!");  			throw new ProtocolNotActiveException("auth.22", new Object[] { "SAML 1" }); | 
