
com.github.robtimus.obfuscation.jackson.databind.ObfuscationModule Maven / Gradle / Ivy
/*
* ObfuscationModule.java
* Copyright 2020 Rob Spoor
*
* 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 com.github.robtimus.obfuscation.jackson.databind;
import java.util.Objects;
import com.fasterxml.jackson.core.Version;
import com.fasterxml.jackson.databind.Module;
import com.github.robtimus.obfuscation.Obfuscator;
/**
* A module that adds support for serializing and deserializing obfuscated values.
*
* @author Rob Spoor
*/
public final class ObfuscationModule extends Module {
private static final ObfuscationModule DEFAULT_MODULE = builder().build();
private final Obfuscator defaultObfuscator;
private ObfuscationModule(Builder builder) {
defaultObfuscator = builder.defaultObfuscator;
}
@Override
public String getModuleName() {
return getClass().getName();
}
@Override
public Version version() {
return ModuleVersion.VERSION;
}
@Override
public void setupModule(SetupContext context) {
context.addBeanSerializerModifier(new ObfuscatedBeanSerializerModifier());
context.addBeanDeserializerModifier(new ObfuscatedBeanDeserializerModifier(defaultObfuscator));
}
/**
* Returns a module with all settings set to default.
*
* @return A module with all settings set to default.
*/
public static ObfuscationModule defaultModule() {
return DEFAULT_MODULE;
}
/**
* Returns a builder that will create {@code ObfuscatedModules}.
*
* @return A builder that will create {@code ObfuscatedModules}.
*/
public static Builder builder() {
return new Builder();
}
/**
* A builder for {@link ObfuscationModule ObfuscationModules}.
*
* @author Rob Spoor
*/
public static final class Builder {
private static final Obfuscator DEFAULT_OBFUSCATOR = Obfuscator.fixedLength(3);
private Obfuscator defaultObfuscator = DEFAULT_OBFUSCATOR;
private Builder() {
super();
}
/**
* Sets the default obfuscator to use, in case no obfuscator could be found from annotations.
* The default is {@link Obfuscator#fixedLength(int) Obfuscator.fixedLength(3)}.
*
* @param defaultObfuscator The default obfuscator to use.
* @return This object.
*/
public Builder withDefaultObfuscator(Obfuscator defaultObfuscator) {
this.defaultObfuscator = Objects.requireNonNull(defaultObfuscator);
return this;
}
/**
* Creates a new {@link ObfuscationModule} with the current settings of this builder.
*
* @return The created {@link ObfuscationModule}.
*/
public ObfuscationModule build() {
return new ObfuscationModule(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy