/****************************************************************************
* Copyright (C) 2012 HS Coburg.
* All rights reserved.
* Contact: ecsec GmbH (info@ecsec.de)
*
* This file is part of the Open eCard App.
*
* GNU General Public License Usage
* This file may be used under the terms of the GNU General Public
* License version 3.0 as published by the Free Software Foundation
* and appearing in the file LICENSE.GPL included in the packaging of
* this file. Please review the following information to ensure the
* GNU General Public License version 3.0 requirements will be met:
* http://www.gnu.org/copyleft/gpl.html.
*
* Other Usage
* Alternatively, this file may be used in accordance with the terms
* and conditions contained in a signed written agreement between
* you and ecsec GmbH.
*
***************************************************************************/
package org.openecard.common.sal.anytype;
import iso.std.iso_iec._24727.tech.schema.CardInfoType;
import iso.std.iso_iec._24727.tech.schema.DifferentialIdentityType;
import org.openecard.common.ECardConstants;
import org.openecard.common.sal.state.cif.CardApplicationWrapper;
import org.openecard.common.sal.state.cif.CardInfoWrapper;
import org.openecard.common.util.StringUtils;
import org.openecard.recognition.CardRecognition;
import org.testng.annotations.Test;
import static org.testng.Assert.*;
/**
*
* @author Dirk Petrautzki <petrautzki@hs-coburg.de>
*/
public class CryptoMarkerTypeTest {
private static final String cardType = "http://ws.gematik.de/egk/1.0.0";
private static final byte[] esignApplication = StringUtils.toByteArray("A000000167455349474E");
private static final String didName = "PrK.CH.AUT_signPKCS1_V1_5";
/**
* Simple test for CryptoMarkerType. After getting the CryptoMarker for the PrK.CH.AUT_signPKCS1_V1_5 DID in the the
* ESIGN application we check if the get-methods return the expected values.
*
* @throws Exception
* when something in this test went unexpectedly wrong
*/
@Test
public void testCryptoMarkerType() throws Exception {
CardRecognition recognition = new CardRecognition(null, null);
CardInfoType cardInfo = recognition.getCardInfo(cardType);
CardInfoWrapper wrapper = new CardInfoWrapper(cardInfo);
CardApplicationWrapper app = wrapper.getCardApplication(esignApplication);
DifferentialIdentityType diffId = app.getDIDInfo(didName).getDIDInfo().getDifferentialIdentity();
CryptoMarkerType cryptoMarker = new CryptoMarkerType(diffId.getDIDMarker().getCryptoMarker());
assertTrue(cryptoMarker.getAlgorithmInfo().getSupportedOperations().size() > 0);
assertEquals(cryptoMarker.getSignatureGenerationInfo(), new String[] { "MSE_KEY", "PSO_CDS" });
assertEquals(cryptoMarker.getCryptoKeyInfo().getKeyRef().getKeyRef(), new byte[] { 0x02 });
assertEquals(cryptoMarker.getAlgorithmInfo().getAlgorithmIdentifier().getAlgorithm(),
"urn:oid:1.2.840.113549.1.1");
assertNull(cryptoMarker.getLegacyKeyName());
assertNull(cryptoMarker.getHashGenerationInfo());
assertEquals(cryptoMarker.getCertificateRef().getDataSetName(), "EF.C.CH.AUT");
// assertEquals(cryptoMarker.getStateInfo(), "");
assertEquals(cryptoMarker.getProtocol(), ECardConstants.Protocol.GENERIC_CRYPTO);
}
}