package io.eguan.utils.mapper; /* * #%L * Project eguan * %% * Copyright (C) 2012 - 2017 Oodrive * %% * 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. * #L% */ import io.eguan.configuration.IntegerConfigKey; /** * The directory structure depth for the {@link FileMapper.Type#DEEP DEEP} {@link FileMapper}. * * Values associated to this key denote the number of directory levels to insert between the base directory and the file * itself, helping spread files over the structure so as not to hit file system limits too early. The value set for this * key multiplied by the value set for {@link DirPrefixLengthConfigKey} must not exceed 31 (i.e. the length of a * hex-encoded UUID - 1). * * <table border='1'> * <tr> * <th>NAME</th> * <th>DESCRIPTION</th> * <th>REQUIRED</th> * <th>UNIT</th> * <th>TYPE</th> * <th>DEFAULT</th> * <th>MIN</th> * <th>MAX</th> * </tr> * <tr> * <td>{@value #NAME}</td> * <td>The directory structure depth for the {@link FileMapper.Type#DEEP DEEP} {@link FileMapper}</td> * <td>FALSE</td> * <td>directory levels</td> * <td>short</td> * <td>1</td> * <td>1</td> * <td>31</td> * </tr> * </table> * * @author oodrive * @author pwehrle * @author llambert * */ public final class DirStructureDepthConfigKey extends IntegerConfigKey { protected static final String NAME = "dir.structure.depth"; private static final int MAX_VALUE = 31; private static final int MIN_VALUE = 1; private static final int DEFAULT_VALUE = 1; private static final DirStructureDepthConfigKey INSTANCE = new DirStructureDepthConfigKey(); /** * Gets the predefined singleton instance. * * @return the singleton instance constructed with {@link #DirStructureDepthConfigKey()} */ public static final DirStructureDepthConfigKey getInstance() { return INSTANCE; } private DirStructureDepthConfigKey() { super(NAME, MIN_VALUE, MAX_VALUE); } @Override protected final Integer getDefaultValue() { return Integer.valueOf(DEFAULT_VALUE); } }