All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.networknt.schema.ApplyDefaultsStrategy Maven / Gradle / Ivy

package com.networknt.schema;

public class ApplyDefaultsStrategy {
    static final ApplyDefaultsStrategy EMPTY_APPLY_DEFAULTS_STRATEGY = new ApplyDefaultsStrategy(false, false, false);

    private final boolean applyPropertyDefaults;
    private final boolean applyPropertyDefaultsIfNull;
    private final boolean applyArrayDefaults;

    /**
     * Specify which default values to apply.
     * We can apply property defaults only if they are missing or if they are declared to be null in the input json,
     * and we can apply array defaults if they are declared to be null in the input json.
     *
     * 

Note that the walker changes the input object in place. * If validation fails, the input object will be changed. * * @param applyPropertyDefaults if true then apply defaults inside json objects if the attribute is missing * @param applyPropertyDefaultsIfNull if true then apply defaults inside json objects if the attribute is explicitly null * @param applyArrayDefaults if true then apply defaults inside json arrays if the attribute is explicitly null * @throws IllegalArgumentException if applyPropertyDefaults is false and applyPropertyDefaultsIfNull is true */ public ApplyDefaultsStrategy(boolean applyPropertyDefaults, boolean applyPropertyDefaultsIfNull, boolean applyArrayDefaults) { if (!applyPropertyDefaults && applyPropertyDefaultsIfNull) { throw new IllegalArgumentException(); } this.applyPropertyDefaults = applyPropertyDefaults; this.applyPropertyDefaultsIfNull = applyPropertyDefaultsIfNull; this.applyArrayDefaults = applyArrayDefaults; } public boolean shouldApplyPropertyDefaults() { return applyPropertyDefaults; } public boolean shouldApplyPropertyDefaultsIfNull() { return applyPropertyDefaultsIfNull; } public boolean shouldApplyArrayDefaults() { return applyArrayDefaults; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy