//* Licensed Materials - Property of *
//* IBM *
//* Alexandra Instituttet A/S *
//* *
//* eu.abc4trust.pabce.1.34 *
//* *
//* (C) Copyright IBM Corp. 2014. All Rights Reserved. *
//* (C) Copyright Alexandra Instituttet A/S, Denmark. 2014. All *
//* Rights Reserved. *
//* US Government Users Restricted Rights - Use, duplication or *
//* disclosure restricted by GSA ADP Schedule Contract with IBM Corp. *
//* *
//* This file is 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 eu.abc4trust.abce.testharness;
import java.util.Random;
import com.google.inject.AbstractModule;
import com.google.inject.Module;
import com.google.inject.Singleton;
import com.google.inject.util.Modules;
import eu.abc4trust.cryptoEngine.issuer.CryptoEngineReIssuer;
import eu.abc4trust.cryptoEngine.issuer.MockCryptoEngineReIssuer;
import eu.abc4trust.guice.ProductionModuleFactory;
import eu.abc4trust.guice.ProductionModuleFactory.CryptoEngine;
import eu.abc4trust.guice.configuration.AbceConfiguration;
import eu.abc4trust.guice.configuration.AbceConfigurationImpl;
import eu.abc4trust.revocationProxy.InMemoryCommunicationStrategy;
import eu.abc4trust.revocationProxy.RevocationProxyCommunicationStrategy;
import eu.abc4trust.revocationProxy.revauth.RevocationProxyAuthority;
import eu.abc4trust.util.TemporaryFileFactory;
public class IntegrationModuleFactory {
public static Module newModule(Random random, CryptoEngine cryptoEngine) {
AbceConfiguration config = generateDefaultConfiguration(random);
Module m = ProductionModuleFactory.newModule(config, cryptoEngine);
return Modules.override(m).with(new AbstractModule() {
@Override
protected void configure() {
this.bind(RevocationProxyCommunicationStrategy.class)
.to(InMemoryCommunicationStrategy.class).in(Singleton.class);
this.bind(CryptoEngineReIssuer.class)
.to(MockCryptoEngineReIssuer.class).in(Singleton.class);
}
});
}
public static Module newModule(Random random) {
return newModule(random, CryptoEngine.UPROVE);
}
public static Module newModule(Random random, RevocationProxyAuthority revocationProxyAuthority) {
return newModule(random, CryptoEngine.UPROVE, revocationProxyAuthority);
}
// public static Module newModule(Random random, CryptoEngine cryptoEngine,
// final RevocationProxyAuthority revocationProxyAuthority) {
// return newModule(random, cryptoEngine, null, revocationProxyAuthority);
// }
public static Module newModule(Random random, CryptoEngine cryptoEngine,
final RevocationProxyAuthority revocationProxyAuthority) {
Module m = newModule(random, cryptoEngine);
return Modules.override(m).with(new AbstractModule() {
@Override
protected void configure() {
this.bind(RevocationProxyAuthority.class).toInstance(revocationProxyAuthority);
}
});
}
private static AbceConfiguration generateDefaultConfiguration(Random random) {
AbceConfigurationImpl config = new AbceConfigurationImpl();
config.setSecretStorageFile(TemporaryFileFactory.createTemporaryFile());
config.setCredentialFile(TemporaryFileFactory.createTemporaryFile());
config.setKeyStorageFile(TemporaryFileFactory.createTemporaryFile());
config.setPseudonymsFile(TemporaryFileFactory.createTemporaryFile());
config.setTokensFile(TemporaryFileFactory.createTemporaryFile());
config.setImageCacheDir(TemporaryFileFactory.createTemporaryDir());
config.setIssuerSecretKeyFile(TemporaryFileFactory.createTemporaryFile());
config.setIssuerLogFile(TemporaryFileFactory.createTemporaryFile());
config.setInspectorSecretKeyFile(TemporaryFileFactory.createTemporaryFile());
config.setRevocationAuthoritySecretStorageFile(TemporaryFileFactory.createTemporaryFile());
config.setRevocationAuthorityStorageFile(TemporaryFileFactory.createTemporaryFile());
config.setPrng(random);
config.setDefaultImagePath("file://error");
config.setUProveRetryTimeout(10);
config.setUProveNumberOfCredentialsToGenerate(3);
return config;
}
}