AuthMe/AuthMeReloaded

View on GitHub
src/main/java/fr/xephi/authme/command/executable/email/ShowEmailCommand.java

Summary

Maintainability
A
0 mins
Test Coverage
package fr.xephi.authme.command.executable.email;

import fr.xephi.authme.command.PlayerCommand;
import fr.xephi.authme.data.auth.PlayerAuth;
import fr.xephi.authme.data.auth.PlayerCache;
import fr.xephi.authme.message.MessageKey;
import fr.xephi.authme.service.CommonService;
import fr.xephi.authme.settings.properties.SecuritySettings;
import fr.xephi.authme.util.Utils;
import org.bukkit.entity.Player;

import javax.inject.Inject;
import java.util.List;

/**
 * Show email command.
 */
public class ShowEmailCommand extends PlayerCommand {

    @Inject
    private CommonService commonService;

    @Inject
    private PlayerCache playerCache;

    @Override
    public void runCommand(Player player, List<String> arguments) {
        PlayerAuth auth = playerCache.getAuth(player.getName());
        if (auth != null && !Utils.isEmailEmpty(auth.getEmail())) {
            if (commonService.getProperty(SecuritySettings.USE_EMAIL_MASKING)){
                commonService.send(player, MessageKey.EMAIL_SHOW, emailMask(auth.getEmail()));
            } else {
                commonService.send(player, MessageKey.EMAIL_SHOW, auth.getEmail());
            }
        } else {
            commonService.send(player, MessageKey.SHOW_NO_EMAIL);
        }
    }

    private String emailMask(String email){
        String[] frag = email.split("@");   //Split id and domain
        int sid = frag[0].length() / 3 + 1;     //Define the id view (required length >= 1)
        int sdomain = frag[1].length() / 3;   //Define the domain view (required length >= 0)
        String id = frag[0].substring(0, sid) + "***";  //Build the id
        String domain = "***" + frag[1].substring(sdomain);  //Build the domain
        return id + "@" + domain;
    }
}