001/**
002 * Copyright 2005-2015 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package org.kuali.rice.ksb.security.credentials;
017
018import org.junit.Before;
019import org.junit.Test;
020
021import java.math.BigInteger;
022import java.security.InvalidKeyException;
023import java.security.NoSuchAlgorithmException;
024import java.security.NoSuchProviderException;
025import java.security.Principal;
026import java.security.PublicKey;
027import java.security.SignatureException;
028import java.security.cert.CertificateEncodingException;
029import java.security.cert.CertificateException;
030import java.security.cert.CertificateExpiredException;
031import java.security.cert.CertificateNotYetValidException;
032import java.security.cert.X509Certificate;
033import java.util.Date;
034import java.util.Set;
035
036import static org.junit.Assert.assertEquals;
037import static org.junit.Assert.assertNotNull;
038/**
039 * 
040 * @author Kuali Rice Team (rice.collab@kuali.org)
041 * @since 0.9
042 *
043 */
044public class X509CredentialsSourceTest {
045
046        private X509CredentialsSource credentialsSource;
047        
048        private X509Certificate cert = new KualiX509Certificate();
049
050    @Before
051        public void setUp() throws Exception {
052                this.credentialsSource = new X509CredentialsSource(cert);
053        }
054
055    @Test
056        public void testX509Certificate() {
057                final X509Credentials context = (X509Credentials) this.credentialsSource.getCredentials("test");
058                assertNotNull(context);
059                final X509Certificate cert = context.getX509Certificate();
060                
061                assertEquals(this.cert, cert);
062        }
063        
064        public static class KualiX509Certificate extends X509Certificate {
065                
066                protected KualiX509Certificate() {
067                        // nothing to do
068                }
069
070                public void checkValidity() throws CertificateExpiredException, CertificateNotYetValidException {
071                        // nothing to do
072                }
073
074                public void checkValidity(Date date) throws CertificateExpiredException, CertificateNotYetValidException {
075                        // nothing to do
076                }
077
078                public int getBasicConstraints() {
079                        return 0;
080                }
081
082                public Principal getIssuerDN() {
083                        return null;
084                }
085
086                public boolean[] getIssuerUniqueID() {
087                        return null;
088                }
089
090                public boolean[] getKeyUsage() {
091                        return null;
092                }
093
094                public Date getNotAfter() {
095                        return null;
096                }
097
098                public Date getNotBefore() {
099                        return null;
100                }
101
102                public BigInteger getSerialNumber() {
103                        return null;
104                }
105
106                public String getSigAlgName() {
107                        return null;
108                }
109
110                public String getSigAlgOID() {
111                        return null;
112                }
113
114                public byte[] getSigAlgParams() {
115                        return null;
116                }
117
118                public byte[] getSignature() {
119                        return null;
120                }
121
122                public Principal getSubjectDN() {
123                        return null;
124                }
125
126                public boolean[] getSubjectUniqueID() {
127                        return null;
128                }
129
130                public byte[] getTBSCertificate() throws CertificateEncodingException {
131                        return null;
132                }
133
134                public int getVersion() {
135                        return 0;
136                }
137
138                public Set<String> getCriticalExtensionOIDs() {
139                        return null;
140                }
141
142                public byte[] getExtensionValue(String arg0) {
143                        return null;
144                }
145
146                public Set<String> getNonCriticalExtensionOIDs() {
147                        return null;
148                }
149
150                public boolean hasUnsupportedCriticalExtension() {
151                        return false;
152                }
153
154                public byte[] getEncoded() throws CertificateEncodingException {
155                        return null;
156                }
157
158                public PublicKey getPublicKey() {
159                        return null;
160                }
161
162                public String toString() {
163                        return null;
164                }
165
166                public void verify(PublicKey arg0, String arg1) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException {
167                        // nothing to do
168                }
169
170                public void verify(PublicKey arg0) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException {
171                        // nothing to do
172                }
173        }
174}