/**
* Copyright (c) Istituto Nazionale di Fisica Nucleare, 2006-2014.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.italiangrid.voms.test.utils;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.security.KeyStoreException;
import java.security.cert.CertificateException;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import org.italiangrid.voms.VOMSValidators;
import org.italiangrid.voms.ac.VOMSACValidator;
import org.italiangrid.voms.ac.impl.DefaultVOMSValidationStrategy;
import org.italiangrid.voms.ac.impl.DefaultVOMSValidator;
import org.italiangrid.voms.ac.impl.LocalHostnameResolver;
import org.italiangrid.voms.request.VOMSACService;
import org.italiangrid.voms.request.VOMSProtocol;
import org.italiangrid.voms.request.VOMSServerInfo;
import org.italiangrid.voms.request.VOMSServerInfoStore;
import org.italiangrid.voms.request.impl.DefaultVOMSACService;
import org.italiangrid.voms.request.impl.DefaultVOMSServerInfo;
import org.italiangrid.voms.store.VOMSTrustStore;
import org.italiangrid.voms.store.impl.DefaultVOMSTrustStore;
import org.italiangrid.voms.util.CertificateValidatorBuilder;
import org.mockito.Mockito;
import eu.emi.security.authn.x509.X509CertChainValidatorExt;
import eu.emi.security.authn.x509.impl.PEMCredential;
public class Utils implements Fixture {
private Utils() {
}
public static VOMSACService buildACService(VOMSProtocol main,
VOMSProtocol fallback) throws Exception {
VOMSServerInfoStore store = Mockito.mock(VOMSServerInfoStore.class);
Set<VOMSServerInfo> testVOEndpoints = new HashSet<VOMSServerInfo>();
testVOEndpoints.add(getTestVOEndpoint());
Mockito.when(store.getVOMSServerInfo("test.vo"))
.thenReturn(testVOEndpoints);
DefaultVOMSACService acService = new DefaultVOMSACService.Builder(
getCertificateValidator()).serverInfoStore(store)
.requestListener(LogListener.INSTANCE).httpProtocol(main)
.legacyProtocol(fallback).build();
return acService;
}
public static VOMSACService buildACService(VOMSProtocol protocol)
throws Exception {
return buildACService(protocol, null);
}
public static VOMSServerInfo getTestVOEndpoint() throws URISyntaxException {
DefaultVOMSServerInfo si = new DefaultVOMSServerInfo();
si.setAlias("test.vo");
si.setVoName("test.vo");
si.setURL(new URI("http://localhost:15000"));
si.setVOMSServerDN("Not checked");
return si;
}
public static X509CertChainValidatorExt getCertificateValidator() {
return new CertificateValidatorBuilder().trustAnchorsDir(trustAnchorsDir)
.build();
}
public static VOMSACValidator getVOMSValidator(LocalHostnameResolver resolver) {
X509CertChainValidatorExt validator = new CertificateValidatorBuilder()
.trustAnchorsDir(trustAnchorsDir).build();
VOMSTrustStore ts = new DefaultVOMSTrustStore(Arrays.asList(vomsdir));
return new DefaultVOMSValidator.Builder().validationStrategy(
new DefaultVOMSValidationStrategy(ts, validator, resolver)).build();
}
public static VOMSACValidator getVOMSValidator() {
X509CertChainValidatorExt validator = new CertificateValidatorBuilder()
.trustAnchorsDir(trustAnchorsDir).build();
return VOMSValidators.newValidator(
new DefaultVOMSTrustStore(Arrays.asList(vomsdir)), validator);
}
public static VOMSACValidator getVOMSValidator(String vomsDir) {
X509CertChainValidatorExt validator = new CertificateValidatorBuilder()
.trustAnchorsDir(trustAnchorsDir).build();
return VOMSValidators.newValidator(
new DefaultVOMSTrustStore(Arrays.asList(vomsDir)), validator);
}
public static PEMCredential getAACredential() throws KeyStoreException,
CertificateException, IOException {
return new PEMCredential(aaKey, aaCert, keyPassword.toCharArray());
}
public static PEMCredential getAACredential2() throws KeyStoreException,
CertificateException, IOException {
return new PEMCredential(aaKey2, aaCert2, keyPassword.toCharArray());
}
public static PEMCredential getTestUserCredential() throws KeyStoreException,
CertificateException, IOException {
return new PEMCredential(holderKey, holderCert, keyPassword.toCharArray());
}
public static PEMCredential getTest1UserCredential()
throws KeyStoreException, CertificateException, IOException {
return new PEMCredential(holderKey2, holderCert2, keyPassword.toCharArray());
}
public static PEMCredential getExpiredCredential() throws KeyStoreException,
CertificateException, IOException {
return new PEMCredential(expiredKey, expiredCert, keyPassword.toCharArray());
}
public static VOMSAA getVOMSAA() throws KeyStoreException,
CertificateException, IOException {
return new VOMSAA(getAACredential(), defaultVO, defaultVOHost,
defaultVOPort);
}
public static Date getDate(int year, int month, int day, int hour,
int minute, int second) {
Calendar cal = Calendar.getInstance();
cal.set(year, month, day, hour, minute, second);
return cal.getTime();
}
public static Date getDate(int year, int month, int day) {
Calendar cal = Calendar.getInstance();
cal.set(year, month, day);
return cal.getTime();
}
}