1561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/* 2561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * Licensed to the Apache Software Foundation (ASF) under one or more 3561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * contributor license agreements. See the NOTICE file distributed with 4561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * this work for additional information regarding copyright ownership. 5561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * The ASF licenses this file to You under the Apache License, Version 2.0 6561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * (the "License"); you may not use this file except in compliance with 7561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * the License. You may obtain a copy of the License at 8561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * 9561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * http://www.apache.org/licenses/LICENSE-2.0 10561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * 11561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * Unless required by applicable law or agreed to in writing, software 12561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * distributed under the License is distributed on an "AS IS" BASIS, 13561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * See the License for the specific language governing permissions and 15561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * limitations under the License. 16561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */ 17561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 18561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespackage org.apache.harmony.security.tests.x509.tsp; 19561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 20561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.io.IOException; 21561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.math.BigInteger; 22561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.util.Arrays; 23561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.util.Collections; 24561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.util.Date; 25561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 26561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport junit.framework.TestCase; 27561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 28561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.asn1.ASN1Integer; 29561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.asn1.ASN1OctetString; 30561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.pkcs7.ContentInfo; 31561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.pkcs7.SignedData; 32561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.pkcs7.SignerInfo; 33561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x501.Name; 34561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.AlgorithmIdentifier; 35561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.Extension; 36561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.Extensions; 37561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.GeneralName; 38561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.MessageImprint; 39561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.PKIFailureInfo; 40561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.PKIStatus; 41561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.PKIStatusInfo; 42561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.TSTInfo; 43561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport org.apache.harmony.security.x509.tsp.TimeStampResp; 44561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 45561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespublic class TimeStampRespTest extends TestCase { 46561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 47561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes /** 48561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * @throws IOException 49561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * @tests 'org.apache.harmony.security.x509.tsp.TimeStampResp.getEncoded()' 50561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */ 51561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes public void testGetEncoded() throws IOException { 52561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes String statusString = "statusString"; 53561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes PKIStatusInfo status = new PKIStatusInfo(PKIStatus.REJECTION, 54561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes Collections.singletonList(statusString), 55561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes PKIFailureInfo.BAD_REQUEST); 56561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 57561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 58561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // creating TimeStampToken 59561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes String policy = "1.2.3.4.5"; 60561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes String sha1 = "1.3.14.3.2.26"; 61561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes MessageImprint msgImprint = new MessageImprint(new AlgorithmIdentifier( 62561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes sha1), new byte[20]); 63561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes Date genTime = new Date(); 64561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes BigInteger nonce = BigInteger.valueOf(1234567890L); 65561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // accuracy is 1 second 66561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes int[] accuracy = new int[] { 1, 0, 0 }; 67561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes GeneralName tsa = new GeneralName(new Name("CN=AnAuthority")); 68561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes Extensions exts = new Extensions(); 69561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // Time-Stamping extension OID: as defined in RFC 3161 70561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes int[] timeStampingExtOID = new int[] { 1, 3, 6, 1, 5, 5, 7, 3, 8 }; 71561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes byte[] timeStampingExtValue = new byte[] { (byte) 1, (byte) 2, (byte) 3 }; 72561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes Extension ext = new Extension(timeStampingExtOID, true, 73561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes timeStampingExtValue); 74561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes exts.addExtension(ext); 75561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 76561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes TSTInfo tSTInfo = new TSTInfo(1, policy, msgImprint, BigInteger.TEN, 77561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes genTime, accuracy, Boolean.FALSE, nonce, tsa, exts); 78561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 79561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes Object[] issuerAndSerialNumber = new Object[] { new Name("CN=issuer"), 80561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes ASN1Integer.fromIntValue(12345) }; 81561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // SHA1withDSA OID 82561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes String sha1dsa = "1.2.840.10040.4.3"; 83561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes SignerInfo sigInfo = new SignerInfo(1, issuerAndSerialNumber, 84561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes new AlgorithmIdentifier(sha1), null, new AlgorithmIdentifier( 85561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes sha1dsa), new byte[20], null); 86561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // TSTInfo OID according to RFC 3161 87561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes int[] tSTInfoOid = new int[] { 1, 2, 840, 113549, 1, 9, 16, 1, 4 }; 88561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes ContentInfo tSTInfoEncoded = new ContentInfo(tSTInfoOid, 89561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes ASN1OctetString.getInstance().encode( 90561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes TSTInfo.ASN1.encode(tSTInfo))); 91561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes SignedData tokenContent = new SignedData(1, Collections 92561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes .singletonList(new AlgorithmIdentifier(sha1)), tSTInfoEncoded, 93561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes null, null, Collections.singletonList(sigInfo)); 94561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes ContentInfo timeStampToken = new ContentInfo(ContentInfo.SIGNED_DATA, 95561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes tokenContent); 96561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 97561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes TimeStampResp response = new TimeStampResp(status, timeStampToken); 98561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 99561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes byte [] encoding = TimeStampResp.ASN1.encode(response); 100561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes TimeStampResp decoded = (TimeStampResp) TimeStampResp.ASN1 101561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes .decode(encoding); 102561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 103561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes // deeper checks are performed in the corresponding unit tests 104561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes assertTrue("Decoded status is incorrect", Arrays.equals( 105561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes PKIStatusInfo.ASN1.encode(status), PKIStatusInfo.ASN1 106561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes .encode(decoded.getStatus()))); 107561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes assertTrue("Decoded timeStampToken is incorrect", Arrays.equals( 108561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes timeStampToken.getEncoded(), decoded.getTimeStampToken() 109561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes .getEncoded())); 110561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes } 111561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes} 112561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes 113