Dieser Commit ist enthalten in:
Ursprung
b024d24a93
Commit
18dfcf5025
@ -1 +1 @@
|
|||||||
Subproject commit b66c18b8b3f1faa3fe97fd8c3f16ce19259dc0d2
|
Subproject commit e83ab4762d77567a01b0b71bdf12b65bf2aca3bd
|
@ -66,7 +66,7 @@ public class PunishmentCommand {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return SteamwarUser.getOrCreate(uuid, name, u -> {}, (o, n) -> {});
|
return SteamwarUser.getOrCreate(uuid, name, u -> {});
|
||||||
}
|
}
|
||||||
|
|
||||||
private static UUID getUUIDofOfflinePlayer(String playerName) {
|
private static UUID getUUIDofOfflinePlayer(String playerName) {
|
||||||
|
@ -1,116 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is a part of the SteamWar software.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2023 SteamWar.de-Serverteam
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package de.steamwar.bungeecore.commands;
|
|
||||||
|
|
||||||
import de.steamwar.bungeecore.BungeeCore;
|
|
||||||
import de.steamwar.bungeecore.Message;
|
|
||||||
import de.steamwar.bungeecore.inventory.SWInventory;
|
|
||||||
import de.steamwar.bungeecore.inventory.SWItem;
|
|
||||||
import de.steamwar.bungeecore.inventory.SWListInv;
|
|
||||||
import de.steamwar.command.SWCommand;
|
|
||||||
import de.steamwar.sql.SteamwarUser;
|
|
||||||
import de.steamwar.sql.Token;
|
|
||||||
import lombok.SneakyThrows;
|
|
||||||
import net.md_5.bungee.api.chat.ClickEvent;
|
|
||||||
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
|
||||||
|
|
||||||
import java.security.MessageDigest;
|
|
||||||
import java.util.Base64;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Random;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public class TokensCommand extends SWCommand {
|
|
||||||
public TokensCommand() {
|
|
||||||
super("tokens", null, "token");
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final Random random = new Random();
|
|
||||||
|
|
||||||
@SneakyThrows
|
|
||||||
private static String generateCode() {
|
|
||||||
byte[] hash = new byte[16];
|
|
||||||
for(int i = 0; i < hash.length; i++) {
|
|
||||||
hash[i] = (byte) (random.nextInt(256) - 128);
|
|
||||||
}
|
|
||||||
return Base64.getEncoder().encodeToString(MessageDigest.getInstance("SHA-1").digest(hash));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SneakyThrows
|
|
||||||
private static String generateHash(String code) {
|
|
||||||
MessageDigest md = MessageDigest.getInstance("SHA-512");
|
|
||||||
return Base64.getEncoder().encodeToString(md.digest(code.getBytes()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Register
|
|
||||||
public void genericCommand(ProxiedPlayer p) {
|
|
||||||
SteamwarUser user = SteamwarUser.get(p.getUniqueId());
|
|
||||||
List<Token> tokens = Token.listUser(user);
|
|
||||||
|
|
||||||
List<SWListInv.SWListEntry<Token>> entries = tokens
|
|
||||||
.stream()
|
|
||||||
.map(token -> new SWListInv.SWListEntry<>(new SWItem("STONE", token.getName()), token))
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
|
|
||||||
SWListInv<Token> inv = new SWListInv<>(p, Message.parse("TOKENS_TITLE", p), entries, (click, element) -> {
|
|
||||||
SWInventory deleteInv = new SWInventory(p, 9, Message.parse("TOKENS_DELETE", p));
|
|
||||||
deleteInv.addItem(0, new SWItem(Message.parse("TOKENS_DELETE_CONFIRM", p), 2), deleteClick -> {
|
|
||||||
Token.delete(element);
|
|
||||||
Message.send("TOKENS_DELETED", p);
|
|
||||||
deleteInv.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
deleteInv.addItem(8, new SWItem(Message.parse("TOKENS_DELETE_CANCEL", p), 1), deleteClick -> {
|
|
||||||
deleteInv.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
deleteInv.open();
|
|
||||||
});
|
|
||||||
|
|
||||||
inv.open();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Register("create")
|
|
||||||
public void createToken(ProxiedPlayer p, String name) {
|
|
||||||
SteamwarUser user = SteamwarUser.get(p.getUniqueId());
|
|
||||||
|
|
||||||
if(name.length() > 32) {
|
|
||||||
Message.send("TOKENS_NAME_TOO_LONG", p);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(name.length() < 3) {
|
|
||||||
Message.send("TOKENS_NAME_TOO_SHORT", p);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(Token.listUser(user).stream().anyMatch(token -> token.getName().equalsIgnoreCase(name))) {
|
|
||||||
Message.send("TOKENS_NAME_ALREADY_EXISTS", p);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
String code = generateCode();
|
|
||||||
String hash = generateHash(code);
|
|
||||||
|
|
||||||
Token token = Token.create(name, user, hash);
|
|
||||||
|
|
||||||
Message.send("TOKENS_NAME_CREATED", p, "TOKENS_NAME_CREATED_HOVER", new ClickEvent(ClickEvent.Action.COPY_TO_CLIPBOARD, code));
|
|
||||||
}
|
|
||||||
}
|
|
@ -19,8 +19,11 @@
|
|||||||
|
|
||||||
package de.steamwar.bungeecore.commands;
|
package de.steamwar.bungeecore.commands;
|
||||||
|
|
||||||
|
import de.steamwar.bungeecore.BungeeCore;
|
||||||
import de.steamwar.command.SWCommand;
|
import de.steamwar.command.SWCommand;
|
||||||
import de.steamwar.messages.ChatSender;
|
import de.steamwar.messages.ChatSender;
|
||||||
|
import de.steamwar.sql.SteamwarUser;
|
||||||
|
import de.steamwar.sql.Token;
|
||||||
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
@ -41,33 +44,11 @@ public class WebpasswordCommand extends SWCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ProcessBuilder pb = new ProcessBuilder("php", "/var/www/register.php", player.getName(), password);
|
SteamwarUser user = SteamwarUser.get(player.getUniqueId());
|
||||||
pb.redirectErrorStream(true);
|
user.setPassword(password);
|
||||||
try {
|
|
||||||
Process regProcess = pb.start();
|
Token.listUser(user).stream().filter(token -> token.getName().startsWith("Website: ")).forEach(token -> token.delete());
|
||||||
BufferedReader reader = new BufferedReader(new InputStreamReader(regProcess.getInputStream()));
|
|
||||||
String errorLine;
|
|
||||||
if((errorLine = reader.readLine()) != null) {
|
|
||||||
if ("updated".equals(errorLine)) {
|
|
||||||
ChatSender.of(player).system("WEB_UPDATED");
|
ChatSender.of(player).system("WEB_UPDATED");
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
throw new SecurityException("Could not create webaccount " + errorLine);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ChatSender.of(player).system("WEB_CREATED");
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new SecurityException("Could not create webaccount", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void changeUsername(String oldUsername, String newUsername){
|
|
||||||
ProcessBuilder pb = new ProcessBuilder("php", "/var/www/changename.php", oldUsername, newUsername);
|
|
||||||
try {
|
|
||||||
pb.start();
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new SecurityException("Could not change username", e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ public class BanListener extends BasicListener {
|
|||||||
event.registerIntent(BungeeCore.get());
|
event.registerIntent(BungeeCore.get());
|
||||||
ProxyServer.getInstance().getScheduler().runAsync(BungeeCore.get(), () -> {
|
ProxyServer.getInstance().getScheduler().runAsync(BungeeCore.get(), () -> {
|
||||||
PendingConnection connection = event.getConnection();
|
PendingConnection connection = event.getConnection();
|
||||||
SteamwarUser user = SteamwarUser.getOrCreate(connection.getUniqueId(), connection.getName(), ConnectionListener::newPlayer, WebpasswordCommand::changeUsername);
|
SteamwarUser user = SteamwarUser.getOrCreate(connection.getUniqueId(), connection.getName(), ConnectionListener::newPlayer);
|
||||||
if (user.isPunished(Punishment.PunishmentType.Ban)) {
|
if (user.isPunished(Punishment.PunishmentType.Ban)) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
BannedUserIPs.banIP(user.getId(), connection.getAddress().getAddress().getHostAddress());
|
BannedUserIPs.banIP(user.getId(), connection.getAddress().getAddress().getHostAddress());
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren