Compare commits
1 Commits
develop-ba
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 469cd19b55 |
@@ -11,14 +11,15 @@ public class CraftAttackReportRepository extends ReportRepository {
|
|||||||
|
|
||||||
public ReqResp<PlayerReports> queryReports(UUID player) {
|
public ReqResp<PlayerReports> queryReports(UUID player) {
|
||||||
return this.get(
|
return this.get(
|
||||||
"users/%s/reports".formatted(player.toString()),
|
"report",
|
||||||
|
(parameters) -> parameters.addParameter("uuid", player.toString()),
|
||||||
PlayerReports.class
|
PlayerReports.class
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ReqResp<ReportUrl> createReport(ReportCreationInfo data) {
|
public ReqResp<ReportUrl> createReport(ReportCreationInfo data) {
|
||||||
return this.post(
|
return this.post(
|
||||||
"reports",
|
"report",
|
||||||
data,
|
data,
|
||||||
ReportUrl.class
|
ReportUrl.class
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -23,18 +23,19 @@ public abstract class ReportRepository extends HttpRepository {
|
|||||||
|
|
||||||
public record PlayerReports(
|
public record PlayerReports(
|
||||||
List<Report> from_self,
|
List<Report> from_self,
|
||||||
List<Report> to_self
|
Object to_self
|
||||||
) {
|
) {
|
||||||
public record Report(
|
public record Report(
|
||||||
@Nullable UUID reported,
|
@Nullable Reporter reported,
|
||||||
@NotNull String reason,
|
@NotNull String subject,
|
||||||
@Nullable Long created,
|
boolean draft,
|
||||||
@Nullable Status status,
|
@NotNull String status,
|
||||||
@NotNull String url
|
@NotNull String url
|
||||||
) {
|
) {
|
||||||
public enum Status {
|
public record Reporter(
|
||||||
open,
|
@NotNull String username,
|
||||||
closed,
|
@NotNull String uuid
|
||||||
|
) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
|||||||
import eu.mhsl.craftattack.spawn.common.api.repositories.CraftAttackReportRepository;
|
import eu.mhsl.craftattack.spawn.common.api.repositories.CraftAttackReportRepository;
|
||||||
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
||||||
import eu.mhsl.craftattack.spawn.core.appliance.ApplianceCommand;
|
import eu.mhsl.craftattack.spawn.core.appliance.ApplianceCommand;
|
||||||
import eu.mhsl.craftattack.spawn.core.util.text.ComponentUtil;
|
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.kyori.adventure.text.ComponentBuilder;
|
import net.kyori.adventure.text.ComponentBuilder;
|
||||||
import net.kyori.adventure.text.TextComponent;
|
import net.kyori.adventure.text.TextComponent;
|
||||||
@@ -20,9 +19,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.function.Function;
|
|
||||||
|
|
||||||
public class Report extends Appliance {
|
public class Report extends Appliance {
|
||||||
public static Component helpText() {
|
public static Component helpText() {
|
||||||
@@ -81,7 +78,7 @@ public class Report extends Appliance {
|
|||||||
.appendNewline()
|
.appendNewline()
|
||||||
.append(
|
.append(
|
||||||
Component
|
Component
|
||||||
.text(createdReport.data().url(), NamedTextColor.GRAY)
|
.text(createdReport.data().url(), NamedTextColor.GRAY) // URL mit Weltkugel-Emoji
|
||||||
.clickEvent(ClickEvent.clickEvent(ClickEvent.Action.OPEN_URL, createdReport.data().url()))
|
.clickEvent(ClickEvent.clickEvent(ClickEvent.Action.OPEN_URL, createdReport.data().url()))
|
||||||
)
|
)
|
||||||
.appendNewline()
|
.appendNewline()
|
||||||
@@ -131,50 +128,43 @@ public class Report extends Appliance {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Function<List<ReportRepository.PlayerReports.Report>, List<ReportRepository.PlayerReports.Report>> filterClosed = reports -> reports.stream()
|
List<ReportRepository.PlayerReports.Report> reports = userReports
|
||||||
.filter(report -> Objects.equals(report.status(), ReportRepository.PlayerReports.Report.Status.closed))
|
.data()
|
||||||
.toList();
|
.from_self()
|
||||||
|
.stream()
|
||||||
|
.filter(report -> !report.draft())
|
||||||
|
.toList()
|
||||||
|
.reversed();
|
||||||
|
|
||||||
List<ReportRepository.PlayerReports.Report> reportsToOthers = filterClosed.apply(userReports.data().from_self()).reversed();
|
if(reports.isEmpty()) {
|
||||||
List<ReportRepository.PlayerReports.Report> reportsToSelf = filterClosed.apply(userReports.data().to_self()).reversed();
|
issuer.sendMessage(
|
||||||
|
Component.text()
|
||||||
ComponentBuilder<TextComponent, TextComponent.Builder> component = Component.text()
|
|
||||||
.append(Component.text(
|
|
||||||
!reportsToSelf.isEmpty()
|
|
||||||
? "Du wurdest insgesamt %d mal von anderen Spielern gemeldet.".formatted(reportsToSelf.size())
|
|
||||||
: "Du wurdest von keinem anderen Spieler gemeldet.",
|
|
||||||
NamedTextColor.GOLD)
|
|
||||||
);
|
|
||||||
|
|
||||||
component.appendNewline();
|
|
||||||
|
|
||||||
component.append(Component.text("Von dir erstellte Reports: ", NamedTextColor.GOLD));
|
|
||||||
reportsToOthers.forEach(report -> {
|
|
||||||
Component button = Component.text("[\uD83D\uDC41/\uD83D\uDD8A]")
|
|
||||||
.clickEvent(ClickEvent.openUrl(report.url()))
|
|
||||||
.hoverEvent(HoverEvent.showText(ComponentUtil.clickLink(report.url())));
|
|
||||||
|
|
||||||
Component reportedDisplayName = report.reported() != null
|
|
||||||
? Component.text(Optional.ofNullable(Bukkit.getOfflinePlayer(report.reported()).getName()).orElse(report.reported().toString()), NamedTextColor.WHITE)
|
|
||||||
: Component.text("Unbekannt", NamedTextColor.YELLOW);
|
|
||||||
|
|
||||||
component
|
|
||||||
.appendNewline()
|
|
||||||
.append(Component.text(" \u27A1 ", NamedTextColor.GRAY))
|
|
||||||
.append(button)
|
|
||||||
.append(Component.text(" du gegen ", NamedTextColor.GRAY))
|
|
||||||
.append(reportedDisplayName)
|
|
||||||
.append(Component.text(String.format(": %s", report.reason()), NamedTextColor.GRAY));
|
|
||||||
});
|
|
||||||
|
|
||||||
if(reportsToOthers.isEmpty()) {
|
|
||||||
component
|
|
||||||
.appendNewline()
|
|
||||||
.append(Component.text("Du hast noch niemanden reportet.", NamedTextColor.RED))
|
.append(Component.text("Du hast noch niemanden reportet.", NamedTextColor.RED))
|
||||||
.appendNewline()
|
.appendNewline()
|
||||||
.append(Component.text("Um jemanden zu melden, nutze /report", NamedTextColor.GRAY));
|
.append(Component.text("Um jemanden zu melden, nutze /report", NamedTextColor.GRAY))
|
||||||
|
);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ComponentBuilder<TextComponent, TextComponent.Builder> component = Component.text()
|
||||||
|
.append(Component.newline())
|
||||||
|
.append(Component.text("Von dir erstellte Reports: ", NamedTextColor.GOLD))
|
||||||
|
.appendNewline();
|
||||||
|
|
||||||
|
reports.forEach(report -> {
|
||||||
|
component
|
||||||
|
.append(Component.text(" - ", NamedTextColor.WHITE))
|
||||||
|
.append(
|
||||||
|
report.reported() != null
|
||||||
|
? Component.text(report.reported().username(), NamedTextColor.WHITE)
|
||||||
|
: Component.text("Unbekannt", NamedTextColor.YELLOW)
|
||||||
|
)
|
||||||
|
.append(Component.text(String.format(": %s", report.subject()), NamedTextColor.GRAY))
|
||||||
|
.clickEvent(ClickEvent.openUrl(report.url()))
|
||||||
|
.hoverEvent(HoverEvent.showText(Component.text("Klicke, um den Report einzusehen.", NamedTextColor.GOLD)));
|
||||||
|
component.appendNewline();
|
||||||
|
});
|
||||||
|
|
||||||
issuer.sendMessage(component.build());
|
issuer.sendMessage(component.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,51 @@
|
|||||||
|
package eu.mhsl.craftattack.spawn.common.appliances.security.antiBoatFreecam;
|
||||||
|
|
||||||
|
import eu.mhsl.craftattack.spawn.common.appliances.tooling.acInform.AcInform;
|
||||||
|
import eu.mhsl.craftattack.spawn.core.Main;
|
||||||
|
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Boat;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
public class AntiBoatFreecam extends Appliance {
|
||||||
|
private static final float MAX_YAW_OFFSET = 106.0f;
|
||||||
|
private final Map<Player, Float> violatedPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public AntiBoatFreecam() {
|
||||||
|
Bukkit.getScheduler().runTaskTimerAsynchronously(
|
||||||
|
Main.instance(),
|
||||||
|
() -> Bukkit.getOnlinePlayers().forEach(player -> {
|
||||||
|
if(!(player.getVehicle() instanceof Boat boat)) return;
|
||||||
|
if(!boat.getPassengers().getFirst().equals(player)) return;
|
||||||
|
float playerYaw = player.getYaw();
|
||||||
|
float boatYaw = boat.getYaw();
|
||||||
|
|
||||||
|
float yawDelta = wrapDegrees(playerYaw - boatYaw);
|
||||||
|
if(Math.abs(yawDelta) <= MAX_YAW_OFFSET) return;
|
||||||
|
|
||||||
|
this.violatedPlayers.merge(player, 1f, Float::sum);
|
||||||
|
float violationCount = this.violatedPlayers.get(player);
|
||||||
|
if(violationCount != 1 && violationCount % 100 != 0) return;
|
||||||
|
Main.instance().getAppliance(AcInform.class).notifyAdmins(
|
||||||
|
"internal",
|
||||||
|
player.getName(),
|
||||||
|
"illegalBoatLookYaw",
|
||||||
|
violationCount
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
1L,
|
||||||
|
1L
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static float wrapDegrees(float deg) {
|
||||||
|
deg = deg % 360f;
|
||||||
|
if (deg >= 180f) deg -= 360f;
|
||||||
|
if (deg < -180f) deg += 360f;
|
||||||
|
return deg;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -5,7 +5,6 @@ import eu.mhsl.craftattack.spawn.core.util.statistics.ServerMonitor;
|
|||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.kyori.adventure.text.ComponentBuilder;
|
import net.kyori.adventure.text.ComponentBuilder;
|
||||||
import net.kyori.adventure.text.TextComponent;
|
import net.kyori.adventure.text.TextComponent;
|
||||||
import net.kyori.adventure.text.event.ClickEvent;
|
|
||||||
import net.kyori.adventure.text.format.NamedTextColor;
|
import net.kyori.adventure.text.format.NamedTextColor;
|
||||||
import net.kyori.adventure.text.format.TextColor;
|
import net.kyori.adventure.text.format.TextColor;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@@ -20,12 +19,7 @@ import java.util.stream.Stream;
|
|||||||
|
|
||||||
public class ComponentUtil {
|
public class ComponentUtil {
|
||||||
public static TextComponent pleaseWait() {
|
public static TextComponent pleaseWait() {
|
||||||
return Component.text("\uD83D\uDCBE Daten werden geladen... Warte einen Augenblick!", NamedTextColor.GRAY);
|
return Component.text("Bitte warte einen Augenblick...", NamedTextColor.GRAY);
|
||||||
}
|
|
||||||
|
|
||||||
public static TextComponent clickLink(String url) {
|
|
||||||
return Component.text("Klicke, um zu öffnen: \uD83D\uDD17[%s]".formatted(url))
|
|
||||||
.clickEvent(ClickEvent.openUrl(url));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Component clearedSpace() {
|
public static Component clearedSpace() {
|
||||||
|
|||||||
@@ -1,10 +1,13 @@
|
|||||||
package eu.mhsl.craftattack.spawn.craftattack.api.repositories;
|
package eu.mhsl.craftattack.spawn.craftattack.api.repositories;
|
||||||
|
|
||||||
|
import com.google.common.reflect.TypeToken;
|
||||||
import eu.mhsl.craftattack.spawn.core.api.client.HttpRepository;
|
import eu.mhsl.craftattack.spawn.core.api.client.HttpRepository;
|
||||||
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
||||||
import eu.mhsl.craftattack.spawn.common.api.CraftAttackApi;
|
import eu.mhsl.craftattack.spawn.common.api.CraftAttackApi;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class FeedbackRepository extends HttpRepository {
|
public class FeedbackRepository extends HttpRepository {
|
||||||
@@ -12,15 +15,14 @@ public class FeedbackRepository extends HttpRepository {
|
|||||||
super(CraftAttackApi.getBaseUri(), new RequestModifier(null, CraftAttackApi::withAuthorizationHeader));
|
super(CraftAttackApi.getBaseUri(), new RequestModifier(null, CraftAttackApi::withAuthorizationHeader));
|
||||||
}
|
}
|
||||||
|
|
||||||
public record Request(String event, String title, List<UUID> users) {
|
public record Request(String event, List<UUID> users) {
|
||||||
}
|
}
|
||||||
|
|
||||||
public record Response(List<Feedback> feedback) {
|
public ReqResp<Map<UUID, String>> createFeedbackUrls(Request data) {
|
||||||
public record Feedback(UUID uuid, String url) {
|
final Type responseType = new TypeToken<Map<UUID, String>>() {
|
||||||
}
|
}.getType();
|
||||||
}
|
ReqResp<Object> rawData = this.post("feedback", data, Object.class);
|
||||||
|
// TODO: use convertToTypeToken from ReqResp
|
||||||
public ReqResp<Response> createFeedbackUrls(Request data) {
|
return new ReqResp<>(rawData.status(), this.gson.fromJson(this.gson.toJson(rawData.data()), responseType));
|
||||||
return this.post("feedback", data, Response.class);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import eu.mhsl.craftattack.spawn.core.api.client.HttpRepository;
|
|||||||
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
||||||
import eu.mhsl.craftattack.spawn.common.api.CraftAttackApi;
|
import eu.mhsl.craftattack.spawn.common.api.CraftAttackApi;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class WhitelistRepository extends HttpRepository {
|
public class WhitelistRepository extends HttpRepository {
|
||||||
@@ -17,15 +16,17 @@ public class WhitelistRepository extends HttpRepository {
|
|||||||
String username,
|
String username,
|
||||||
String firstname,
|
String firstname,
|
||||||
String lastname,
|
String lastname,
|
||||||
List<Strike> strikes
|
Long banned_until,
|
||||||
|
Long outlawed_until
|
||||||
) {
|
) {
|
||||||
public record Strike(int at, int weight) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private record UserQuery(UUID uuid) {}
|
||||||
|
|
||||||
public ReqResp<UserData> getUserData(UUID userId) {
|
public ReqResp<UserData> getUserData(UUID userId) {
|
||||||
return this.get(
|
return this.post(
|
||||||
"users/%s".formatted(userId.toString()),
|
"player",
|
||||||
|
new UserQuery(userId),
|
||||||
UserData.class
|
UserData.class
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package eu.mhsl.craftattack.spawn.craftattack.appliances.metaGameplay.feedback;
|
package eu.mhsl.craftattack.spawn.craftattack.appliances.metaGameplay.feedback;
|
||||||
|
|
||||||
|
import eu.mhsl.craftattack.spawn.core.Main;
|
||||||
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
import eu.mhsl.craftattack.spawn.core.api.client.ReqResp;
|
||||||
import eu.mhsl.craftattack.spawn.core.util.text.ComponentUtil;
|
|
||||||
import eu.mhsl.craftattack.spawn.craftattack.api.repositories.FeedbackRepository;
|
import eu.mhsl.craftattack.spawn.craftattack.api.repositories.FeedbackRepository;
|
||||||
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
||||||
import eu.mhsl.craftattack.spawn.core.appliance.ApplianceCommand;
|
import eu.mhsl.craftattack.spawn.core.appliance.ApplianceCommand;
|
||||||
@@ -9,6 +9,7 @@ import eu.mhsl.craftattack.spawn.core.api.HttpStatus;
|
|||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.kyori.adventure.text.ComponentBuilder;
|
import net.kyori.adventure.text.ComponentBuilder;
|
||||||
import net.kyori.adventure.text.TextComponent;
|
import net.kyori.adventure.text.TextComponent;
|
||||||
|
import net.kyori.adventure.text.event.ClickEvent;
|
||||||
import net.kyori.adventure.text.event.HoverEvent;
|
import net.kyori.adventure.text.event.HoverEvent;
|
||||||
import net.kyori.adventure.text.format.NamedTextColor;
|
import net.kyori.adventure.text.format.NamedTextColor;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
@@ -17,27 +18,32 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
public class Feedback extends Appliance {
|
public class Feedback extends Appliance {
|
||||||
public Feedback() {
|
public Feedback() {
|
||||||
super("feedback");
|
super("feedback");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void requestFeedback(String eventName, String title, List<Player> receivers, @Nullable String question) {
|
public void requestFeedback(String eventName, List<Player> receivers, @Nullable String question) {
|
||||||
ReqResp<FeedbackRepository.Response> response = this.queryRepository(FeedbackRepository.class).createFeedbackUrls(
|
ReqResp<Map<UUID, String>> response = this.queryRepository(FeedbackRepository.class).createFeedbackUrls(
|
||||||
new FeedbackRepository.Request(eventName, title, receivers.stream().map(Entity::getUniqueId).toList())
|
new FeedbackRepository.Request(eventName, receivers.stream().map(Entity::getUniqueId).toList())
|
||||||
);
|
);
|
||||||
|
|
||||||
if(response.status() != HttpStatus.OK) throw new RuntimeException();
|
System.out.println(response.toString());
|
||||||
|
System.out.println(response.status());
|
||||||
|
|
||||||
|
if(response.status() != HttpStatus.CREATED) throw new RuntimeException();
|
||||||
|
|
||||||
Component border = Component.text("-".repeat(40), NamedTextColor.GRAY);
|
Component border = Component.text("-".repeat(40), NamedTextColor.GRAY);
|
||||||
|
|
||||||
receivers.forEach(player -> {
|
receivers.forEach(player -> {
|
||||||
String feedbackUrl = response.data().feedback().stream()
|
String feedbackUrl = response.data().get(player.getUniqueId());
|
||||||
.filter(feedback -> feedback.uuid().equals(player.getUniqueId()))
|
if(feedbackUrl == null) {
|
||||||
.findFirst()
|
Main.logger().warning(String.format("FeedbackUrl not found for player '%s' from backend!", player.getUniqueId()));
|
||||||
.orElseThrow()
|
return;
|
||||||
.url();
|
}
|
||||||
|
|
||||||
ComponentBuilder<TextComponent, TextComponent.Builder> message = Component.text()
|
ComponentBuilder<TextComponent, TextComponent.Builder> message = Component.text()
|
||||||
.append(border)
|
.append(border)
|
||||||
@@ -52,7 +58,8 @@ public class Feedback extends Appliance {
|
|||||||
|
|
||||||
message
|
message
|
||||||
.append(Component.text("Klicke hier und gib uns Feedback, damit wir dein Spielerlebnis verbessern können!", NamedTextColor.DARK_GREEN)
|
.append(Component.text("Klicke hier und gib uns Feedback, damit wir dein Spielerlebnis verbessern können!", NamedTextColor.DARK_GREEN)
|
||||||
.hoverEvent(HoverEvent.showText(ComponentUtil.clickLink(feedbackUrl))))
|
.clickEvent(ClickEvent.openUrl(feedbackUrl)))
|
||||||
|
.hoverEvent(HoverEvent.showText(Component.text("Klicke, um Feedback zu geben.")))
|
||||||
.appendNewline()
|
.appendNewline()
|
||||||
.append(border);
|
.append(border);
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,6 @@ class FeedbackCommand extends ApplianceCommand.PlayerChecked<Feedback> {
|
|||||||
Main.instance(),
|
Main.instance(),
|
||||||
() -> this.getAppliance().requestFeedback(
|
() -> this.getAppliance().requestFeedback(
|
||||||
"self-issued-ingame",
|
"self-issued-ingame",
|
||||||
"Dein Feedback an uns",
|
|
||||||
List.of(this.getPlayer()),
|
List.of(this.getPlayer()),
|
||||||
null
|
null
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -20,7 +20,6 @@ class RequestFeedbackCommand extends ApplianceCommand<Feedback> {
|
|||||||
Main.instance(),
|
Main.instance(),
|
||||||
() -> this.getAppliance().requestFeedback(
|
() -> this.getAppliance().requestFeedback(
|
||||||
"admin-issued-ingame",
|
"admin-issued-ingame",
|
||||||
"Hilf uns dein Spielerlebnis zu verbessern!",
|
|
||||||
new ArrayList<>(Bukkit.getOnlinePlayers()), String.join(" ", args)
|
new ArrayList<>(Bukkit.getOnlinePlayers()), String.join(" ", args)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,21 +0,0 @@
|
|||||||
package eu.mhsl.craftattack.spawn.craftattack.appliances.tooling.strike;
|
|
||||||
|
|
||||||
import eu.mhsl.craftattack.spawn.core.appliance.Appliance;
|
|
||||||
|
|
||||||
import java.time.Duration;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class Strike extends Appliance {
|
|
||||||
public Strike() {
|
|
||||||
super("strike");
|
|
||||||
}
|
|
||||||
|
|
||||||
private final Map<Integer, Duration> strikePunishmentMap = Map.of(
|
|
||||||
1, Duration.ofHours(1),
|
|
||||||
2, Duration.ofHours(24),
|
|
||||||
3, Duration.ofDays(3),
|
|
||||||
4, Duration.ofDays(7)
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -47,7 +47,7 @@ public class Whitelist extends Appliance {
|
|||||||
player.getUniqueId()
|
player.getUniqueId()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
this.queryAppliance(Outlawed.class).updateForcedStatus(player, this.timestampRelevant(0L)); // TODO
|
this.queryAppliance(Outlawed.class).updateForcedStatus(player, this.timestampRelevant(user.outlawed_until()));
|
||||||
|
|
||||||
String purePlayerName = Floodgate.isBedrock(player)
|
String purePlayerName = Floodgate.isBedrock(player)
|
||||||
? Floodgate.getBedrockPlayer(player).getUsername()
|
? Floodgate.getBedrockPlayer(player).getUsername()
|
||||||
@@ -67,14 +67,14 @@ public class Whitelist extends Appliance {
|
|||||||
Main.instance().getLogger().info(String.format("Running integrityCheck for %s", name));
|
Main.instance().getLogger().info(String.format("Running integrityCheck for %s", name));
|
||||||
boolean overrideCheck = this.localConfig().getBoolean("overrideIntegrityCheck", false);
|
boolean overrideCheck = this.localConfig().getBoolean("overrideIntegrityCheck", false);
|
||||||
WhitelistRepository.UserData user = overrideCheck
|
WhitelistRepository.UserData user = overrideCheck
|
||||||
? new WhitelistRepository.UserData(uuid, name, "", "", List.of())
|
? new WhitelistRepository.UserData(uuid, name, "", "", 0L, 0L)
|
||||||
: this.fetchUserData(uuid);
|
: this.fetchUserData(uuid);
|
||||||
|
|
||||||
this.userData.put(uuid, user);
|
this.userData.put(uuid, user);
|
||||||
Main.logger().info(String.format("got userdata %s", user.toString()));
|
Main.logger().info(String.format("got userdata %s", user.toString()));
|
||||||
|
|
||||||
if(this.timestampRelevant(0L)) { //TODO
|
if(this.timestampRelevant(user.banned_until())) {
|
||||||
Instant bannedDate = new Date(0 * 1000L) // TODO
|
Instant bannedDate = new Date(user.banned_until() * 1000L)
|
||||||
.toInstant()
|
.toInstant()
|
||||||
.plus(1, ChronoUnit.HOURS);
|
.plus(1, ChronoUnit.HOURS);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user