diff options
author | Thomas Lenz <thomas.lenz@egiz.gv.at> | 2019-10-01 10:57:01 +0200 |
---|---|---|
committer | Thomas Lenz <thomas.lenz@egiz.gv.at> | 2019-10-01 10:57:01 +0200 |
commit | df2ba23f9479f37c11a7a23b697b5acaa4e97d33 (patch) | |
tree | ea042bb74cab85c45f47f84ff864ab808f72342b /src/test/java/at | |
parent | dcd678d6ac5ededc8b58b5d473cf12acfdbd8598 (diff) | |
download | egovutils-df2ba23f9479f37c11a7a23b697b5acaa4e97d33.tar.gz egovutils-df2ba23f9479f37c11a7a23b697b5acaa4e97d33.tar.bz2 egovutils-df2ba23f9479f37c11a7a23b697b5acaa4e97d33.zip |
update MIS v2.0 end-point implementation
add MISV2Client.java for testing
Diffstat (limited to 'src/test/java/at')
-rw-r--r-- | src/test/java/at/gv/util/demo/Clienttests.java | 88 | ||||
-rw-r--r-- | src/test/java/at/gv/util/demo/ZuseSSLTest.java | 15 |
2 files changed, 91 insertions, 12 deletions
diff --git a/src/test/java/at/gv/util/demo/Clienttests.java b/src/test/java/at/gv/util/demo/Clienttests.java index e233944..b2f90ae 100644 --- a/src/test/java/at/gv/util/demo/Clienttests.java +++ b/src/test/java/at/gv/util/demo/Clienttests.java @@ -36,6 +36,7 @@ import javax.xml.bind.JAXBElement; import javax.xml.namespace.QName; import javax.xml.transform.TransformerException; +import org.apache.commons.lang.RandomStringUtils; import org.apache.cxf.common.util.Base64Utility; import org.apache.cxf.helpers.IOUtils; import org.w3c.dom.Element; @@ -44,6 +45,7 @@ import at.gv.util.BpkUtil; import at.gv.util.DOMUtils; import at.gv.util.MiscUtil; import at.gv.util.client.mis.usp_v2.USPClient; +import at.gv.util.client.mis_v2.MISV2Client; import at.gv.util.client.mms.MMSClient; import at.gv.util.client.szr.SZRClient; import at.gv.util.client.ur_V5.URClient; @@ -52,7 +54,12 @@ import at.gv.util.client.ur_V5.URClientException; import at.gv.util.config.EgovUtilPropertiesConfiguration; import at.gv.util.data.BPK; import at.gv.util.ex.EgovUtilException; +import at.gv.util.wsdl.mis_v2.GetMandatesError; import at.gv.util.wsdl.szr.SZRException; +import at.gv.util.xsd.mis_v2.GetMandatesRequestType; +import at.gv.util.xsd.mis_v2.GetMandatesResponseType; +import at.gv.util.xsd.mis_v2.PersonInformationType; +import at.gv.util.xsd.mis_v2.persondata.IdentificationType.Value; import at.gv.util.xsd.mms.GetMandatesRequest; import at.gv.util.xsd.mms.GetMandatesRequest.MandateIdentifiers; import at.gv.util.xsd.mms.GetMandatesResponse; @@ -134,7 +141,7 @@ public class Clienttests { SZRClient szrClient = new SZRClient(egovUtilConfiguration); URClient urClient = new URClient(egovUtilConfiguration, UR_TYPES, ERSB_KEYS, false, true); MMSClient mmsClient = new MMSClient(egovUtilConfiguration); - + MISV2Client misV2Client = new MISV2Client(egovUtilConfiguration); PersonInfoType personInfo = new PersonInfoType(); @@ -291,28 +298,87 @@ public class Clienttests { personName.setFamilyName("Mustermann"); personName.setGivenName("Max"); person.setDateOfBirth("1940-01-01"); +// id.setType(SSPIN_PREFIX + "ZP"); +// id.setValue("nOuO8JELgLMCke6qWSAfNSDPPcM="); + id.setType(SSPIN_PREFIX + "ZU"); + id.setValue("NEK/9ZsnA7e2phK71F/OSdIjwbU="); + person.setIdentification(id); + +// personName.setFamilyName("Hiptmair"); +// personName.setGivenName("Karl"); + //person.setDateOfBirth("1968-04-07"); +// id.setType(SSPIN_PREFIX + "ZU"); +// id.setValue("WlDEwRwleyT9gyCRedqhL+vNmBs="); + +// id.setType(SSPIN_PREFIX + "ZP"); +// id.setValue("OzlNpKPY4oFt10uu0dQ55G/uaCE="); + + person.setIdentification(id); + + + //************************************* + //MIS v2.0 test + GetMandatesRequestType getMandatesRequest = new GetMandatesRequestType(); + getMandatesRequest.setReqId(RandomStringUtils.randomAlphabetic(10)); + PersonInformationType pInfo = new PersonInformationType(); + pInfo.setDateOfBirth(person.getDateOfBirth()); + pInfo.setGivenName(person.getName().getGivenName()); + pInfo.setFamilyName(person.getName().getFamilyName()); + at.gv.util.xsd.mis_v2.persondata.IdentificationType idType = new at.gv.util.xsd.mis_v2.persondata.IdentificationType(); + idType.setType(person.getIdentification().getType()); + Value idValue = new Value(); + idValue.setValue(person.getIdentification().getValue()); + idType.setValue(idValue ); + pInfo.setIdentification(idType ); + getMandatesRequest.setPersonInformation(pInfo ); + + try { + GetMandatesResponseType getMandatesResp = misV2Client.sendMandateIssueRequest(getMandatesRequest, "https://labda.iaik.tugraz.at:5343/mis/services/GetMandatesRequest"); + System.out.println("Get result from MIS v2.0 with #" + getMandatesResp.getMisMandate().size() + " mandates"); + + } catch (GetMandatesError e) { + e.printStackTrace(); + + } + + //************************************* String baseID = szrClient.getStammzahl(personInfo ); - BPK zpBpk = BpkUtil.createBPK(baseID, "ZP"); + BPK zpBpk; + BPK zuBpk; + //BPK zuBpk = BpkUtil.createBPK(baseID, "ZU"); + zuBpk = new BPK("ZU", id.getValue()); + zpBpk = new BPK("ZP", id.getValue()); + +// id.setType(SSPIN_PREFIX + zuBpk.getSector()); +// id.setValue(zuBpk.getBpk()); +// person.setDateOfBirth(null); +// person.setIdentification(id); + + + // BPK zpBpk = BpkUtil.createBPK(baseID, "ZP-MH"); // System.out.print(zpBpk); - GetMandatesRequest mmsRequest = new GetMandatesRequest(); - mmsRequest.setBPK(zpBpk.getBpk()); - mmsRequest.setBPKType(BpkUtil.PREFIX_BPK_TYPE + "ZU"); - MandateIdentifiers filters = new MandateIdentifiers(); - filters.getMandateIdentifier().add("GeneralvollmachtBilateral"); - mmsRequest.setMandateIdentifiers(filters ); - GetMandatesResponse mmsResult = mmsClient.sendGetMandatesRequest(mmsRequest, "https://vollmachten.egiz.gv.at/mms-test/services/GetMandatesService"); +// GetMandatesRequest mmsRequest = new GetMandatesRequest(); +// mmsRequest.setBPK(zpBpk.getBpk()); +// mmsRequest.setBPKType(BpkUtil.PREFIX_BPK_TYPE + "ZU"); +// MandateIdentifiers filters = new MandateIdentifiers(); +// filters.getMandateIdentifier().add("GeneralvollmachtBilateral"); +// mmsRequest.setMandateIdentifiers(filters ); +// GetMandatesResponse mmsResult = mmsClient.sendGetMandatesRequest(mmsRequest, "https://vollmachten.egiz.gv.at/mms-test/services/GetMandatesService"); // personInfo.getPerson().setDateOfBirth(null); -// String test = szrClient.getBPK(personInfo, "BF", "BBA-STA"); +// String test = szrClient.getBPK(personInfo, "ZP", "BBA-STA"); + String test = szrClient.getBPK(personInfo, "ZP", "BKA"); + //String test = szrClient.getBPK(personInfo, "ZU", "BKA"); // String encryptedbPK = szrClient.transformBPK(personInfo, zpBpk.getBpk(), SSPIN_PREFIX + "ZP", SSPIN_PREFIX + "WT-UR", "BBA-STA"); - FremdBPKType encryptedbPK = szrClient.transformBPK(personInfo, zpBpk.getBpk(), SSPIN_PREFIX + "ZP", SSPIN_PREFIX + "WT-UR", "BMF"); +// FremdBPKType encryptedbPK = szrClient.transformBPK(personInfo, zpBpk.getBpk(), SSPIN_PREFIX + "ZP", SSPIN_PREFIX + "WT-UR", "BMF"); + FremdBPKType encryptedbPK = szrClient.transformBPK(personInfo, zuBpk.getBpk(), SSPIN_PREFIX + "ZU", SSPIN_PREFIX + "WT-UR", "BMF"); // String encryptedbPK = szrClient.transformBPK(personInfo, zpBpk.getBpk(), SSPIN_PREFIX + "ZP", SSPIN_PREFIX + "ZU", "ZUSETNVZ"); diff --git a/src/test/java/at/gv/util/demo/ZuseSSLTest.java b/src/test/java/at/gv/util/demo/ZuseSSLTest.java index 359cb4e..516c228 100644 --- a/src/test/java/at/gv/util/demo/ZuseSSLTest.java +++ b/src/test/java/at/gv/util/demo/ZuseSSLTest.java @@ -4,6 +4,7 @@ import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; +import java.io.UnsupportedEncodingException; import java.net.Socket; import java.security.Key; import java.security.KeyManagementException; @@ -35,7 +36,19 @@ import at.gv.util.xsd.szr.pvp.sec.Security; public class ZuseSSLTest { - public static void main(String[] args) { + public static void main(String[] args) throws UnsupportedEncodingException { + + String b64AuthBlock = "<?xml version="1.0" encoding="UTF-8" ?>
<sl:CreateXMLSignatureRequest xmlns:dsig='http://www.w3.org/2000/09/xmldsig#' xmlns:sl='http://www.buergerkarte.at/namespaces/securitylayer/1.2#'>
 <sl:KeyboxIdentifier>SecureSignatureKeypair</sl:KeyboxIdentifier>
 <sl:DataObjectInfo Structure='detached'>
  <sl:DataObject Reference=''/>
<sl:TransformsInfo>
	<dsig:Transforms xmlns:dsig="http://www.w3.org/2000/09/xmldsig#">
		<dsig:Transform Algorithm="http://www.w3.org/TR/1999/REC-xslt-19991116">
			<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:saml="urn:oasis:names:tc:SAML:1.0:assertion" xmlns:pr="http://reference.e-government.gv.at/namespace/persondata/20020228#" exclude-result-prefixes="pr saml">
				<xsl:output method="xml" xml:space="default"/>
				<xsl:template match="/" xmlns="http://www.w3.org/1999/xhtml">
					<html>
						<head>
							<title>Signatur der Anmeldedaten</title>
							<style type="text/css" media="screen">
              					.normalstyle { font-size: medium; } 
              					.italicstyle { font-size: medium; font-style: italic; }
								.titlestyle{ text-decoration:underline; font-weight:bold; font-size: medium; } 
								.h4style{ font-size: large; }                                                                                      
              				</style>
						</head>
						<body>
							<h4 class="h4style">Anmeldedaten:</h4>
							<p class="titlestyle">Daten zur Person</p>
							<table class="parameters">
								<xsl:if test="normalize-space(//@Issuer)">
									<tr>
										<td class="italicstyle">Name:</td>
										<td class="normalstyle">
											<xsl:value-of select="//@Issuer"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="string(//saml:Attribute[@AttributeName='Geburtsdatum']/saml:AttributeValue)">
									<tr>
										<td class="italicstyle">Geburtsdatum:</td>
										<td class="normalstyle">
											<xsl:value-of select="substring(//saml:Attribute[@AttributeName='Geburtsdatum']/saml:AttributeValue,9,2)"/>
											<xsl:text>.</xsl:text>
											<xsl:value-of select="substring(//saml:Attribute[@AttributeName='Geburtsdatum']/saml:AttributeValue,6,2)"/>
											<xsl:text>.</xsl:text>
											<xsl:value-of select="substring(//saml:Attribute[@AttributeName='Geburtsdatum']/saml:AttributeValue,1,4)"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='OIDTextualDescription']">
									<tr>
										<td class="italicstyle">Rolle:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='OIDTextualDescription']/saml:AttributeValue"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='mandateReferenceValue']">
									<tr>
										<td class="italicstyle">Vollmacht:</td>
										<td class="normalstyle">
											<xsl:text>Ich melde mich in Vertretung an. Im nächsten Schritt wird mir eine Liste der für mich verfügbaren Vertretungsverhältnisse angezeigt, aus denen ich eines auswählen werde.</xsl:text>
										</td>
									</tr>
								</xsl:if>
							</table>
							<p class="titlestyle">Daten zur Anwendung</p>
							<table class="parameters">
								<tr>
									<td class="italicstyle">Name:</td>
									<td class="normalstyle">
										<xsl:value-of select="//saml:Attribute[@AttributeName='oaFriendlyName']/saml:AttributeValue"/>
									</td>
								</tr>
								<tr>
									<td class="italicstyle">Staat:</td>
									<td class="normalstyle">Österreich</td>
								</tr>
							</table>
							<p class="titlestyle">Technische Parameter</p>
							<table class="parameters">
								<tr>
									<td class="italicstyle">URL:</td>
									<td class="normalstyle">
										<xsl:value-of select="//saml:Attribute[@AttributeName='OA']/saml:AttributeValue"/>
									</td>
								</tr>
								<xsl:if test="//saml:Attribute[@AttributeName='Geschaeftsbereich']">
									<tr>
										<td class="italicstyle">Bereich:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='Geschaeftsbereich']/saml:AttributeValue"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='mandateReferenceValue']">
									<tr>
										<td class="italicstyle">
											Vollmachten-Referenz:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='mandateReferenceValue']"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='IdentityLinkDomainIdentifierType']">
									<tr>
										<td class="italicstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='IdentityLinkDomainIdentifierType']"/>:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='wbPK']/saml:AttributeValue/pr:Identification/pr:Type"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='bPK'] or //saml:Attribute[@AttributeName='wbPK']">
									<tr>
										<td class="italicstyle">Identifikator:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='bPK']/saml:AttributeValue/pr:Identification/pr:Value"/>
											<xsl:value-of select="//saml:Attribute[@AttributeName='wbPK']/saml:AttributeValue/pr:Identification/pr:Value"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='OIDTextualDescription']">
									<tr>
										<td class="italicstyle">OID:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='OID']/saml:AttributeValue"/>
										</td>
									</tr>
								</xsl:if>
								<xsl:if test="//saml:Attribute[@AttributeName='HPI']">
									<tr>
										<td class="italicstyle">HPI:</td>
										<td class="normalstyle">
											<xsl:value-of select="//saml:Attribute[@AttributeName='HPI']/saml:AttributeValue"/>
										</td>
									</tr>
								</xsl:if>
								<tr>
									<td class="italicstyle">Datum:</td>
									<td class="normalstyle">
										<xsl:value-of select="substring(//@IssueInstant,9,2)"/>
										<xsl:text>.</xsl:text>
										<xsl:value-of select="substring(//@IssueInstant,6,2)"/>
										<xsl:text>.</xsl:text>
										<xsl:value-of select="substring(//@IssueInstant,1,4)"/>
									</td>
								</tr>
								<tr>
									<td class="italicstyle">Uhrzeit:</td>
									<td class="normalstyle">
										<xsl:value-of select="substring(//@IssueInstant,12,2)"/>
										<xsl:text>:</xsl:text>
										<xsl:value-of select="substring(//@IssueInstant,15,2)"/>
										<xsl:text>:</xsl:text>
										<xsl:value-of select="substring(//@IssueInstant,18,2)"/>
									</td>
								</tr>
							</table>
						</body>
					</html>
				</xsl:template>
			</xsl:stylesheet>
		</dsig:Transform>
		<dsig:Transform Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments"/>
	</dsig:Transforms>
	<sl:FinalDataMetaInfo>
		<sl:MimeType>application/xhtml+xml</sl:MimeType>
	</sl:FinalDataMetaInfo>
