Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
Copyright @FabioZumbi12
This class is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any
damages arising from the use of this class.
Permission is granted to anyone to use this class for any purpose, including commercial plugins, and to alter it and
redistribute it freely, subject to the following restrictions:
1 - The origin of this class must not be misrepresented; you must not claim that you wrote the original software. If you
use this class in other plugins, an acknowledgment in the plugin documentation would be appreciated but is not required.
2 - Altered source versions must be plainly marked as such, and must not be misrepresented as being the original class.
3 - This notice may not be removed or altered from any source distribution.
Esta classe é fornecida "como está", sem qualquer garantia expressa ou implícita. Em nenhum caso os autores serão
responsabilizados por quaisquer danos decorrentes do uso desta classe.
É concedida permissão a qualquer pessoa para usar esta classe para qualquer finalidade, incluindo plugins pagos, e para
alterá-lo e redistribuí-lo livremente, sujeito às seguintes restrições:
1 - A origem desta classe não deve ser deturpada; você não deve afirmar que escreveu a classe original. Se você usar esta
classe em um plugin, uma confirmação de autoria na documentação do plugin será apreciada, mas não é necessária.
2 - Versões de origem alteradas devem ser claramente marcadas como tal e não devem ser deturpadas como sendo a
classe original.
3 - Este aviso não pode ser removido ou alterado de qualquer distribuição de origem.
*/
package br.net.fabiozumbi12.UltimateChat.Bukkit.config;
import br.net.fabiozumbi12.UltimateChat.Bukkit.UCChannel;
import br.net.fabiozumbi12.UltimateChat.Bukkit.UChat;
import br.net.fabiozumbi12.UltimateChat.Bukkit.util.UCUtil;
import br.net.fabiozumbi12.UltimateChat.Bukkit.util.UChatColor;
import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.inventory.ItemStack;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.util.*;
import java.util.Map.Entry;
public class UCConfig {
private static UCCommentedConfig comConfig;
private static YamlConfiguration Prots = new YamlConfiguration();
private final UChat plugin;
public UCConfig(UChat plugin) throws IOException {
this.plugin = plugin;
File main = UChat.get().getDataFolder();
File protections = new File(UChat.get().getDataFolder(), "protections.yml");
if (!main.exists()) {
main.mkdir();
plugin.getUCLogger().info("Created folder: " + UChat.get().getDataFolder());
}
if (!protections.exists()) {
UCUtil.saveResource("/assets/ultimatechat/protections.yml", new File(UChat.get().getDataFolder(), "protections.yml"));
plugin.getUCLogger().info("Created protections file: " + protections.getPath());
//load protections file
Prots = updateFile(protections);
}
//------------------------------ Add default Values ----------------------------//
comConfig = new UCCommentedConfig();
comConfig.addDefaults();
/*------------------------------------------------------------------------------------*/
/* Load Channels */
loadChannels();
/*------------------------------------------------------------------------------------*/
//----------------------------------------------------------------------------------------//
save();
plugin.getUCLogger().info("All configurations loaded!");
}
private static YamlConfiguration updateFile(File saved) {
YamlConfiguration finalyml = new YamlConfiguration();
YamlConfiguration tempProts = new YamlConfiguration();
try {
finalyml.load(saved);
tempProts.load(new InputStreamReader(UChat.get().getResource("assets/ultimatechat/protections.yml"), StandardCharsets.UTF_8));
} catch (Exception e) {
e.printStackTrace();
}
for (String key : tempProts.getKeys(true)) {
Object obj = tempProts.get(key);
if (finalyml.get(key) != null) {
obj = finalyml.get(key);
}
finalyml.set(key, obj);
}
return finalyml;
}
/* Channels */
private void loadChannels() throws IOException {
File chfolder = new File(UChat.get().getDataFolder(), "channels");
if (!chfolder.exists()) {
chfolder.mkdir();
UChat.get().getUCLogger().info("Created folder: " + chfolder.getPath());
}
if (UChat.get().getChannels() == null) {
UChat.get().setChannels(new HashMap<>());
}
File[] listOfFiles = chfolder.listFiles();
YamlConfiguration channel;
if (Objects.requireNonNull(listOfFiles).length == 0) {
//create default channels
File g = new File(chfolder, "global.yml");
channel = YamlConfiguration.loadConfiguration(g);
channel.set("name", "Global");
channel.set("alias", "g");
channel.set("color", "&2");
channel.set("jedis", false);
channel.set("dynmap.enable", true);
channel.save(g);
File l = new File(chfolder, "local.yml");
channel = YamlConfiguration.loadConfiguration(l);
channel.set("name", "Local");
channel.set("alias", "l");
channel.set("color", "&e");
channel.set("jedis", false);
channel.set("across-worlds", false);
channel.set("distance", 40);
channel.save(l);
File ad = new File(chfolder, "admin.yml");
channel = YamlConfiguration.loadConfiguration(ad);
channel.set("name", "Admin");
channel.set("alias", "ad");
channel.set("color", "&b");
channel.set("jedis", false);
channel.save(ad);
listOfFiles = chfolder.listFiles();
}
for (File file : Objects.requireNonNull(listOfFiles)) {
if (file.getName().endsWith(".yml")) {
channel = YamlConfiguration.loadConfiguration(file);
UCChannel ch = new UCChannel(channel.getValues(true));
try {
addChannel(ch);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
public void delChannel(UCChannel ch) {
for (Entry, UCChannel> ch0 : UChat.get().getChannels().entrySet()) {
if (ch0.getValue().getName().equals(ch.getName())) {
UChat.get().getChannels().remove(ch0.getKey());
break;
}
}
File defch = new File(UChat.get().getDataFolder(), "channels" + File.separator + ch.getName().toLowerCase() + ".yml");
if (defch.exists()) {
defch.delete();
}
}
public void addChannel(UCChannel ch) throws IOException {
File defch = new File(UChat.get().getDataFolder(), "channels" + File.separator + ch.getName().toLowerCase() + ".yml");
YamlConfiguration chFile = YamlConfiguration.loadConfiguration(defch);
chFile.options().header(""
+ "###################################################\n"
+ "############## Channel Configuration ##############\n"
+ "###################################################\n"
+ "\n"
+ "This is the channel configuration.\n"
+ "You can change and copy this file to create as many channels you want.\n"
+ "This is the default options:\n"
+ "\n"
+ "name: Global - The name of channel.\n"
+ "alias: g - The alias to use the channel\n"
+ "across-worlds: true - Send messages of this channel to all worlds?\n"
+ "distance: 0 - If across worlds is false, distance to receive this messages.\n"
+ "color: &b - The color of channel\n"
+ "tag-builder: ch-tags,world,clan-tag,marry-tag,group-prefix,nickname,group-suffix,message - Tags of this channel\n"
+ "need-focus: false - Player can use the alias or need to use '/ch g' to use this channel?\n"
+ "canLock: true - Change if the player can use / to lock on channel."
+ "receivers-message: true - Send chat messages like if 'no players near to receive the message'?\n"
+ "cost: 0.0 - Cost to player use this channel.\n"
+ "use-this-builder: false - Use this tag builder or use the 'config.yml' tag-builder?\n"
+ "channelAlias - Use this channel as a command alias.\n"
+ " enable: true - Enable this execute a command alias?\n"
+ " sendAs: player - Send the command alias as 'player' or 'console'?\n"
+ " cmd: '' - Command to send on every message send by this channel.\n"
+ "available-worlds - Worlds and only this world where this chat can be used and messages sent/received.\n"
+ "discord:\n"
+ " mode: NONE - The options are NONE, SEND, LISTEN, BOTH. If enabled and token code set and the channel ID matches with one discord channel, will react according the choosen mode.\n"
+ " hover: &3Discord Channel: &a{dd-channel}\\n&3Role Name: {dd-rolecolor}{dd-rolename}\n"
+ " format-to-mc: {ch-color}[{ch-alias}]&b{dd-rolecolor}[{dd-rolename}]{sender}&r: \n"
+ " format-to-dd: :thought_balloon: **{sender}**: {message} \n"
+ " allow-server-cmds: false - Use this channel to send commands from discord > minecraft.\n"
+ " channelID: '' - The IDs of your Discord Channels. Enable debug on your discord to get the channel ID.\n"
+ " Note: You can add more than one discord id, just separate by \",\" like: 13246579865498,3216587898754\n");
ch.getProperties().forEach((key, value) -> chFile.set((String) key, value));
chFile.save(defch);
if (UChat.get().getChannel(ch.getName()) != null) {
ch.setMembers(UChat.get().getChannel(ch.getName()).getMembers());
UChat.get().getChannels().remove(Arrays.asList(ch.getName().toLowerCase(), ch.getAlias().toLowerCase()));
}
UChat.get().getChannels().put(Arrays.asList(ch.getName().toLowerCase(), ch.getAlias().toLowerCase()), ch);
}
public List getTagList() {
List tags = new ArrayList<>();
for (String key : plugin.getConfig().getKeys(true)) {
if (key.startsWith("tags.") && key.split("\\.").length == 2) {
tags.add(key.replace("tags.", ""));
}
}
tags.addAll(getStringList("general.custom-tags"));
return tags;
}
public String[] getDefBuilder() {
return getString("general.default-tag-builder").replace(" ", "").split(",");
}
public List getBroadcastAliases() {
return Arrays.asList(plugin.getConfig().getString("broadcast.aliases", "").replace(" ", "").split(","));
}
public List getTellAliases() {
return Arrays.asList(plugin.getConfig().getString("tell.cmd-aliases", "").replace(" ", "").split(","));
}
public List getMsgAliases() {
return Arrays.asList(plugin.getConfig().getString("general.umsg-cmd-aliases", "").replace(" ", "").split(","));
}
public boolean getBoolean(String key) {
return plugin.getConfig().getBoolean(key, false);
}
public void setConfig(String key, Object value) {
plugin.getConfig().set(key, value);
}
public String getString(String key) {
return plugin.getConfig().getString(key, "");
}
public int getInt(String key, int def) {
return plugin.getConfig().getInt(key, def);
}
public List getStringList(String key) {
return plugin.getConfig().getStringList(key);
}
public void save() {
try {
comConfig.saveConfig();
Prots.save(new File(UChat.get().getDataFolder(), "protections.yml"));
} catch (IOException e) {
e.printStackTrace();
}
}
//protection methods
public ConfigurationSection getProtReplecements() {
return Prots.getConfigurationSection("chat-protection.censor.replace-words");
}
public void delFilter(String word) {
Prots.set("chat-protection.censor.replace-words." + word, null);
save();
}
public void addFilter(String word) {
String[] pair = word.split(":");
Prots.set("chat-protection.censor.replace-words." + pair[0], pair[1]);
save();
}
public int getProtInt(String key) {
return Prots.getInt(key);
}
public boolean getProtBool(String key) {
return Prots.getBoolean(key);
}
public List getProtStringList(String key) {
return Prots.getStringList(key);
}
public String getProtString(String key) {
return Prots.getString(key);
}
public String getProtMsg(String key) {
return UChatColor.translateAlternateColorCodes(Prots.getString(key));
}
public String getColorStr(String key) {
return UChatColor.translateAlternateColorCodes(plugin.getConfig().getString(key));
}
public boolean hasBlackListed(ItemStack itemStack) {
return plugin.getConfig().getStringList("general.item-hand.blacklist").stream().anyMatch(i -> i.equalsIgnoreCase(itemStack.getType().name()));
}
}