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    /**
488d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath     * @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);
568d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath
578d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath
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);
788d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath
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(
858d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath                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);
968d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath
97561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        TimeStampResp response = new TimeStampResp(status, timeStampToken);
988d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath
998d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath        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
1068d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath                .encode(decoded.getStatus())));
107561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertTrue("Decoded timeStampToken is incorrect", Arrays.equals(
108561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                timeStampToken.getEncoded(), decoded.getTimeStampToken()
1098d8858e39800de641b50f6e8e864af9cf68bedeaNarayan Kamath                .getEncoded()));
110561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    }
111561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes}
112561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
113