diff options
Diffstat (limited to 'eidas_modules/authmodule-eIDAS-v2/src/test')
2 files changed, 192 insertions, 0 deletions
| diff --git a/eidas_modules/authmodule-eIDAS-v2/src/test/java/at/gv/egiz/test/eidas/specific/modules/authmodule_eIDASv2/SZRClientTest.java b/eidas_modules/authmodule-eIDAS-v2/src/test/java/at/gv/egiz/test/eidas/specific/modules/authmodule_eIDASv2/SZRClientTest.java new file mode 100644 index 00000000..33050b12 --- /dev/null +++ b/eidas_modules/authmodule-eIDAS-v2/src/test/java/at/gv/egiz/test/eidas/specific/modules/authmodule_eIDASv2/SZRClientTest.java @@ -0,0 +1,172 @@ +package at.gv.egiz.test.eidas.specific.modules.authmodule_eIDASv2; + +import java.io.IOException; +import java.math.BigInteger; +import java.security.InvalidKeyException; +import java.security.NoSuchProviderException; +import java.security.PublicKey; +import java.security.interfaces.RSAPublicKey; +import java.util.ArrayList; +import java.util.List; + +import org.apache.commons.lang3.StringUtils; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.test.context.ContextConfiguration; +import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; +import org.springframework.util.Base64Utils; +import org.w3._2000._09.xmldsig.KeyValueType; +import org.w3._2000._09.xmldsig.RSAKeyValueType; +import org.w3c.dom.Element; + +import at.gv.e_government.reference.namespace.persondata._20020228.PersonNameType; +import at.gv.e_government.reference.namespace.persondata._20020228.PhysicalPersonType; +import at.gv.egiz.eaaf.core.api.data.EAAFConstants; +import at.gv.egiz.eaaf.core.api.idp.IConfiguration; +import at.gv.egiz.eaaf.core.api.idp.auth.data.IIdentityLink; +import at.gv.egiz.eaaf.core.exceptions.EAAFParserException; +import at.gv.egiz.eaaf.core.impl.data.Trible; +import at.gv.egiz.eaaf.core.impl.idp.auth.data.SimpleIdentityLinkAssertionParser; +import at.gv.egiz.eidas.specific.modules.authmodule_eIDASv2.Constants; +import at.gv.egiz.eidas.specific.modules.authmodule_eIDASv2.exception.SZRCommunicationException; +import at.gv.egiz.eidas.specific.modules.authmodule_eIDASv2.szr.SZRClient; +import at.gv.egiz.eidas.specific.modules.authmodule_eIDASv2.utils.eIDASResponseUtils; +import szrservices.IdentityLinkType; +import szrservices.PersonInfoType; +import szrservices.SZRException_Exception; +import szrservices.TravelDocumentType; + +@RunWith(SpringJUnit4ClassRunner.class) +@ContextConfiguration("/SpringTest-context_basic_test.xml") +public class SZRClientTest { +	private static final Logger log = LoggerFactory.getLogger(SZRClientTest.class); +	 +	@Autowired SZRClient szrClient; +	@Autowired IConfiguration basicConfig; +	 +	private static final String givenName = "Franz"; +	private static final String familyName = "Mustermann"; +	private static final String dateOfBirth = "1987-05-05"; +	private static final String eIDASeID = "IS/AT/123456789ABCDE"; +	 +	private static final String DUMMY_TARGET = EAAFConstants.URN_PREFIX_CDID + "ZP"; +	 +	@Test +	public void dummyTest() {  +				 +	} +	 +	 +	//@Test +	public void getIdentityLink() throws SZRException_Exception, EAAFParserException, NoSuchProviderException, IOException, InvalidKeyException, SZRCommunicationException { +		log.debug("Starting connecting SZR Gateway");											 +		IdentityLinkType result = szrClient.getIdentityLink( +									getPersonInfo(),  +									dummyCodeForKeys(),  +									basicConfig.getBasicMOAIDConfigurationBoolean( +											Constants.CONIG_PROPS_EIDAS_SZRCLIENT_DEBUG_INSERTERNB,  +											true) +									); + +		Element idlFromSZR = (Element)result.getAssertion();			 +		IIdentityLink identityLink = new SimpleIdentityLinkAssertionParser(idlFromSZR).parseIdentityLink(); +		if (identityLink == null) +			throw new SZRCommunicationException("ernb.00", new Object[] {"bPK is null or empty"}); +			 +	} +	 +	//@Test +	public void getbPKTest() throws SZRException_Exception, SZRCommunicationException { +		String bPK = szrClient.getBPK(getPersonInfo(), DUMMY_TARGET,  +				basicConfig.getBasicConfiguration( +				Constants.CONIG_PROPS_EIDAS_SZRCLIENT_PARAMS_VKZ,  +				"no VKZ defined")); +		 +		if (StringUtils.isEmpty(bPK)) +			throw new SZRCommunicationException("ernb.01", new Object[] {"bPK is null or empty"}); +		 +		 +	} +	 +	private PersonInfoType getPersonInfo() { +		PersonInfoType personInfo = new PersonInfoType(); +		PersonNameType personName = new PersonNameType(); +		PhysicalPersonType naturalPerson = new PhysicalPersonType(); +		TravelDocumentType eDocument = new TravelDocumentType();				 +		 +		naturalPerson.setName(personName ); +		personInfo.setPerson(naturalPerson ); +		personInfo.setTravelDocument(eDocument ); +						 +		//parse some eID attributes +		Trible<String, String, String> eIdentifier =  +				eIDASResponseUtils.parseEidasPersonalIdentifier((String)eIDASeID); +		String uniqueId = (String)eIDASeID; +		String citizenCountry = eIdentifier.getFirst(); +					 +		//person information +		personName.setFamilyName((String)familyName); +		personName.setGivenName((String)givenName); +		naturalPerson.setDateOfBirth(dateOfBirth); +		eDocument.setIssuingCountry(citizenCountry); +		eDocument.setDocumentNumber(uniqueId); +		 +		//eID document information								 +		eDocument.setDocumentType(basicConfig.getBasicConfiguration( +				Constants.CONIG_PROPS_EIDAS_SZRCLIENT_PARAMS_EDOCUMENTTYPE,  +				Constants.SZR_CONSTANTS_DEFAULT_DOCUMENT_TYPE)); +		 +		//TODO: that should be removed +		eDocument.setIssueDate(basicConfig.getBasicConfiguration( +				Constants.CONIG_PROPS_EIDAS_SZRCLIENT_PARAMS_ISSUING_DATE,  +				Constants.SZR_CONSTANTS_DEFAULT_ISSUING_DATE)); +		eDocument.setIssuingAuthority(basicConfig.getBasicConfiguration( +				Constants.CONIG_PROPS_EIDAS_SZRCLIENT_PARAMS_ISSUING_AUTHORITY,  +				Constants.SZR_CONSTANTS_DEFAULT_ISSUING_AUTHORITY)); +		 +		return personInfo; +	} + + +	private List<KeyValueType> dummyCodeForKeys() throws IOException, NoSuchProviderException, InvalidKeyException { +		if (basicConfig.getBasicMOAIDConfigurationBoolean( +				Constants.CONIG_PROPS_EIDAS_SZRCLIENT_PARAMS_KEYS_USEDUMMY,  +				false)) { +			List<KeyValueType> keyvalueList = new ArrayList<KeyValueType>(); +			try { +				//Security.addProvider(new BouncyCastleProvider()); +				//PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(Constants.SZR_CONSTANTS_DEFAULT_PUBL_KEY); +				//KeyFactory kf = KeyFactory.getInstance("RSA", "BC"); +										 +				//PublicKey pb = kf.generatePublic(spec); +				PublicKey pb = new iaik.security.rsa.RSAPublicKey(Constants.SZR_CONSTANTS_DEFAULT_PUBL_KEY); +				 +				RSAPublicKey rsapb = (RSAPublicKey)pb;	         +				BigInteger modulus = rsapb.getModulus(); +				BigInteger exponent = rsapb.getPublicExponent(); +		           	            +				// set key values +				RSAKeyValueType rsa = new RSAKeyValueType(); +				rsa.setExponent(new String(Base64Utils.encode(exponent.toByteArray()))); +				rsa.setModulus(new String(Base64Utils.encode(modulus.toByteArray()))); +						 +				KeyValueType key = new KeyValueType(); +				key.setRSAKeyValue(rsa); +							 +				keyvalueList.add(key); +			 +				return keyvalueList; +			} catch (Exception e) { +				log.error("TestCode has an internal ERROR", e); +				throw e; +			} +			 +		} +		 +		return null; +		 +	} +} diff --git a/eidas_modules/authmodule-eIDAS-v2/src/test/resources/SpringTest-context_basic_test.xml b/eidas_modules/authmodule-eIDAS-v2/src/test/resources/SpringTest-context_basic_test.xml new file mode 100644 index 00000000..b381a0e9 --- /dev/null +++ b/eidas_modules/authmodule-eIDAS-v2/src/test/resources/SpringTest-context_basic_test.xml @@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="UTF-8"?> +<beans xmlns="http://www.springframework.org/schema/beans" +	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" +	xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" +	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd +		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd +		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd +		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> + +	<context:annotation-config /> + +	<bean id="SZRClientForeIDAS" +		class="at.gv.egiz.eidas.specific.modules.authmodule_eIDASv2.szr.SZRClient" /> +  + 	<bean id="BasicMSSpecificNodeConfig"  + 			class="at.gv.egiz.eidas.specific.connector.config.BasicConfigurationProvider"> +		<constructor-arg value="#{systemProperties['eidas.ms.configuration'] != null ? systemProperties['eidas.ms.configuration'] : 'file:/F:/Projekte/configs/ms_connector/default_config.properties' }"/> +	</bean>	 + +</beans>
\ No newline at end of file | 
