<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}{3}:KeyboxIdentifier>" + nl +
" <{3}:DataObjectInfo Structure=''detached''>" + nl +
" <{4}:DataObject Reference=''''/>" + nl +
"{2}" +
" {3}:DataObjectInfo>" + nl +
" <{3}:SignatureInfo>" + nl +
" <{3}:SignatureEnvironment>" + nl +
" <{4}:XMLContent>{0}{4}:XMLContent>" + nl +
" {3}:SignatureEnvironment>" + nl +
" <{3}:SignatureLocation xmlns:saml=''" + SAML_NS_URI + "'' Index=''2''>/saml:Assertion{3}:SignatureLocation>" + nl +
" {3}:SignatureInfo>" + nl +
"{3}:CreateXMLSignatureRequest>";
/**
* 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, String[] dsigTransformInfos, boolean slVersion12) {
String sl10Prefix;
String sl11Prefix;
String slNsDeclaration;
String dsigTransformInfosString = "";
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>
*/
public String buildForeignID(String subject, OAAuthParameter oaParam, AuthenticationSession session) {
String target = session.getTarget();
String sectorName = TargetToSectorNameMapper.getSectorNameViaTarget(target);
Calendar cal = Calendar.getInstance();
String date = DateTimeUtils.buildDate(cal);
String time = DateTimeUtils.buildTime(cal);
String request = "";
request += "Personal Data
"; request += "Name: | "; request += ""; request += subject; request += " | "; request += "
Application Data
"; request += "Name: | "; request += ""; // friendlyname from OA request += StringUtils.isEmpty(oaParam.getFriendlyName()) ? "" : oaParam.getFriendlyName(); request += " | "; request += "
Country: | "; request += "Austria | "; request += "
Technical Parameters
"; request += "URL: | "; request += ""; //public URL prefix from OA request += oaParam.getPublicURLPrefix(); request += " | "; request += "
"; request += identifierType + ":"; request += " | "; request += ""; request += identifier; request += " | "; request += "
"; request += "Sector: | "; request += ""; request += target + " (" + sectorName + ")"; request += " | "; request += "
Date: | "; request += ""; request += date; request += " | "; request += "
Time: | "; request += ""; request += time; request += " | "; 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).