/******************************************************************************* * 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. ******************************************************************************/ /* * Copyright 2003 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.text.MessageFormat; import java.util.Calendar; import java.util.List; import at.gv.egiz.eaaf.core.api.IRequest; import at.gv.egovernment.moa.id.commons.MOAIDAuthConstants; import at.gv.egovernment.moa.id.commons.api.IOAAuthParameters; import at.gv.egovernment.moa.id.commons.api.exceptions.ConfigurationException; import at.gv.egovernment.moa.id.config.TargetToSectorNameMapper; import at.gv.egovernment.moa.id.config.auth.OAAuthParameterDecorator; import at.gv.egovernment.moa.util.Constants; import at.gv.egovernment.moa.util.DateTimeUtils; import at.gv.egovernment.moa.util.MiscUtil; import at.gv.egovernment.moa.util.StringUtils; /** * Builder for the <CreateXMLSignatureRequest> structure * used for requesting a signature under the authentication block from the * security layer implementation. * * @author Paul Ivancsics * @version $Id$ */ public class CreateXMLSignatureRequestBuilder implements Constants { /** private static String nl contains the NewLine representation in Java*/ private static final String nl = "\n"; /** * XML template for the <moa:CreateXMLSignatureRequest> to be built */ private static final String CREATE_XML_SIGNATURE_REQUEST = "" + nl + "<{3}:CreateXMLSignatureRequest xmlns:dsig=''" + DSIG_NS_URI + "'' {5}>" + nl + " <{3}:KeyboxIdentifier>{1}" + nl + " <{3}:DataObjectInfo Structure=''detached''>" + nl + " <{4}:DataObject Reference=''''/>" + nl + "{2}" + " " + nl + " <{3}:SignatureInfo>" + nl + " <{3}:SignatureEnvironment>" + nl + " <{4}:XMLContent>{0}" + nl + " " + nl + " <{3}:SignatureLocation xmlns:saml=''" + SAML_NS_URI + "'' Index=''2''>/saml:Assertion" + nl + " " + nl + ""; /** * Constructor for CreateXMLSignatureRequestBuilder. */ public CreateXMLSignatureRequestBuilder() { super(); } /** * Builds the <CreateXMLSignatureRequest>. * * @param authBlock String representation of XML authentication block * @param keyBoxIdentifier the key box identifier which will be used (e.g. CertifiedKeypair) * @param slVersion12 specifies whether the Security Layer version number is 1.2 or not * @return String representation of <CreateXMLSignatureRequest> */ public String build(String authBlock, String keyBoxIdentifier, List dsigTransformInfos) { String sl10Prefix; String sl11Prefix; String slNsDeclaration; String dsigTransformInfosString = ""; for (String element : dsigTransformInfos) { dsigTransformInfosString += element; } // for (int i = 0; i < dsigTransformInfos.length; i++) { // dsigTransformInfosString += dsigTransformInfos[i]; // } // if (slVersion12) { // replace the SecurityLayer namespace prefixes and URIs within the transforms dsigTransformInfosString = StringUtils.changeSLVersion(dsigTransformInfosString, SL10_PREFIX, SL12_PREFIX, SL10_NS_URI, SL12_NS_URI); sl10Prefix = SL12_PREFIX; sl11Prefix = SL12_PREFIX; slNsDeclaration = "xmlns:" + SL12_PREFIX + "='" + SL12_NS_URI + "'"; // } else { // // sl10Prefix = SL10_PREFIX; // sl11Prefix = SL11_PREFIX; // slNsDeclaration = "xmlns:" + sl10Prefix + "='" + SL10_NS_URI + "' xmlns:" + sl11Prefix + "='" + SL11_NS_URI + "'"; // // } String request = MessageFormat.format( CREATE_XML_SIGNATURE_REQUEST, new Object[] { authBlock, keyBoxIdentifier, dsigTransformInfosString, sl11Prefix, sl10Prefix, slNsDeclaration }); return request; } /** * Builds the <CreateXMLSignatureRequest> for a foreign ID. * * @param subject the subject of the foreign certificate * @param oaParam parameter for the OA * @param session current session * @return String representation of <CreateXMLSignatureRequest> * @throws ConfigurationException */ public String buildForeignID(String subject, IRequest pendingReq) throws ConfigurationException { String request = ""; request += ""; request += "SecureSignatureKeypair"; request += ""; request += ""; request += ""; request += buildForeignIDTextToBeSigned(subject,pendingReq); request += ""; request += ""; request += ""; request += ""; request += "application/xhtml+xml"; request += ""; request += ""; request += ""; request += ""; return request; } public static String buildForeignIDTextToBeSigned(String subject, IRequest pendingReq) throws ConfigurationException { IOAAuthParameters oaParam = pendingReq.getServiceProviderConfiguration(OAAuthParameterDecorator.class); String target = null; String sectorName = null; String saml1Target = pendingReq.getRawData( MOAIDAuthConstants.AUTHPROCESS_DATA_TARGET, String.class); if (MiscUtil.isNotEmpty(saml1Target)) { target = saml1Target; sectorName = TargetToSectorNameMapper.getSectorNameViaTarget(saml1Target); } else { target = oaParam.getAreaSpecificTargetIdentifier(); sectorName = oaParam.getAreaSpecificTargetIdentifierFriendlyName(); } Calendar cal = Calendar.getInstance(); String date = DateTimeUtils.buildDate(cal); String time = DateTimeUtils.buildTime(cal); String request = ""; request += ""; //application/xhtml+xml text/html //request += ""; request += ""; request += "Signatur der Anmeldedaten"; request += ""; // request += ""; request += ""; request += ""; request += "

Anmeldedaten für (Requesting Application Access for):

"; request += "

Persönliche Daten (Personal Data)

"; request += ""; request += ""; request += ""; request += ""; request += ""; request += "
Name:"; request += subject; request += "
"; request += "

Daten zur Anwendung (Application Data)

"; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += "
Dienst (Service):"; // friendlyname from OA request += StringUtils.isEmpty(oaParam.getFriendlyName()) ? "" : oaParam.getFriendlyName(); request += "
Land (Country):Österreich (Austria)
"; request += "

Technische Parameter (Technical Parameters)

"; request += ""; request += ""; request += ""; request += ""; request += ""; if (!target.startsWith(MOAIDAuthConstants.PREFIX_CDID)) { // OA is businessservice String identifierType = oaParam.getAreaSpecificTargetIdentifierFriendlyName(); String identifier = oaParam.getAreaSpecificTargetIdentifier(); request += ""; request += ""; request += ""; request += ""; } else { // OA is publicservice request += ""; request += ""; request += ""; request += ""; } request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += ""; request += "
URL:"; //public URL prefix from OA request += oaParam.getPublicURLPrefix(); request += "
"; request += identifierType + ":"; request += ""; request += identifier; request += "
"; request += "Sektor (Sector):"; request += target.substring(MOAIDAuthConstants.PREFIX_CDID.length()) + " (" + sectorName + ")"; request += "
Datum (Date):"; request += date; request += "
Zeit (Time):"; request += time; request += "
"; request += "

Mit der Anmeldung erfolgt eine Abfrage des Ergänzungsregister für " + "natürliche Personen (ERnP), damit ich meinen elektronischen " + "Identitätsnachweis (meine elektronische Identitätskarte) unmittelbar " + "als Österreichische Bürgerkarte verwenden kann. Ich bin nicht im " + "Zentralen Melderegister eingetragen und stimme, sofern ich nicht im " + "ERnP eingetragen bin, einer Eintragung ins ERnP zu. Ich nehme zur " + "Kenntnis, dass die Eintragung ins ERnP ausschließlich der Aufzeichnung " + "jener Daten, die für die eindeutige Identität notwendig sind, dient.

"; request += "

I affirm that I am not registered with the Austrian Central " + "Register of Residents or the Supplementary Register for Natural Persons. I therefore " + "apply for registration in the Supplementary Register for Natural Persons in order to use " + "my electronic identity (my electronic ID card) as an Austrian citizen card. I take note " + "that registration in the Supplementary Register for Natural Persons solely serves keeping " + "records of those data that are used for validation of unique identity and that those data " + "is only used for e-government purposes.

"; // request += "

I hereby request to access this e-government application by using my " + // "domestic electronic identity.
" + // "I further affirm that I am not yet registered with the Austrian Central " + // "Residents Registry and that I am not obliged to register with the Austrian " + // "Central Residents Registry according to Austrian law.
" + // "In the event I am not yet registered with the Supplementary Register, I " + // "explicitly grant to do so according to §6 (5) E-Government Act (EGovG, idF: " + // "BGBl. I Nr. 7/2008 und BGBl. I Nr. 59/2008).

"; request += ""; request += ""; return request; } }