org.apache.ignite.hadoop.util.BasicUserNameMapper Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.ignite.hadoop.util;
import org.apache.ignite.internal.util.typedef.internal.S;
import org.jetbrains.annotations.Nullable;
import java.util.Map;
/**
* Name mapper which maps one user name to another based on predefined dictionary. If name is not found in the
* dictionary, or dictionary is not defined, either passed user name or some default value could be returned.
*/
public class BasicUserNameMapper implements UserNameMapper {
/** */
private static final long serialVersionUID = 0L;
/** Mappings. */
private Map mappings;
/** Whether to use default user name. */
private boolean useDfltUsrName;;
/** Default user name. */
private String dfltUsrName;
/** {@inheritDoc} */
@Nullable @Override public String map(String name) {
String res = mappings != null ? mappings.get(name) : null;
return res != null ? res : useDfltUsrName ? dfltUsrName : name;
}
/**
* Get mappings.
*
* @return Mappings.
*/
@Nullable public Map getMappings() {
return mappings;
}
/**
* Set mappings.
*
* @param mappings Mappings.
*/
public void setMappings(@Nullable Map mappings) {
this.mappings = mappings;
}
/**
* Get whether to use default user name when there is no mapping for current user name.
*
* @return Whether to use default user name.
*/
public boolean isUseDefaultUserName() {
return useDfltUsrName;
}
/**
* Set whether to use default user name when there is no mapping for current user name.
*
* @param useDfltUsrName Whether to use default user name.
*/
public void setUseDefaultUserName(boolean useDfltUsrName) {
this.useDfltUsrName = useDfltUsrName;
}
/**
* Get default user name (optional).
*
* This user name will be used if provided mappings doesn't contain mapping for the given user name and
* {#isUseDefaultUserName} is set to {@code true}.
*
* Defaults to {@code null}.
*
* @return Default user name.
*/
@Nullable public String getDefaultUserName() {
return dfltUsrName;
}
/**
* Set default user name (optional). See {@link #getDefaultUserName()} for more information.
*
* @param dfltUsrName Default user name.
*/
public void setDefaultUserName(@Nullable String dfltUsrName) {
this.dfltUsrName = dfltUsrName;
}
/** {@inheritDoc} */
@Override public String toString() {
return S.toString(BasicUserNameMapper.class, this);
}
}