</sl:TransformsInfo>
 </sl:DataObjectInfo>
 <sl:SignatureInfo>
  <sl:SignatureEnvironment>
   <sl:XMLContent><saml:Assertion xmlns:saml='urn:oasis:names:tc:SAML:1.0:assertion' xmlns:pr="http://reference.e-government.gv.at/namespace/persondata/20020228#" MajorVersion='1' MinorVersion='0' AssertionID='any' Issuer='Gregor Johannes Weissensteiner' IssueInstant='2018-03-12T16:03:43Z'>
 <saml:AttributeStatement>
   <saml:Subject>
     <saml:NameIdentifier>https://moaid.bmi.gv.at/moa-id-auth</saml:NameIdentifier>
   </saml:Subject>
   <saml:Attribute AttributeName='Geschaeftsbereich' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue>ZP (Personenidentität und Bürgerrechte (zur Person))</saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='OA' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue>https://citizen.bmi.gv.at</saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='Geburtsdatum' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue>1988-12-29</saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='SpecialText' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue></saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='UniqueTokken' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue>s3230313831323033577a3c745db065cba13785</saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='bPK' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue><pr:Identification xmlns:pr="http://reference.e-government.gv.at/namespace/persondata/20020228#">
         <pr:Value>mc06WsMnr/EsUgj8EpXgxRioHp8=</pr:Value>
         <pr:Type>urn:publicid:gv.at:cdid+bpk</pr:Type>
       </pr:Identification></saml:AttributeValue>
   </saml:Attribute>
   <saml:Attribute AttributeName='oaFriendlyName' AttributeNamespace='http://reference.e-government.gv.at/namespace/moa/20020822#'>
     <saml:AttributeValue>Bürgerportal - Neuer Name</saml:AttributeValue>
   </saml:Attribute>
 </saml:AttributeStatement>
</saml:Assertion></sl:XMLContent>
  </sl:SignatureEnvironment>
  <sl:SignatureLocation xmlns:saml='urn:oasis:names:tc:SAML:1.0:assertion' Index='2'>/saml:Assertion</sl:SignatureLocation>
 </sl:SignatureInfo>
</sl:CreateXMLSignatureRequest>"; + byte[] authBlock = Base64.getDecoder().decode(b64AuthBlock); + + new String(authBlock, "UTF-8"); + new String(authBlock, "ISO-8859-1"); + new String(authBlock, "Cp850"); + new String(authBlock, "Cp1252"); + + + + String keyStoreFile = "F:/Projekte/configs/mis/egiz.gv.at-816-2018-06-07.jks"; char[] keyStorePassword = "OSgmSn!".toCharArray(); char[] keyPassword = "nichts".toCharArray(); |