org.vertexium.accumulo.AccumuloNameSubstitutionStrategy Maven / Gradle / Ivy
package org.vertexium.accumulo;
import org.apache.hadoop.io.Text;
import org.cache2k.Cache;
import org.cache2k.CacheBuilder;
import org.cache2k.CacheSource;
import org.vertexium.id.IdentityNameSubstitutionStrategy;
import org.vertexium.id.NameSubstitutionStrategy;
import java.util.Map;
public class AccumuloNameSubstitutionStrategy implements NameSubstitutionStrategy {
private final NameSubstitutionStrategy nameSubstitutionStrategy;
private final Cache inflateTextCache;
protected AccumuloNameSubstitutionStrategy(NameSubstitutionStrategy nameSubstitutionStrategy) {
this.nameSubstitutionStrategy = nameSubstitutionStrategy;
inflateTextCache = CacheBuilder
.newCache(Text.class, String.class)
.name(AccumuloNameSubstitutionStrategy.class, "inflateTextCache-" + System.identityHashCode(this))
.maxSize(10000)
.source(new CacheSource() {
@Override
public String get(Text text) throws Throwable {
return inflate(text.toString());
}
})
.build();
}
@Override
public void setup(Map config) {
return;
}
@Override
public String deflate(String value) {
return this.nameSubstitutionStrategy.deflate(value);
}
@Override
public String inflate(String value) {
return this.nameSubstitutionStrategy.inflate(value);
}
public String inflate(Text text) {
if (text == null) {
return null;
}
if (this.nameSubstitutionStrategy instanceof IdentityNameSubstitutionStrategy) {
return text.toString();
}
return inflateTextCache.get(text);
}
public static AccumuloNameSubstitutionStrategy create(NameSubstitutionStrategy nameSubstitutionStrategy) {
if (nameSubstitutionStrategy instanceof AccumuloNameSubstitutionStrategy) {
return (AccumuloNameSubstitutionStrategy) nameSubstitutionStrategy;
}
return new AccumuloNameSubstitutionStrategy(nameSubstitutionStrategy);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy