adorsys/datasafe

View on GitHub
datasafe-business/src/main/java/de/adorsys/datasafe/business/impl/directory/DefaultKeystoreCacheModule.java

Summary

Maintainability
A
0 mins
Test Coverage
package de.adorsys.datasafe.business.impl.directory;

import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
import dagger.Module;
import dagger.Provides;
import de.adorsys.datasafe.directory.impl.profile.keys.DefaultKeyStoreCacheRuntimeDelegatable;
import de.adorsys.datasafe.directory.impl.profile.keys.KeyStoreCache;
import de.adorsys.datasafe.encrypiton.api.types.UserID;
import de.adorsys.datasafe.encrypiton.api.types.keystore.PublicKeyIDWithPublicKey;
import de.adorsys.datasafe.types.api.context.overrides.OverridesRegistry;

import javax.annotation.Nullable;
import javax.inject.Singleton;
import java.security.KeyStore;
import java.util.List;
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier;

@Module
public abstract class DefaultKeystoreCacheModule {

    /**
     * Default keystore and public key Guava-based cache. If one can't afford that some instances
     * may not see that storage access credentials were removed (for some time window they will be available)
     * or keystore password has changed, they can use any distributed cache available. But for most use cases
     * it is ok.
     */
    @Provides
    @Singleton
    static KeyStoreCache keyStoreCache(@Nullable OverridesRegistry registry) {

        Supplier<Cache<UserID, KeyStore>> cacheKeystore = () -> CacheBuilder.newBuilder()
                .initialCapacity(1000)
                // for this interval removed storage access key/changed keystore might not be seen
                .expireAfterWrite(15, TimeUnit.MINUTES)
                .build();

        // These are actually static, so we can afford longer expiry time
        Supplier<Cache<UserID, List<PublicKeyIDWithPublicKey>>> cachePubKeys = () -> CacheBuilder.newBuilder()
                .initialCapacity(1000)
                .expireAfterWrite(60, TimeUnit.MINUTES)
                .build();

        return new DefaultKeyStoreCacheRuntimeDelegatable(
                registry,
                cachePubKeys.get().asMap(),
                cacheKeystore.get().asMap(),
                // it will generate new instance here
                cacheKeystore.get().asMap()
        );
    }
}