Compare commits
113 Commits
v1.34.4-be
...
master
Author | SHA1 | Date | |
---|---|---|---|
a4c61f183c | |||
eeb0f1adc7 | |||
87fc89407d | |||
85b9becfab | |||
2e589287b5 | |||
ba495d9bd7 | |||
bbb97b0859 | |||
150939dc45 | |||
0cb2ac81d4 | |||
a39030e258 | |||
fd853661e3 | |||
230e26037f | |||
9660968125 | |||
765fef5c66 | |||
6978e4f05b | |||
3ec3c63724 | |||
170dd8cbe7 | |||
a321e39fe5 | |||
0e638e00b2 | |||
3fe0ebfe3c | |||
16d2ae73d8 | |||
7f04300fc3 | |||
5f3051aaf9 | |||
761d51c653 | |||
a66014227c | |||
0471764641 | |||
53ec758ad4 | |||
4ebcb4e7fd | |||
a37f194d1b | |||
c0fcc2aaa0 | |||
bb32f085ac | |||
e6cea57dfe | |||
ee470c6cad | |||
8da3c1e871 | |||
c9ea2384a0 | |||
99125fa924 | |||
15793e24b4 | |||
4deb2ac5fa | |||
3923973778 | |||
e0bd285e74 | |||
cabd3149ff | |||
96c07e3067 | |||
0ad56e3c0b | |||
4a8ae8b568 | |||
c74b332e65 | |||
010e9386da | |||
8bee085eda | |||
533063ee7c | |||
86fe23421f | |||
36a32c1d7b | |||
9180a2a4e0 | |||
49772fadc9 | |||
6007773710 | |||
316abaef33 | |||
2c013e0eb4 | |||
86d40fedb2 | |||
9e1ad7640a | |||
79d7f13a94 | |||
5e5d45e1d7 | |||
bdfb368716 | |||
46d15d01eb | |||
26fa5f60a5 | |||
f22b97a7f7 | |||
8b9e984917 | |||
bdec39272c | |||
ee2cc157d0 | |||
d348ee76f9 | |||
c2caf96c03 | |||
e3cd0a04a8 | |||
4706e1325a | |||
066d7a389b | |||
9a11f4b1f9 | |||
00193c5cb9 | |||
ff0a65a3d5 | |||
fc09831546 | |||
aeb8264645 | |||
390333e782 | |||
fe75a3cfda | |||
1297f0cb34 | |||
4d1325a126 | |||
81e7cdd217 | |||
4beeea5040 | |||
6f1ae1a904 | |||
aa31a45cec | |||
9c2d18cc3e | |||
b3934b9fe2 | |||
de2d8758d1 | |||
0fe7f28c64 | |||
4c8066f7cb | |||
cc2423dd1b | |||
ba81403d6f | |||
f3c52fe8e5 | |||
95d6d809b0 | |||
c859718f8b | |||
23eb35c8b3 | |||
fb1736e0f2 | |||
c858332fbd | |||
9997fc12a9 | |||
eb9fd31277 | |||
|
e7a5e2b37f | ||
32c730e28c | |||
0e1eb53465 | |||
f08e0f51e2 | |||
6a3f9fbd20 | |||
26f87ab835 | |||
a119cf747f | |||
4498267c50 | |||
0d714a402b | |||
21a5b10a97 | |||
e690b3f66a | |||
9b94a2c5a6 | |||
9a36ddbc06 | |||
2f7ae111a9 |
@ -1,4 +1,4 @@
|
||||
name: Java CI-CD with Maven
|
||||
name: Java CI-CD with Gradle
|
||||
|
||||
on:
|
||||
push:
|
||||
@ -13,18 +13,17 @@ jobs:
|
||||
uses: https://ssl.lunadeer.cn:14446/actions/checkout@v3
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- name: "Set up Maven"
|
||||
uses: https://ssl.lunadeer.cn:14446/actions/setup-maven@v4
|
||||
- name: "Set up JDK 17"
|
||||
- name: "Set up JDK 21"
|
||||
uses: https://ssl.lunadeer.cn:14446/actions/setup-java@v3
|
||||
with:
|
||||
java-version: '17'
|
||||
java-version: '21'
|
||||
distribution: 'zulu'
|
||||
cache: maven
|
||||
- name: "Build with Maven"
|
||||
run: mvn -B package --file pom.xml
|
||||
cache: gradle
|
||||
- name: "Build with Gradle"
|
||||
run: |
|
||||
./gradlew buildPlugin
|
||||
- name: "Copy jar to staging"
|
||||
run: mkdir staging && cp target/*.jar staging
|
||||
run: mkdir staging && cp build/libs/*.jar staging/
|
||||
- name: "Build & test"
|
||||
run: |
|
||||
echo "done!"
|
||||
|
27
.github/workflows/main.yml
vendored
27
.github/workflows/main.yml
vendored
@ -1,4 +1,4 @@
|
||||
name: Java CI-CD with Maven
|
||||
name: Java CI-CD with Gradle
|
||||
|
||||
on:
|
||||
push:
|
||||
@ -11,33 +11,24 @@ jobs:
|
||||
permissions: write-all
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
# 下载代码
|
||||
- uses: actions/checkout@v3
|
||||
- name: Set up JDK 17
|
||||
# 安装 JDK
|
||||
- name: Set up JDK 21
|
||||
uses: actions/setup-java@v3
|
||||
with:
|
||||
java-version: '17'
|
||||
distribution: 'temurin'
|
||||
cache: maven
|
||||
# Maven 打包
|
||||
- name: Build with Maven
|
||||
run: mvn -B package --file pom.xml
|
||||
# 将打包好的 Jar 包 放到 staging 文件夹
|
||||
- run: mkdir staging && cp target/*.jar staging
|
||||
# 设置 jobs Maven pom 版本环境变量
|
||||
- name: Set Release version env variable
|
||||
run: |
|
||||
echo "RELEASE_VERSION=$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout)" >> $GITHUB_ENV
|
||||
java-version: '21'
|
||||
distribution: 'zulu'
|
||||
cache: gradle
|
||||
- name: "Build with Gradle"
|
||||
run: ./gradlew buildPlugin
|
||||
- name: "Copy jar to staging"
|
||||
run: mkdir staging && cp build/libs/*.jar staging/
|
||||
- name: "Build & test"
|
||||
run: |
|
||||
echo "done!"
|
||||
# 上传文件并发布 Release
|
||||
- uses: "marvinpinto/action-automatic-releases@latest"
|
||||
with:
|
||||
repo_token: "${{ secrets.GITHUB_TOKEN }}"
|
||||
automatic_release_tag: "latest"
|
||||
prerelease: false
|
||||
title: "Release ${{ env.RELEASE_VERSION }}"
|
||||
files: |
|
||||
staging/*.jar
|
||||
|
9
LICENSE
Normal file
9
LICENSE
Normal file
@ -0,0 +1,9 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2024 ZhangYuheng
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
26
README.md
26
README.md
@ -1,22 +1,20 @@
|
||||
<div style="text-align: center;">
|
||||
<div align="center">
|
||||
|
||||
<img src="https://ssl.lunadeer.cn:14437/i/2024/03/28/6604f0cec0f0e.png" alt="" width="70%">
|
||||
|
||||
### [开源地址](https://ssl.lunadeer.cn:14446/zhangyuheng/Dominion) | [文档地址](https://ssl.lunadeer.cn:14448/doc/23/)
|
||||
### [开源地址](https://github.com/DeerGiteaMirror/Dominion) | [文档地址](https://ssl.lunadeer.cn:14448/doc/23/)
|
||||
|
||||
### [下载页面](https://ssl.lunadeer.cn:14446/zhangyuheng/Dominion/releases)
|
||||
|
||||
### [统计页面](https://bstats.org/plugin/bukkit/Dominion/21445) | [Hangar](https://hangar.papermc.io/zhangyuheng/Dominion)
|
||||
|
||||
[![CodeFactor](https://www.codefactor.io/repository/github/deergiteamirror/dominion/badge/master)](https://www.codefactor.io/repository/github/deergiteamirror/dominion/overview/master)
|
||||
|
||||
</div>
|
||||
|
||||
## 简介
|
||||
|
||||
鉴于 Residence 插件的作者项目较多,维护压力大,无法及时跟进新版本以及适配Folia核心。故开发此插件,旨在平替纯净版生存服Residence的使用。
|
||||
鉴于 Residence 插件的作者项目较多,维护压力大,无法及时跟进新版本以及适配Folia核心。故开发此插件,旨在平替纯净版生存服Residence的使用(支持从 Res 迁移数据)。
|
||||
|
||||
请注意,本插件仍然处于测试阶段,因此可能存在一定的行为控制漏洞。如果遇到此类遗漏的行为控制欢迎即使发送邮件或添加QQ告知,感激不尽。
|
||||
**请注意,本插件目前处于中期测试稳定阶段,绝大多数bug或漏洞已被修复,目前已具备完全可用性。但不排除仍然存在某些问题,如果遇到任何 BUG 欢迎及时发送邮件或添加QQ群告知,感激不尽。**
|
||||
|
||||
## 说明
|
||||
|
||||
@ -31,7 +29,7 @@
|
||||
## 功能介绍
|
||||
|
||||
- 支持 Postgresql、Mysql、Sqlite3 存储数据;
|
||||
- 支持BlueMap卫星地图渲染;
|
||||
- 支持 BlueMap、Dynmap 卫星地图渲染;
|
||||
- 支持为玩家单独设置特权;
|
||||
- 支持设置领地管理员;
|
||||
- 支持子领地;
|
||||
@ -40,21 +38,25 @@
|
||||
- 领地区域可视化;
|
||||
- 管理员可在游戏内使用TUI配置领地系统;
|
||||
- 支持[从 Residence 迁移](https://ssl.lunadeer.cn:14448/doc/73/)领地数据(1.33.7+);
|
||||
- 超高性能(一个坐标在10127个领地内的搜索平均耗时不超过0.2ms,仅占用1tick的不到0.4%时间)
|
||||
|
||||
<div style="text-align: center;">
|
||||
<div align="center">
|
||||
|
||||
创建领地
|
||||
### 创建领地
|
||||
|
||||
<img src="https://ssl.lunadeer.cn:14437/i/2024/05/10/663debf78eca4.gif" alt="" width="60%">
|
||||
|
||||
权限管理
|
||||
### 权限管理
|
||||
|
||||
<img src="https://ssl.lunadeer.cn:14437/i/2024/05/10/663debe052786.gif" alt="" width="60%">
|
||||
|
||||
配置
|
||||
### 配置
|
||||
|
||||
<img src="https://ssl.lunadeer.cn:14437/i/2024/05/10/663debec11dad.gif" alt="" width="60%">
|
||||
|
||||
### 高性能
|
||||
|
||||
<img src="https://ssl.lunadeer.cn:14437/i/2024/08/13/66bad56cc9fac.png" alt="" width="60%">
|
||||
|
||||
</div>
|
||||
|
||||
@ -62,6 +64,8 @@
|
||||
|
||||
- 1.20.1+ (Bukkit、Spigot、Paper、Folia)
|
||||
|
||||
> 需要使用 Java21 运行你的服务端,如果你还在使用 Java17 可以放心替换为 Java21,理论上 1.20.1+ 版本的服务端核心可以直接升级到 Java21 启动。
|
||||
|
||||
## TODO
|
||||
|
||||
- WebUI
|
||||
|
73
build.gradle.kts
Normal file
73
build.gradle.kts
Normal file
@ -0,0 +1,73 @@
|
||||
plugins {
|
||||
id("java")
|
||||
id("com.github.johnrengelman.shadow") version "8.1.1"
|
||||
}
|
||||
|
||||
group = "cn.lunadeer"
|
||||
version = "2.3.0-beta"
|
||||
|
||||
java {
|
||||
toolchain.languageVersion.set(JavaLanguageVersion.of(21))
|
||||
}
|
||||
|
||||
// utf-8
|
||||
tasks.withType<JavaCompile> {
|
||||
options.encoding = "UTF-8"
|
||||
}
|
||||
|
||||
allprojects {
|
||||
apply(plugin = "java")
|
||||
apply(plugin = "com.github.johnrengelman.shadow")
|
||||
|
||||
repositories {
|
||||
mavenLocal()
|
||||
mavenCentral()
|
||||
maven("https://oss.sonatype.org/content/groups/public")
|
||||
maven("https://repo.papermc.io/repository/maven-public/")
|
||||
maven("https://jitpack.io")
|
||||
maven("https://repo.mikeprimm.com/")
|
||||
maven("https://ssl.lunadeer.cn:14454/repository/maven-snapshots/")
|
||||
maven("https://repo.extendedclip.com/content/repositories/placeholderapi/")
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compileOnly("com.github.BlueMap-Minecraft:BlueMapAPI:v2.6.2")
|
||||
compileOnly("us.dynmap:DynmapCoreAPI:3.4")
|
||||
compileOnly("me.clip:placeholderapi:2.11.6")
|
||||
|
||||
implementation("cn.lunadeer:MinecraftPluginUtils:1.3.7-SNAPSHOT")
|
||||
implementation("org.yaml:snakeyaml:2.0")
|
||||
}
|
||||
|
||||
tasks.processResources {
|
||||
outputs.upToDateWhen { false }
|
||||
// replace @version@ in plugin.yml with project version
|
||||
filesMatching("**/plugin.yml") {
|
||||
filter {
|
||||
it.replace("@version@", rootProject.version.toString())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
tasks.shadowJar {
|
||||
archiveClassifier.set("")
|
||||
archiveVersion.set(project.version.toString())
|
||||
dependsOn(tasks.withType<ProcessResources>())
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
implementation(project(":core"))
|
||||
implementation(project(":v1_20_1"))
|
||||
implementation(project(":v1_21"))
|
||||
}
|
||||
|
||||
tasks.shadowJar {
|
||||
archiveClassifier.set("")
|
||||
archiveVersion.set(project.version.toString())
|
||||
}
|
||||
|
||||
tasks.register("buildPlugin") { // <<<< RUN THIS TASK TO BUILD PLUGIN
|
||||
dependsOn(tasks.clean)
|
||||
dependsOn(tasks.shadowJar)
|
||||
}
|
16
core/build.gradle.kts
Normal file
16
core/build.gradle.kts
Normal file
@ -0,0 +1,16 @@
|
||||
plugins {
|
||||
id("java")
|
||||
}
|
||||
|
||||
java {
|
||||
toolchain.languageVersion.set(JavaLanguageVersion.of(21))
|
||||
}
|
||||
|
||||
// utf-8
|
||||
tasks.withType<JavaCompile> {
|
||||
options.encoding = "UTF-8"
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compileOnly("io.papermc.paper:paper-api:1.20.1-R0.1-SNAPSHOT")
|
||||
}
|
591
core/src/main/java/cn/lunadeer/dominion/Cache.java
Normal file
591
core/src/main/java/cn/lunadeer/dominion/Cache.java
Normal file
@ -0,0 +1,591 @@
|
||||
package cn.lunadeer.dominion;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.*;
|
||||
import cn.lunadeer.dominion.utils.MapRender;
|
||||
import cn.lunadeer.dominion.utils.Particle;
|
||||
import cn.lunadeer.dominion.utils.ResMigration;
|
||||
import cn.lunadeer.minecraftpluginutils.AutoTimer;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.GameMode;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.CompletableFuture;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
import java.util.concurrent.atomic.AtomicBoolean;
|
||||
import java.util.concurrent.atomic.AtomicLong;
|
||||
|
||||
import static cn.lunadeer.dominion.DominionNode.getLocInDominionNode;
|
||||
import static cn.lunadeer.dominion.DominionNode.isInDominion;
|
||||
|
||||
public class Cache {
|
||||
|
||||
public Cache() {
|
||||
player_current_dominion_id = new HashMap<>();
|
||||
loadDominions();
|
||||
loadMembers();
|
||||
loadGroups();
|
||||
}
|
||||
|
||||
/**
|
||||
* 从数据库加载所有领地
|
||||
* 如果idToLoad为null,则加载所有领地
|
||||
*
|
||||
* @param idToLoad 领地ID
|
||||
*/
|
||||
public void loadDominions(Integer idToLoad) {
|
||||
if (_last_update_dominion.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadDominionsExecution directly");
|
||||
loadDominionsExecution(idToLoad);
|
||||
} else {
|
||||
if (_update_dominion_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadDominionsExecution");
|
||||
_update_dominion_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_dominion.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadDominionsExecution scheduled");
|
||||
loadDominionsExecution(idToLoad);
|
||||
_update_dominion_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
public void loadDominions() {
|
||||
loadDominions(null);
|
||||
}
|
||||
|
||||
private void loadDominionsExecution(Integer idToLoad) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
int count = 0;
|
||||
if (idToLoad == null) {
|
||||
id_dominions = new ConcurrentHashMap<>();
|
||||
dominion_children = new ConcurrentHashMap<>();
|
||||
|
||||
List<DominionDTO> dominions = DominionDTO.selectAll();
|
||||
CompletableFuture<Void> res = dominion_trees.initAsync(dominions);
|
||||
count = dominions.size();
|
||||
|
||||
for (DominionDTO d : dominions) {
|
||||
id_dominions.put(d.getId(), d);
|
||||
if (!dominion_children.containsKey(d.getParentDomId())) {
|
||||
dominion_children.put(d.getParentDomId(), new ArrayList<>());
|
||||
}
|
||||
dominion_children.get(d.getParentDomId()).add(d.getId());
|
||||
}
|
||||
|
||||
res.join(); // 等待树的构建完成
|
||||
} else {
|
||||
DominionDTO dominion = DominionDTO.select(idToLoad);
|
||||
if (dominion == null && id_dominions.containsKey(idToLoad)) {
|
||||
id_dominions.remove(idToLoad);
|
||||
} else if (dominion != null) {
|
||||
id_dominions.put(idToLoad, dominion);
|
||||
count = 1;
|
||||
}
|
||||
}
|
||||
MapRender.render();
|
||||
recheckPlayerState = true;
|
||||
_last_update_dominion.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadDominionsExecution cost: %d ms for %d dominions"
|
||||
, System.currentTimeMillis() - start, count);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 从数据库加载所有玩家特权
|
||||
* 如果player_uuid为null,则加载所有玩家的特权
|
||||
*
|
||||
* @param player_uuid 玩家UUID
|
||||
*/
|
||||
public void loadMembers(UUID player_uuid) {
|
||||
if (_last_update_member.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadMembersExecution directly");
|
||||
loadMembersExecution(player_uuid);
|
||||
} else {
|
||||
if (_update_member_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadMembersExecution");
|
||||
_update_member_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_member.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadMembersExecution scheduled");
|
||||
loadMembersExecution(player_uuid);
|
||||
_update_member_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
public void loadMembers() {
|
||||
loadMembers(null);
|
||||
}
|
||||
|
||||
private void loadMembersExecution(UUID player_to_update) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
List<MemberDTO> all_privileges;
|
||||
if (player_to_update == null) {
|
||||
all_privileges = MemberDTO.selectAll();
|
||||
player_uuid_to_member = new ConcurrentHashMap<>();
|
||||
} else {
|
||||
all_privileges = MemberDTO.selectAll(player_to_update);
|
||||
if (!player_uuid_to_member.containsKey(player_to_update)) {
|
||||
player_uuid_to_member.put(player_to_update, new ConcurrentHashMap<>());
|
||||
}
|
||||
player_uuid_to_member.get(player_to_update).clear();
|
||||
}
|
||||
for (MemberDTO privilege : all_privileges) {
|
||||
UUID player_uuid = privilege.getPlayerUUID();
|
||||
if (!player_uuid_to_member.containsKey(player_uuid)) {
|
||||
player_uuid_to_member.put(player_uuid, new ConcurrentHashMap<>());
|
||||
}
|
||||
player_uuid_to_member.get(player_uuid).put(privilege.getDomID(), privilege);
|
||||
}
|
||||
recheckPlayerState = true;
|
||||
_last_update_member.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadMembersExecution cost: %d ms for %d privileges"
|
||||
, System.currentTimeMillis() - start, all_privileges.size());
|
||||
});
|
||||
}
|
||||
|
||||
public void loadGroups() {
|
||||
loadGroups(null);
|
||||
}
|
||||
|
||||
public void loadGroups(Integer groupId) {
|
||||
if (_last_update_group.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadGroupsExecution directly");
|
||||
loadGroupExecution(groupId);
|
||||
} else {
|
||||
if (_update_group_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadGroupsExecution");
|
||||
_update_group_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_group.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadGroupsExecution scheduled");
|
||||
loadGroupExecution(groupId);
|
||||
_update_group_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
private void loadGroupExecution(Integer groupId) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
if (groupId == null) {
|
||||
id_groups = new ConcurrentHashMap<>();
|
||||
List<GroupDTO> groups = GroupDTO.selectAll();
|
||||
List<PlayerDTO> players = PlayerDTO.all();
|
||||
for (GroupDTO group : groups) {
|
||||
id_groups.put(group.getId(), group);
|
||||
}
|
||||
for (PlayerDTO player : players) {
|
||||
map_player_using_group_title_id.put(player.getUuid(), player.getUsingGroupTitleID());
|
||||
}
|
||||
} else {
|
||||
GroupDTO group = GroupDTO.select(groupId);
|
||||
if (group == null && id_groups.containsKey(groupId)) {
|
||||
id_groups.remove(groupId);
|
||||
} else if (group != null) {
|
||||
id_groups.put(groupId, group);
|
||||
}
|
||||
}
|
||||
recheckPlayerState = true;
|
||||
_last_update_group.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadGroupsExecution cost: %d ms", System.currentTimeMillis() - start);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取玩家当前所在领地
|
||||
* 此方法会先判断缓存中是否有玩家当前所在领地,如果没有则遍历所有领地判断玩家所在位置
|
||||
* 如果玩家不在任何领地内,则返回null
|
||||
* 如果玩家在领地内,则返回领地信息
|
||||
*
|
||||
* @param player 玩家
|
||||
* @return 玩家当前所在领地
|
||||
*/
|
||||
public DominionDTO getPlayerCurrentDominion(Player player) {
|
||||
try (AutoTimer ignored = new AutoTimer(Dominion.config.TimerEnabled())) {
|
||||
Integer last_in_dom_id = player_current_dominion_id.get(player.getUniqueId());
|
||||
DominionDTO last_dominion = null;
|
||||
if (last_in_dom_id != null) {
|
||||
last_dominion = id_dominions.get(last_in_dom_id);
|
||||
}
|
||||
if (isInDominion(last_dominion, player.getLocation())) {
|
||||
if (dominion_children.get(last_in_dom_id) == null || dominion_children.get(last_in_dom_id).isEmpty()) {
|
||||
// 如果玩家仍在领地内,且领地没有子领地,则直接返回
|
||||
if (recheckPlayerState) {
|
||||
lightOrNot(player, last_dominion);
|
||||
flyOrNot(player, last_dominion);
|
||||
recheckPlayerState = false;
|
||||
}
|
||||
return last_dominion;
|
||||
}
|
||||
}
|
||||
DominionDTO current_dominion = dominion_trees.getLocInDominionDTO(player.getLocation());
|
||||
int last_dom_id = last_dominion == null ? -1 : last_dominion.getId();
|
||||
int current_dom_id = current_dominion == null ? -1 : current_dominion.getId();
|
||||
if (last_dom_id == current_dom_id) {
|
||||
return last_dominion;
|
||||
}
|
||||
if (last_dom_id != -1) {
|
||||
String msg = last_dominion.getLeaveMessage();
|
||||
msg = msg.replace("${DOM_NAME}", last_dominion.getName());
|
||||
Notification.actionBar(player, msg);
|
||||
}
|
||||
if (current_dom_id != -1) {
|
||||
String msg = current_dominion.getJoinMessage();
|
||||
msg = msg.replace("${DOM_NAME}", current_dominion.getName());
|
||||
Notification.actionBar(player, msg);
|
||||
}
|
||||
|
||||
lightOrNot(player, current_dominion); // 发光检查
|
||||
flyOrNot(player, current_dominion); // 飞行检查
|
||||
if (current_dominion == null) {
|
||||
player_current_dominion_id.put(player.getUniqueId(), null);
|
||||
return null;
|
||||
}
|
||||
player_current_dominion_id.put(player.getUniqueId(), current_dominion.getId());
|
||||
// show border
|
||||
if (current_dominion.getFlagValue(Flag.SHOW_BORDER)) {
|
||||
Particle.showBorder(player, current_dominion);
|
||||
}
|
||||
return current_dominion;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 玩家退出时调用 用于清除玩家当前所在领地
|
||||
* 会将玩家当前所在领地设置为null
|
||||
* 这样当玩家下次进入领地时,会重新检查玩家所在位置
|
||||
*
|
||||
* @param player 玩家
|
||||
*/
|
||||
public void onPlayerQuit(Player player) {
|
||||
player_current_dominion_id.put(player.getUniqueId(), null);
|
||||
}
|
||||
|
||||
/**
|
||||
* 检查玩家是否需要设置为发光
|
||||
*
|
||||
* @param player 玩家
|
||||
* @param dominion 领地
|
||||
*/
|
||||
private void lightOrNot(Player player, DominionDTO dominion) {
|
||||
if (!Flag.GLOW.getEnable()) {
|
||||
return;
|
||||
}
|
||||
if (dominion == null) {
|
||||
player.setGlowing(false);
|
||||
return;
|
||||
}
|
||||
MemberDTO privilege = getMember(player, dominion);
|
||||
if (privilege != null) {
|
||||
if (privilege.getGroupId() == -1) {
|
||||
player.setGlowing(privilege.getFlagValue(Flag.GLOW));
|
||||
} else {
|
||||
GroupDTO group = getGroup(privilege.getGroupId());
|
||||
if (group != null) {
|
||||
player.setGlowing(group.getFlagValue(Flag.GLOW));
|
||||
} else {
|
||||
player.setGlowing(dominion.getFlagValue(Flag.GLOW));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
player.setGlowing(dominion.getFlagValue(Flag.GLOW));
|
||||
}
|
||||
}
|
||||
|
||||
private void flyOrNot(Player player, DominionDTO dominion) {
|
||||
for (String flyPN : Dominion.config.getFlyPermissionNodes()) {
|
||||
if (player.hasPermission(flyPN)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (player.getGameMode() == GameMode.CREATIVE || player.getGameMode() == GameMode.SPECTATOR) {
|
||||
return;
|
||||
}
|
||||
if (player.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return;
|
||||
}
|
||||
if (!Flag.FLY.getEnable()) {
|
||||
player.setAllowFlight(false);
|
||||
return;
|
||||
}
|
||||
if (dominion == null) {
|
||||
player.setAllowFlight(false);
|
||||
return;
|
||||
}
|
||||
MemberDTO privilege = getMember(player, dominion);
|
||||
if (privilege != null) {
|
||||
if (privilege.getGroupId() == -1) {
|
||||
player.setAllowFlight(privilege.getFlagValue(Flag.FLY));
|
||||
} else {
|
||||
GroupDTO group = getGroup(privilege.getGroupId());
|
||||
if (group != null) {
|
||||
player.setAllowFlight(group.getFlagValue(Flag.FLY));
|
||||
} else {
|
||||
player.setAllowFlight(dominion.getFlagValue(Flag.FLY));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
player.setAllowFlight(dominion.getFlagValue(Flag.FLY));
|
||||
}
|
||||
}
|
||||
|
||||
public DominionDTO getDominionByLoc(Location loc) {
|
||||
return dominion_trees.getLocInDominionDTO(loc);
|
||||
}
|
||||
|
||||
public GroupDTO getGroup(Integer id) {
|
||||
return id_groups.get(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取玩家在指定领地的特权
|
||||
* 如果玩家不存在特权,则返回null
|
||||
*
|
||||
* @param player 玩家
|
||||
* @param dominion 领地
|
||||
* @return 特权表
|
||||
*/
|
||||
public MemberDTO getMember(Player player, DominionDTO dominion) {
|
||||
if (!player_uuid_to_member.containsKey(player.getUniqueId())) return null;
|
||||
return player_uuid_to_member.get(player.getUniqueId()).get(dominion.getId());
|
||||
}
|
||||
|
||||
public MemberDTO getMember(UUID player_uuid, DominionDTO dominion) {
|
||||
if (!player_uuid_to_member.containsKey(player_uuid)) return null;
|
||||
return player_uuid_to_member.get(player_uuid).get(dominion.getId());
|
||||
}
|
||||
|
||||
public List<GroupDTO> getBelongGroupsOf(UUID plauer_uuid) {
|
||||
List<GroupDTO> groups = new ArrayList<>();
|
||||
if (!player_uuid_to_member.containsKey(plauer_uuid)) return groups;
|
||||
for (MemberDTO member : player_uuid_to_member.get(plauer_uuid).values()) {
|
||||
if (member.getGroupId() != -1) {
|
||||
GroupDTO group = getGroup(member.getGroupId());
|
||||
if (group != null) {
|
||||
groups.add(group);
|
||||
}
|
||||
}
|
||||
}
|
||||
return groups;
|
||||
}
|
||||
|
||||
public DominionDTO getDominion(Integer id) {
|
||||
return id_dominions.get(id);
|
||||
}
|
||||
|
||||
public int getPlayerDominionCount(UUID player_uuid) {
|
||||
int count = 0;
|
||||
for (DominionDTO dominion : id_dominions.values()) {
|
||||
if (dominion.getOwner().equals(player_uuid)) {
|
||||
count++;
|
||||
}
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
public List<ResMigration.ResidenceNode> getResidenceData(UUID player_uuid) {
|
||||
if (residence_data == null) {
|
||||
residence_data = new HashMap<>();
|
||||
List<ResMigration.ResidenceNode> residences = ResMigration.extractFromResidence(Dominion.instance);
|
||||
for (ResMigration.ResidenceNode node : residences) {
|
||||
if (node == null) {
|
||||
continue;
|
||||
}
|
||||
if (!residence_data.containsKey(node.owner)) {
|
||||
XLogger.debug("residence_data put %s", node.owner);
|
||||
residence_data.put(node.owner, new ArrayList<>());
|
||||
}
|
||||
residence_data.get(node.owner).add(node);
|
||||
}
|
||||
XLogger.debug("residence_data: %d", residence_data.size());
|
||||
}
|
||||
return residence_data.get(player_uuid);
|
||||
}
|
||||
|
||||
public List<DominionDTO> getDominions() {
|
||||
return new ArrayList<>(id_dominions.values());
|
||||
}
|
||||
|
||||
public int getDominionCounts() {
|
||||
return id_dominions.size();
|
||||
}
|
||||
|
||||
public int getMemberCounts() {
|
||||
int count = 0;
|
||||
for (Map<Integer, MemberDTO> member : player_uuid_to_member.values()) {
|
||||
count += member.size();
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
public int getGroupCounts() {
|
||||
return id_groups.size();
|
||||
}
|
||||
|
||||
public static Cache instance;
|
||||
private ConcurrentHashMap<Integer, DominionDTO> id_dominions;
|
||||
private ConcurrentHashMap<Integer, GroupDTO> id_groups;
|
||||
private final WorldDominionTreeSectored dominion_trees = new WorldDominionTreeSectored();
|
||||
private ConcurrentHashMap<UUID, ConcurrentHashMap<Integer, MemberDTO>> player_uuid_to_member; // 玩家所有的特权
|
||||
private final Map<UUID, Integer> player_current_dominion_id; // 玩家当前所在领地
|
||||
private ConcurrentHashMap<Integer, List<Integer>> dominion_children;
|
||||
private final AtomicLong _last_update_dominion = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_dominion_is_scheduled = new AtomicBoolean(false);
|
||||
private final AtomicLong _last_update_member = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_member_is_scheduled = new AtomicBoolean(false);
|
||||
private final AtomicLong _last_update_group = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_group_is_scheduled = new AtomicBoolean(false);
|
||||
private static final long UPDATE_INTERVAL = 1000 * 4;
|
||||
private boolean recheckPlayerState = false; // 是否需要重新检查玩家状态(发光、飞行)
|
||||
public final Map<UUID, LocalDateTime> NextTimeAllowTeleport = new java.util.HashMap<>();
|
||||
|
||||
private Map<UUID, List<ResMigration.ResidenceNode>> residence_data = null;
|
||||
|
||||
private final Map<UUID, Integer> map_player_using_group_title_id = new HashMap<>();
|
||||
|
||||
private static class WorldDominionTreeSectored {
|
||||
/*
|
||||
D | C
|
||||
--+--
|
||||
B | A
|
||||
*/
|
||||
|
||||
private ConcurrentHashMap<UUID, List<DominionNode>> world_dominion_tree_sector_a; // x >= 0, z >= 0
|
||||
private ConcurrentHashMap<UUID, List<DominionNode>> world_dominion_tree_sector_b; // x <= 0, z >= 0
|
||||
private ConcurrentHashMap<UUID, List<DominionNode>> world_dominion_tree_sector_c; // x >= 0, z <= 0
|
||||
private ConcurrentHashMap<UUID, List<DominionNode>> world_dominion_tree_sector_d; // x <= 0, z <= 0
|
||||
|
||||
public DominionDTO getLocInDominionDTO(@NotNull Location loc) {
|
||||
try (AutoTimer ignored = new AutoTimer(Dominion.config.TimerEnabled())) {
|
||||
List<DominionNode> nodes = getNodes(loc);
|
||||
if (nodes == null) return null;
|
||||
if (nodes.isEmpty()) return null;
|
||||
DominionNode dominionNode = getLocInDominionNode(nodes, loc);
|
||||
return dominionNode == null ? null : dominionNode.getDominion();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public List<DominionNode> getNodes(@NotNull Location loc) {
|
||||
return getNodes(loc.getWorld().getUID(), loc.getBlockX(), loc.getBlockZ());
|
||||
}
|
||||
|
||||
public List<DominionNode> getNodes(World world, int x, int z) {
|
||||
return getNodes(world.getUID(), x, z);
|
||||
}
|
||||
|
||||
public List<DominionNode> getNodes(UUID world, int x, int z) {
|
||||
if (x >= 0 && z >= 0) {
|
||||
return world_dominion_tree_sector_a.get(world);
|
||||
}
|
||||
if (x <= 0 && z >= 0) {
|
||||
return world_dominion_tree_sector_b.get(world);
|
||||
}
|
||||
if (x >= 0) {
|
||||
return world_dominion_tree_sector_c.get(world);
|
||||
}
|
||||
return world_dominion_tree_sector_d.get(world);
|
||||
}
|
||||
|
||||
public CompletableFuture<Void> initAsync(List<DominionDTO> dominions) {
|
||||
return CompletableFuture.runAsync(() -> init(dominions));
|
||||
}
|
||||
|
||||
|
||||
private void init(List<DominionDTO> dominions) {
|
||||
world_dominion_tree_sector_a = new ConcurrentHashMap<>();
|
||||
world_dominion_tree_sector_b = new ConcurrentHashMap<>();
|
||||
world_dominion_tree_sector_c = new ConcurrentHashMap<>();
|
||||
world_dominion_tree_sector_d = new ConcurrentHashMap<>();
|
||||
|
||||
Map<UUID, List<DominionDTO>> world_dominions_sector_a = new HashMap<>();
|
||||
Map<UUID, List<DominionDTO>> world_dominions_sector_b = new HashMap<>();
|
||||
Map<UUID, List<DominionDTO>> world_dominions_sector_c = new HashMap<>();
|
||||
Map<UUID, List<DominionDTO>> world_dominions_sector_d = new HashMap<>();
|
||||
for (DominionDTO d : dominions) {
|
||||
// 对每个世界的领地进行四个象限的划分
|
||||
if (!world_dominions_sector_a.containsKey(d.getWorldUid()) ||
|
||||
!world_dominions_sector_b.containsKey(d.getWorldUid()) ||
|
||||
!world_dominions_sector_c.containsKey(d.getWorldUid()) ||
|
||||
!world_dominions_sector_d.containsKey(d.getWorldUid())) {
|
||||
world_dominions_sector_a.put(d.getWorldUid(), new ArrayList<>());
|
||||
world_dominions_sector_b.put(d.getWorldUid(), new ArrayList<>());
|
||||
world_dominions_sector_c.put(d.getWorldUid(), new ArrayList<>());
|
||||
world_dominions_sector_d.put(d.getWorldUid(), new ArrayList<>());
|
||||
}
|
||||
if (d.getX1() >= 0 && d.getZ1() >= 0) {
|
||||
world_dominions_sector_a.get(d.getWorldUid()).add(d);
|
||||
} else if (d.getX1() <= 0 && d.getZ1() >= 0) {
|
||||
if (d.getX2() >= 0) {
|
||||
world_dominions_sector_a.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_b.get(d.getWorldUid()).add(d);
|
||||
} else {
|
||||
world_dominions_sector_b.get(d.getWorldUid()).add(d);
|
||||
}
|
||||
} else if (d.getX1() >= 0 && d.getZ1() <= 0) {
|
||||
if (d.getZ2() >= 0) {
|
||||
world_dominions_sector_a.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_c.get(d.getWorldUid()).add(d);
|
||||
} else {
|
||||
world_dominions_sector_c.get(d.getWorldUid()).add(d);
|
||||
}
|
||||
} else {
|
||||
if (d.getX2() >= 0 && d.getZ2() >= 0) {
|
||||
world_dominions_sector_a.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_b.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_c.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_d.get(d.getWorldUid()).add(d);
|
||||
} else if (d.getX2() >= 0 && d.getZ2() <= 0) {
|
||||
world_dominions_sector_c.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_d.get(d.getWorldUid()).add(d);
|
||||
} else if (d.getZ2() >= 0 && d.getX2() <= 0) {
|
||||
world_dominions_sector_b.get(d.getWorldUid()).add(d);
|
||||
world_dominions_sector_d.get(d.getWorldUid()).add(d);
|
||||
} else {
|
||||
world_dominions_sector_d.get(d.getWorldUid()).add(d);
|
||||
}
|
||||
}
|
||||
}
|
||||
for (Map.Entry<UUID, List<DominionDTO>> entry : world_dominions_sector_a.entrySet()) {
|
||||
world_dominion_tree_sector_a.put(entry.getKey(), DominionNode.BuildNodeTree(-1, entry.getValue()));
|
||||
}
|
||||
for (Map.Entry<UUID, List<DominionDTO>> entry : world_dominions_sector_b.entrySet()) {
|
||||
world_dominion_tree_sector_b.put(entry.getKey(), DominionNode.BuildNodeTree(-1, entry.getValue()));
|
||||
}
|
||||
for (Map.Entry<UUID, List<DominionDTO>> entry : world_dominions_sector_c.entrySet()) {
|
||||
world_dominion_tree_sector_c.put(entry.getKey(), DominionNode.BuildNodeTree(-1, entry.getValue()));
|
||||
}
|
||||
for (Map.Entry<UUID, List<DominionDTO>> entry : world_dominions_sector_d.entrySet()) {
|
||||
world_dominion_tree_sector_d.put(entry.getKey(), DominionNode.BuildNodeTree(-1, entry.getValue()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public @Nullable GroupDTO getPlayerUsingGroupTitle(UUID uuid) {
|
||||
if (!Dominion.config.getGroupTitleEnable()) {
|
||||
return null;
|
||||
}
|
||||
if (map_player_using_group_title_id.containsKey(uuid)) {
|
||||
return getGroup(map_player_using_group_title_id.get(uuid));
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public void updatePlayerUsingGroupTitle(UUID uuid, Integer groupId) {
|
||||
map_player_using_group_title_id.put(uuid, groupId);
|
||||
}
|
||||
}
|
@ -4,15 +4,13 @@ import cn.lunadeer.dominion.commands.*;
|
||||
import cn.lunadeer.dominion.controllers.PlayerController;
|
||||
import cn.lunadeer.dominion.cuis.*;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.tuis.AllDominion;
|
||||
import cn.lunadeer.dominion.tuis.Menu;
|
||||
import cn.lunadeer.dominion.tuis.MigrateList;
|
||||
import cn.lunadeer.dominion.tuis.SysConfig;
|
||||
import cn.lunadeer.dominion.tuis.*;
|
||||
import cn.lunadeer.dominion.tuis.dominion.DominionList;
|
||||
import cn.lunadeer.dominion.tuis.dominion.DominionManage;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.EnvSetting;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.GuestSetting;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.SizeInfo;
|
||||
import cn.lunadeer.dominion.utils.TuiUtils;
|
||||
import org.bukkit.command.Command;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.command.TabExecutor;
|
||||
@ -54,7 +52,7 @@ public class Commands implements TabExecutor {
|
||||
DominionList.show(sender, args);
|
||||
break;
|
||||
case "help":
|
||||
cn.lunadeer.dominion.tuis.Apis.printHelp(sender, args);
|
||||
TuiUtils.printHelp(sender, args);
|
||||
break;
|
||||
case "info":
|
||||
SizeInfo.show(sender, args);
|
||||
@ -137,6 +135,12 @@ public class Commands implements TabExecutor {
|
||||
case "env_setting":
|
||||
EnvSetting.show(sender, args);
|
||||
break;
|
||||
case "use_title":
|
||||
Title.use_title(sender, args);
|
||||
break;
|
||||
case "title_list":
|
||||
TitleList.show(sender, args);
|
||||
break;
|
||||
// ---=== Sub Command ===---
|
||||
case "member":
|
||||
Member.handle(sender, args);
|
@ -1,10 +1,10 @@
|
||||
package cn.lunadeer.dominion;
|
||||
|
||||
import cn.lunadeer.dominion.events.EnvironmentEvents;
|
||||
import cn.lunadeer.dominion.events.PlayerEvents;
|
||||
import cn.lunadeer.dominion.events.SelectPointEvents;
|
||||
import cn.lunadeer.dominion.managers.ConfigManager;
|
||||
import cn.lunadeer.dominion.managers.DatabaseTables;
|
||||
import cn.lunadeer.dominion.managers.PlaceHolderApi;
|
||||
import cn.lunadeer.dominion.utils.DynmapConnect;
|
||||
import cn.lunadeer.dominion.utils.MapRender;
|
||||
import cn.lunadeer.minecraftpluginutils.*;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseManager;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseType;
|
||||
@ -27,7 +27,6 @@ public final class Dominion extends JavaPlugin {
|
||||
new Notification(this);
|
||||
new XLogger(this);
|
||||
config = new ConfigManager(this);
|
||||
XLogger.setDebug(config.isDebug());
|
||||
new DatabaseManager(this,
|
||||
DatabaseType.valueOf(config.getDbType().toUpperCase()),
|
||||
config.getDbHost(),
|
||||
@ -39,16 +38,25 @@ public final class Dominion extends JavaPlugin {
|
||||
new Scheduler(this);
|
||||
AutoClean.run();
|
||||
Cache.instance = new Cache();
|
||||
if (config.getEconomyEnable()) {
|
||||
new VaultConnect(this);
|
||||
|
||||
if (config.getGroupTitleEnable()) {
|
||||
if (Bukkit.getPluginManager().isPluginEnabled("PlaceholderAPI")) {
|
||||
new PlaceHolderApi(this);
|
||||
} else {
|
||||
XLogger.warn("未找到 PlaceholderAPI 插件,无法使用权限组组称号功能,已自动关闭");
|
||||
config.setGroupTitleEnable(false);
|
||||
}
|
||||
}
|
||||
|
||||
Bukkit.getPluginManager().registerEvents(new PlayerEvents(), this);
|
||||
Bukkit.getPluginManager().registerEvents(new EnvironmentEvents(), this);
|
||||
Bukkit.getPluginManager().registerEvents(new SelectPointEvents(), this);
|
||||
new EventsRegister(this);
|
||||
Objects.requireNonNull(Bukkit.getPluginCommand("dominion")).setExecutor(new Commands());
|
||||
|
||||
bStatsMetrics metrics = new bStatsMetrics(this, 21445);
|
||||
metrics.addCustomChart(new bStatsMetrics.SimplePie("database", () -> config.getDbType()));
|
||||
metrics.addCustomChart(new bStatsMetrics.SingleLineChart("dominion_count", () -> Cache.instance.getDominionCounts()));
|
||||
metrics.addCustomChart(new bStatsMetrics.SingleLineChart("group_count", () -> Cache.instance.getGroupCounts()));
|
||||
metrics.addCustomChart(new bStatsMetrics.SingleLineChart("member_count", () -> Cache.instance.getMemberCounts()));
|
||||
|
||||
if (config.getCheckUpdate()) {
|
||||
giteaReleaseCheck = new GiteaReleaseCheck(this,
|
||||
"https://ssl.lunadeer.cn:14446",
|
||||
@ -70,7 +78,8 @@ public final class Dominion extends JavaPlugin {
|
||||
XLogger.info(" |_____/ \\___/|_| |_| |_|_|_| |_|_|\\___/|_| |_|");
|
||||
XLogger.info(" ");
|
||||
|
||||
Scheduler.runTaskLaterAsync(BlueMapConnect::render, 40 * 20);
|
||||
if (config.getDynmap()) new DynmapConnect(); // 注册 Dynmap API
|
||||
Scheduler.runTaskLaterAsync(MapRender::render, 40 * 20);
|
||||
}
|
||||
|
||||
@Override
|
@ -55,32 +55,21 @@ public class DominionNode {
|
||||
return node;
|
||||
} else {
|
||||
DominionNode childDominion = getLocInDominionNode(node.children, loc);
|
||||
if (childDominion == null) {
|
||||
return node;
|
||||
} else {
|
||||
return childDominion;
|
||||
}
|
||||
return Objects.requireNonNullElse(childDominion, node);
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static DominionDTO getLocInDominionDTO(@Nullable List<DominionNode> nodes, @NotNull Location loc) {
|
||||
if (nodes == null) return null;
|
||||
if (nodes.isEmpty()) return null;
|
||||
DominionNode dominionNode = getLocInDominionNode(nodes, loc);
|
||||
return dominionNode == null ? null : dominionNode.getDominion();
|
||||
}
|
||||
|
||||
public static boolean isInDominion(@Nullable DominionDTO dominion, Location location) {
|
||||
public static boolean isInDominion(@Nullable DominionDTO dominion, @NotNull Location location) {
|
||||
if (dominion == null) return false;
|
||||
if (!Objects.equals(dominion.getWorld(), location.getWorld().getName())) return false;
|
||||
if (!Objects.equals(dominion.getWorldUid(), location.getWorld().getUID())) return false;
|
||||
double x = location.getX();
|
||||
double y = location.getY();
|
||||
double z = location.getZ();
|
||||
return x >= dominion.getX1() && x <= dominion.getX2() &&
|
||||
y >= dominion.getY1() && y <= dominion.getY2() &&
|
||||
z >= dominion.getZ1() && z <= dominion.getZ2();
|
||||
return x >= dominion.getX1() && x < dominion.getX2() &&
|
||||
y >= dominion.getY1() && y < dominion.getY2() &&
|
||||
z >= dominion.getZ1() && z < dominion.getZ2();
|
||||
}
|
||||
}
|
64
core/src/main/java/cn/lunadeer/dominion/EventsRegister.java
Normal file
64
core/src/main/java/cn/lunadeer/dominion/EventsRegister.java
Normal file
@ -0,0 +1,64 @@
|
||||
package cn.lunadeer.dominion;
|
||||
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
|
||||
public class EventsRegister {
|
||||
|
||||
private JavaPlugin plugin;
|
||||
|
||||
public EventsRegister(JavaPlugin plugin) {
|
||||
APIVersion version = GetAPIVersion(plugin);
|
||||
this.plugin = plugin;
|
||||
if (version == null) {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
switch (version) {
|
||||
case v1_21:
|
||||
XLogger.debug("Load API version: 1.21");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_21.PlayerEvents");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_21.EnvironmentEvents");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_21.SelectPointEvents");
|
||||
break;
|
||||
case v1_20_1:
|
||||
XLogger.debug("Load API version: 1.20.1");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_20_1.PlayerEvents");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_20_1.EnvironmentEvents");
|
||||
registerEvents("cn.lunadeer.dominion.events_v1_20_1.SelectPointEvents");
|
||||
break;
|
||||
}
|
||||
} catch (ClassNotFoundException | IllegalAccessException | InstantiationException e) {
|
||||
XLogger.err("Failed to register events: %s", e.getMessage());
|
||||
plugin.getServer().getPluginManager().disablePlugin(plugin);
|
||||
}
|
||||
}
|
||||
|
||||
enum APIVersion {
|
||||
v1_21,
|
||||
v1_20_1
|
||||
}
|
||||
|
||||
private static APIVersion GetAPIVersion(JavaPlugin plugin) {
|
||||
String version = plugin.getServer().getBukkitVersion();
|
||||
if (version.contains("1.21")) {
|
||||
return APIVersion.v1_21;
|
||||
} else if (version.contains("1.20.1")
|
||||
|| version.contains("1.20.4")
|
||||
|| version.contains("1.20.6")) {
|
||||
return APIVersion.v1_20_1;
|
||||
}
|
||||
XLogger.err("Unsupported API version: %s", version);
|
||||
plugin.getServer().getPluginManager().disablePlugin(plugin);
|
||||
return null;
|
||||
}
|
||||
|
||||
private void registerEvents(String className) throws ClassNotFoundException, IllegalAccessException, InstantiationException {
|
||||
Class<?> clazz = Class.forName(className);
|
||||
Listener listener = (Listener) clazz.newInstance();
|
||||
Bukkit.getPluginManager().registerEvents(listener, plugin);
|
||||
}
|
||||
|
||||
}
|
@ -7,9 +7,8 @@ import cn.lunadeer.dominion.tuis.dominion.manage.EnvSetting;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.GuestSetting;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
|
||||
public class DominionFlag {
|
||||
|
||||
@ -21,9 +20,10 @@ public class DominionFlag {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void setDominionFlag(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 3) {
|
||||
FlagsController.setFlag(operator, args[1], Boolean.parseBoolean(args[2]));
|
||||
} else if (args.length == 4) {
|
@ -6,7 +6,8 @@ import cn.lunadeer.dominion.controllers.BukkitPlayerOperator;
|
||||
import cn.lunadeer.dominion.controllers.DominionController;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.Teleport;
|
||||
@ -20,8 +21,8 @@ import java.time.LocalDateTime;
|
||||
import java.util.Map;
|
||||
|
||||
import static cn.lunadeer.dominion.DominionNode.isInDominion;
|
||||
import static cn.lunadeer.dominion.commands.Apis.autoPoints;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.*;
|
||||
import static cn.lunadeer.dominion.utils.EventUtils.canByPass;
|
||||
|
||||
public class DominionOperate {
|
||||
/**
|
||||
@ -32,6 +33,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void createDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2) {
|
||||
@ -56,6 +60,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void createSubDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2 && args.length != 3) {
|
||||
@ -84,6 +91,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void autoCreateDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2) {
|
||||
@ -107,6 +117,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void autoCreateSubDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2 && args.length != 3) {
|
||||
@ -129,6 +142,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void expandDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2 && args.length != 3) {
|
||||
@ -166,6 +182,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void contractDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2 && args.length != 3) {
|
||||
@ -203,9 +222,10 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void deleteDominion(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 2) {
|
||||
String name = args[1];
|
||||
DominionController.delete(operator, name, false);
|
||||
@ -229,9 +249,10 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void setEnterMessage(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 2) {
|
||||
DominionController.setJoinMessage(operator, args[1]);
|
||||
return;
|
||||
@ -251,9 +272,10 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void setLeaveMessage(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 2) {
|
||||
DominionController.setLeaveMessage(operator, args[1]);
|
||||
return;
|
||||
@ -273,6 +295,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void setTpLocation(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
@ -298,9 +323,10 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void renameDominion(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length != 3) {
|
||||
Notification.error(sender, "用法: /dominion rename <原领地名称> <新领地名称>");
|
||||
return;
|
||||
@ -316,9 +342,10 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void giveDominion(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 3) {
|
||||
String dom_name = args[1];
|
||||
String player_name = args[2];
|
||||
@ -344,6 +371,9 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void teleportToDominion(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (args.length != 2) {
|
||||
@ -361,7 +391,11 @@ public class DominionOperate {
|
||||
if (location == null) {
|
||||
int x = (dominionDTO.getX1() + dominionDTO.getX2()) / 2;
|
||||
int z = (dominionDTO.getZ1() + dominionDTO.getZ2()) / 2;
|
||||
World world = Dominion.instance.getServer().getWorld(dominionDTO.getWorld());
|
||||
World world = dominionDTO.getWorld();
|
||||
if (world == null) {
|
||||
Notification.error(sender, "领地所在世界不存在");
|
||||
return;
|
||||
}
|
||||
location = new Location(world, x, player.getLocation().getY(), z);
|
||||
XLogger.warn("领地 %s 没有设置传送点,将尝试传送到中心点", dominionDTO.getName());
|
||||
}
|
||||
@ -374,17 +408,25 @@ public class DominionOperate {
|
||||
return;
|
||||
}
|
||||
|
||||
PlayerPrivilegeDTO privilegeDTO = PlayerPrivilegeDTO.select(player.getUniqueId(), dominionDTO.getId());
|
||||
if (!player.getUniqueId().equals(dominionDTO.getOwner())) { // 领地所有人可以传送到自己的领地
|
||||
MemberDTO privilegeDTO = MemberDTO.select(player.getUniqueId(), dominionDTO.getId());
|
||||
if (!canByPass(player, dominionDTO, privilegeDTO)) {
|
||||
if (privilegeDTO == null) {
|
||||
if (!dominionDTO.getFlagValue(Flag.TELEPORT)) {
|
||||
Notification.error(sender, "此领地禁止传送");
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
if (!privilegeDTO.getFlagValue(Flag.TELEPORT)) {
|
||||
Notification.error(sender, "你不被允许传送到这个领地");
|
||||
return;
|
||||
GroupDTO groupDTO = Cache.instance.getGroup(privilegeDTO.getGroupId());
|
||||
if (privilegeDTO.getGroupId() != -1 && groupDTO != null) {
|
||||
if (!groupDTO.getFlagValue(Flag.TELEPORT)) {
|
||||
Notification.error(sender, "你所在的权限组组不被允许传送到这个领地");
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
if (!privilegeDTO.getFlagValue(Flag.TELEPORT)) {
|
||||
Notification.error(sender, "你不被允许传送到这个领地");
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -421,13 +463,17 @@ public class DominionOperate {
|
||||
Location location = dominionDTO.getTpLocation();
|
||||
int center_x = (dominionDTO.getX1() + dominionDTO.getX2()) / 2;
|
||||
int center_z = (dominionDTO.getZ1() + dominionDTO.getZ2()) / 2;
|
||||
World world = Dominion.instance.getServer().getWorld(dominionDTO.getWorld());
|
||||
World world = dominionDTO.getWorld();
|
||||
if (world == null) {
|
||||
Notification.error(player, "领地所在世界不存在");
|
||||
return;
|
||||
}
|
||||
if (location == null) {
|
||||
location = new Location(world, center_x, player.getLocation().getY(), center_z);
|
||||
XLogger.warn("领地 %s 没有设置传送点,将尝试传送到中心点", dominionDTO.getName());
|
||||
Notification.warn(player, "领地 %s 没有设置传送点,将尝试传送到中心点", dominionDTO.getName());
|
||||
} else if (!isInDominion(dominionDTO, location)) {
|
||||
location = new Location(world, center_x, player.getLocation().getY(), center_z);
|
||||
XLogger.warn("领地 %s 传送点不在领地内,将尝试传送到中心点", dominionDTO.getName());
|
||||
Notification.warn(player, "领地 %s 传送点不在领地内,将尝试传送到中心点", dominionDTO.getName());
|
||||
}
|
||||
if (player.isOnline()) {
|
||||
Teleport.doTeleportSafely(player, location).thenAccept(b -> {
|
||||
@ -448,13 +494,14 @@ public class DominionOperate {
|
||||
* @param args 命令参数
|
||||
*/
|
||||
public static void setMapColor(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "用法: /dominion set_map_color <颜色> [领地名称]");
|
||||
return;
|
||||
}
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
if (args.length == 2) {
|
||||
DominionController.setMapColor(operator, args[1]);
|
||||
} else {
|
@ -5,9 +5,9 @@ import cn.lunadeer.dominion.controllers.GroupController;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.group.GroupList;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.group.GroupSetting;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.group.SelectMember;
|
||||
import cn.lunadeer.minecraftpluginutils.ColorParser;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
@ -16,9 +16,9 @@ import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.Commands.boolOptions;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
import static cn.lunadeer.dominion.commands.Helper.*;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class Group {
|
||||
|
||||
@ -30,16 +30,17 @@ public class Group {
|
||||
*/
|
||||
public static void createGroup(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 4) {
|
||||
Notification.error(sender, "用法: /dominion group create <领地名称> <权限组名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String groupName = args[3];
|
||||
GroupController.createGroup(operator, dominionName, groupName);
|
||||
GroupController.createGroup(operator, dominionName, ColorParser.getPlainText(groupName), groupName);
|
||||
GroupList.show(sender, dominionName);
|
||||
} catch (Exception e) {
|
||||
Notification.error(sender, e.getMessage());
|
||||
@ -54,13 +55,14 @@ public class Group {
|
||||
*/
|
||||
public static void deleteGroup(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 4) {
|
||||
Notification.error(sender, "用法: /dominion group delete <领地名称> <权限组名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String groupName = args[3];
|
||||
GroupController.deleteGroup(operator, dominionName, groupName);
|
||||
@ -78,17 +80,18 @@ public class Group {
|
||||
*/
|
||||
public static void renameGroup(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 5) {
|
||||
Notification.error(sender, "用法: /dominion group rename <领地名称> <权限组旧名称> <新名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String oldGroupName = args[3];
|
||||
String newGroupName = args[4];
|
||||
GroupController.renameGroup(operator, dominionName, oldGroupName, newGroupName);
|
||||
GroupController.renameGroup(operator, dominionName, oldGroupName, ColorParser.getPlainText(newGroupName), newGroupName);
|
||||
GroupSetting.show(sender, dominionName, newGroupName);
|
||||
} catch (Exception e) {
|
||||
Notification.error(sender, e.getMessage());
|
||||
@ -103,13 +106,14 @@ public class Group {
|
||||
*/
|
||||
public static void setGroupFlag(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 6) {
|
||||
Notification.error(sender, "用法: /dominion group set_flag <领地名称> <权限组名称> <权限名称> <true|false>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String groupName = args[3];
|
||||
String flag = args[4];
|
||||
@ -130,13 +134,14 @@ public class Group {
|
||||
*/
|
||||
public static void addMember(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 5) {
|
||||
Notification.error(sender, "用法: /dominion group add_member <领地名称> <权限组名称> <玩家名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String groupName = args[3];
|
||||
String playerName = args[4];
|
||||
@ -156,13 +161,14 @@ public class Group {
|
||||
*/
|
||||
public static void removeMember(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 5) {
|
||||
Notification.error(sender, "用法: /dominion group remove_member <领地名称> <权限组名称> <玩家名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String groupName = args[3];
|
||||
String playerName = args[4];
|
||||
@ -175,6 +181,10 @@ public class Group {
|
||||
}
|
||||
|
||||
public static void handle(@NotNull CommandSender sender, @NotNull String[] args) {
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "用法: /dominion group <create|delete|rename|set_flag|add_member|remove_member|select_member|setting|list>");
|
||||
return;
|
||||
}
|
||||
switch (args[1]) {
|
||||
case "create":
|
||||
createGroup(sender, args);
|
@ -9,7 +9,7 @@ import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class Helper {
|
||||
|
||||
@ -55,8 +55,8 @@ public class Helper {
|
||||
if (dominion == null) return players_name;
|
||||
GroupDTO group = GroupDTO.select(dominion.getId(), groupName);
|
||||
if (group == null) return players_name;
|
||||
List<PlayerPrivilegeDTO> privileges = PlayerPrivilegeDTO.selectByGroupId(group.getId());
|
||||
for (PlayerPrivilegeDTO privilege : privileges) {
|
||||
List<MemberDTO> privileges = MemberDTO.selectByDomGroupId(dominion.getId(), group.getId());
|
||||
for (MemberDTO privilege : privileges) {
|
||||
PlayerDTO player = PlayerDTO.select(privilege.getPlayerUUID());
|
||||
if (player == null) continue;
|
||||
players_name.add(player.getLastKnownName());
|
||||
@ -79,8 +79,8 @@ public class Helper {
|
||||
List<String> dominions_name = new ArrayList<>();
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return dominions_name;
|
||||
List<PlayerPrivilegeDTO> dominions_admin = PlayerPrivilegeDTO.selectAll(player.getUniqueId());
|
||||
for (PlayerPrivilegeDTO privilege : dominions_admin) {
|
||||
List<MemberDTO> dominions_admin = MemberDTO.selectAll(player.getUniqueId());
|
||||
for (MemberDTO privilege : dominions_admin) {
|
||||
if (privilege.getAdmin()) {
|
||||
DominionDTO dom = DominionDTO.select(privilege.getDomID());
|
||||
if (dom == null) continue;
|
@ -8,7 +8,6 @@ import cn.lunadeer.dominion.tuis.dominion.manage.member.SelectPlayer;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.member.SelectTemplate;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
@ -18,7 +17,7 @@ import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.Commands.boolOptions;
|
||||
import static cn.lunadeer.dominion.Commands.playerNames;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
import static cn.lunadeer.dominion.commands.Helper.*;
|
||||
|
||||
public class Member {
|
||||
@ -32,13 +31,14 @@ public class Member {
|
||||
*/
|
||||
public static void member_add(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 4) {
|
||||
Notification.error(sender, "用法: /dominion member add <领地名称> <玩家名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String playerName = args[3];
|
||||
MemberController.memberAdd(operator, dominionName, playerName);
|
||||
@ -57,13 +57,14 @@ public class Member {
|
||||
*/
|
||||
public static void member_set_flag(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 6) {
|
||||
Notification.error(sender, "用法: /dominion member set_flag <领地名称> <玩家名称> <权限名称> <true/false>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String playerName = args[3];
|
||||
String flagName = args[4];
|
||||
@ -85,13 +86,14 @@ public class Member {
|
||||
*/
|
||||
public static void member_remove(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 4) {
|
||||
Notification.error(sender, "用法: /dominion member remove <领地名称> <玩家名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String playerName = args[3];
|
||||
MemberController.memberRemove(operator, dominionName, playerName);
|
||||
@ -110,13 +112,14 @@ public class Member {
|
||||
*/
|
||||
public static void member_apply_template(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 5) {
|
||||
Notification.error(sender, "用法: /dominion member apply_template <领地名称> <玩家名称> <模板名称>");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(player);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
String dominionName = args[2];
|
||||
String playerName = args[3];
|
||||
String templateName = args[4];
|
||||
@ -128,6 +131,10 @@ public class Member {
|
||||
}
|
||||
|
||||
public static void handle(@NotNull CommandSender sender, @NotNull String[] args) {
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "用法: /dominion member <add/set_flag/remove/apply_template/list/setting/select_player/select_template>");
|
||||
return;
|
||||
}
|
||||
switch (args[1]) {
|
||||
case "add":
|
||||
Member.member_add(sender, args);
|
@ -14,12 +14,16 @@ import org.bukkit.entity.Player;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class Migration {
|
||||
|
||||
public static void migrate(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
|
@ -1,12 +1,14 @@
|
||||
package cn.lunadeer.dominion.commands;
|
||||
|
||||
import cn.lunadeer.dominion.BlueMapConnect;
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.utils.MapRender;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseManager;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseType;
|
||||
import org.bukkit.command.CommandSender;
|
||||
|
||||
import java.io.File;
|
||||
@ -15,12 +17,15 @@ import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.notOpOrConsole;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
|
||||
|
||||
public class Operator {
|
||||
|
||||
public static void reloadCache(CommandSender sender, String[] args) {
|
||||
if (notOpOrConsole(sender)) return;
|
||||
if (!hasPermission(sender, "dominion.admin")) {
|
||||
return;
|
||||
}
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
Notification.info(sender, "正在从数据库重新加载领地缓存...");
|
||||
Cache.instance.loadDominions();
|
||||
@ -28,25 +33,30 @@ public class Operator {
|
||||
});
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
Notification.info(sender, "正在从数据库重新加载玩家权限缓存...");
|
||||
Cache.instance.loadPlayerPrivileges();
|
||||
Cache.instance.loadMembers();
|
||||
Notification.info(sender, "玩家权限缓存已重新加载");
|
||||
});
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
Notification.info(sender, "正在从数据库重新加载权限组缓存...");
|
||||
Cache.instance.loadGroup();
|
||||
Cache.instance.loadGroups();
|
||||
Notification.info(sender, "权限组缓存已重新加载");
|
||||
});
|
||||
}
|
||||
|
||||
public static void exportMca(CommandSender sender, String[] args) {
|
||||
if (notOpOrConsole(sender)) return;
|
||||
if (!hasPermission(sender, "dominion.admin")) {
|
||||
return;
|
||||
}
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
Notification.info(sender, "正在导出拥有领地的MCA文件列表...");
|
||||
Map<String, List<String>> mca_cords = new HashMap<>();
|
||||
List<DominionDTO> doms = Cache.instance.getDominions();
|
||||
for (DominionDTO dom : doms) {
|
||||
if (!mca_cords.containsKey(dom.getWorld())) {
|
||||
mca_cords.put(dom.getWorld(), new ArrayList<>());
|
||||
if (dom.getWorld() == null) {
|
||||
continue;
|
||||
}
|
||||
if (!mca_cords.containsKey(dom.getWorld().getName())) {
|
||||
mca_cords.put(dom.getWorld().getName(), new ArrayList<>());
|
||||
}
|
||||
Integer world_x1 = dom.getX1();
|
||||
Integer world_x2 = dom.getX2();
|
||||
@ -59,10 +69,10 @@ public class Operator {
|
||||
for (int x = mca_x1; x <= mca_x2; x++) {
|
||||
for (int z = mca_z1; z <= mca_z2; z++) {
|
||||
String file_name = "r." + x + "." + z + ".mca";
|
||||
if (mca_cords.get(dom.getWorld()).contains(file_name)) {
|
||||
if (mca_cords.get(dom.getWorld().getName()).contains(file_name)) {
|
||||
continue;
|
||||
}
|
||||
mca_cords.get(dom.getWorld()).add(file_name);
|
||||
mca_cords.get(dom.getWorld().getName()).add(file_name);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -104,16 +114,26 @@ public class Operator {
|
||||
Notification.error(sender, e.getMessage());
|
||||
}
|
||||
}
|
||||
BlueMapConnect.renderMCA(mca_cords);
|
||||
MapRender.renderMCA(mca_cords);
|
||||
Notification.info(sender, "MCA文件列表已导出到 %s", folder.getAbsolutePath());
|
||||
});
|
||||
}
|
||||
|
||||
public static void reloadConfig(CommandSender sender, String[] args) {
|
||||
if (notOpOrConsole(sender)) return;
|
||||
if (!hasPermission(sender, "dominion.admin")) {
|
||||
return;
|
||||
}
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
Notification.info(sender, "正在重新加载配置文件...");
|
||||
Dominion.config.reload();
|
||||
DatabaseManager.instance.reConnection(
|
||||
DatabaseType.valueOf(Dominion.config.getDbType().toUpperCase()),
|
||||
Dominion.config.getDbHost(),
|
||||
Dominion.config.getDbPort(),
|
||||
Dominion.config.getDbName(),
|
||||
Dominion.config.getDbUser(),
|
||||
Dominion.config.getDbPass()
|
||||
);
|
||||
Notification.info(sender, "配置文件已重新加载");
|
||||
});
|
||||
}
|
@ -5,12 +5,14 @@ import cn.lunadeer.dominion.tuis.SysConfig;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.command.CommandSender;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.notOpOrConsole;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
|
||||
public class SetConfig {
|
||||
|
||||
public static void handler(CommandSender sender, String[] args) {
|
||||
if (notOpOrConsole(sender)) return;
|
||||
if (!hasPermission(sender, "dominion.admin")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "参数错误");
|
||||
return;
|
||||
@ -70,6 +72,9 @@ public class SetConfig {
|
||||
case "residence_migration":
|
||||
setResidenceMigration(sender, args);
|
||||
break;
|
||||
case "spawn_protection":
|
||||
setSpawnProtection(sender, args);
|
||||
break;
|
||||
default:
|
||||
Notification.error(sender, "未知参数");
|
||||
}
|
||||
@ -97,14 +102,14 @@ public class SetConfig {
|
||||
}
|
||||
|
||||
private static void adjustSizeY() {
|
||||
if (Dominion.config.getLimitVert()) {
|
||||
Dominion.config.setLimitSizeY(Dominion.config.getLimitMaxY() - Dominion.config.getLimitMinY() + 1);
|
||||
if (Dominion.config.getLimitVert(null)) {
|
||||
Dominion.config.setLimitSizeY(Dominion.config.getLimitMaxY(null) - Dominion.config.getLimitMinY(null) + 1);
|
||||
}
|
||||
}
|
||||
|
||||
private static void setLimitMaxY(CommandSender sender, String[] args) {
|
||||
int maxY = Integer.parseInt(args[2]);
|
||||
if (maxY <= Dominion.config.getLimitMinY()) {
|
||||
if (maxY <= Dominion.config.getLimitMinY(null)) {
|
||||
Notification.error(sender, "最高Y坐标限制不能小于最低Y坐标限制");
|
||||
return;
|
||||
}
|
||||
@ -115,7 +120,7 @@ public class SetConfig {
|
||||
|
||||
private static void setLimitMinY(CommandSender sender, String[] args) {
|
||||
int minY = Integer.parseInt(args[2]);
|
||||
if (minY >= Dominion.config.getLimitMaxY()) {
|
||||
if (minY >= Dominion.config.getLimitMaxY(null)) {
|
||||
Notification.error(sender, "最低Y坐标限制不能大于最高Y坐标限制");
|
||||
return;
|
||||
}
|
||||
@ -252,6 +257,7 @@ public class SetConfig {
|
||||
} else {
|
||||
Dominion.config.setEconomyRefund(economyRefund);
|
||||
}
|
||||
refreshPageOrNot(sender, args);
|
||||
}
|
||||
|
||||
private static void setResidenceMigration(CommandSender sender, String[] args) {
|
||||
@ -259,4 +265,15 @@ public class SetConfig {
|
||||
Dominion.config.setResidenceMigration(residenceMigration);
|
||||
refreshPageOrNot(sender, args);
|
||||
}
|
||||
|
||||
private static void setSpawnProtection(CommandSender sender, String[] args) {
|
||||
int spawnProtection = Integer.parseInt(args[2]);
|
||||
if (spawnProtection != -1 && spawnProtection <= 0) {
|
||||
Dominion.config.setSpawnProtection(1);
|
||||
Notification.error(sender, "出生点保护半径不能小于或等于0");
|
||||
} else {
|
||||
Dominion.config.setSpawnProtection(spawnProtection);
|
||||
}
|
||||
refreshPageOrNot(sender, args);
|
||||
}
|
||||
}
|
@ -15,10 +15,11 @@ import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.Commands.boolOptions;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.commands.Helper.allTemplates;
|
||||
import static cn.lunadeer.dominion.commands.Helper.playerPrivileges;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class Template {
|
||||
|
||||
@ -31,6 +32,9 @@ public class Template {
|
||||
*/
|
||||
public static void createTemplate(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 3) {
|
||||
Notification.error(sender, "用法: /dominion template create <模板名称>");
|
||||
return;
|
||||
@ -54,6 +58,9 @@ public class Template {
|
||||
*/
|
||||
public static void deleteTemplate(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 3) {
|
||||
Notification.error(sender, "用法: /dominion template delete <模板名称>");
|
||||
return;
|
||||
@ -77,6 +84,9 @@ public class Template {
|
||||
*/
|
||||
public static void setTemplateFlag(CommandSender sender, String[] args) {
|
||||
try {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
if (args.length < 5) {
|
||||
Notification.error(sender, "用法: /dominion template set_flag <模板名称> <权限名称> <true/false>");
|
||||
return;
|
||||
@ -96,6 +106,10 @@ public class Template {
|
||||
|
||||
|
||||
public static void handle(@NotNull CommandSender sender, @NotNull String[] args) {
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "用法: /dominion template <list|setting|delete|create|set_flag>");
|
||||
return;
|
||||
}
|
||||
switch (args[1]) {
|
||||
case "list":
|
||||
TemplateList.show(sender, args);
|
69
core/src/main/java/cn/lunadeer/dominion/commands/Title.java
Normal file
69
core/src/main/java/cn/lunadeer/dominion/commands/Title.java
Normal file
@ -0,0 +1,69 @@
|
||||
package cn.lunadeer.dominion.commands;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.tuis.TitleList;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.hasPermission;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class Title {
|
||||
|
||||
public static void use_title(CommandSender sender, String[] args) {
|
||||
if (!hasPermission(sender, "dominion.default")) {
|
||||
return;
|
||||
}
|
||||
Player bukkit_player = playerOnly(sender);
|
||||
if (bukkit_player == null) return;
|
||||
if (args.length < 2) {
|
||||
Notification.error(sender, "用法: /dominion use_title <权限组ID>");
|
||||
return;
|
||||
}
|
||||
try {
|
||||
int id = Integer.parseInt(args[1]);
|
||||
PlayerDTO player = PlayerDTO.get(bukkit_player);
|
||||
if (id == -1) {
|
||||
player.setUsingGroupTitleID(id);
|
||||
Notification.info(sender, "成功卸下权限组称号");
|
||||
} else {
|
||||
GroupDTO group = Cache.instance.getGroup(id);
|
||||
if (group == null) {
|
||||
Notification.error(sender, "权限组不存在");
|
||||
return;
|
||||
}
|
||||
DominionDTO dominion = Cache.instance.getDominion(group.getDomID());
|
||||
if (dominion == null) {
|
||||
Notification.error(sender, "权限组 %s 所属领地不存在", group.getName());
|
||||
return;
|
||||
}
|
||||
if (!dominion.getOwner().equals(bukkit_player.getUniqueId())) {
|
||||
MemberDTO member = Cache.instance.getMember(bukkit_player, dominion);
|
||||
if (member == null) {
|
||||
Notification.error(sender, "你不是 %s 的成员,无法使用其称号", dominion.getName());
|
||||
return;
|
||||
}
|
||||
if (!Objects.equals(member.getGroupId(), group.getId())) {
|
||||
Notification.error(sender, "你不属于权限组 %s,无法使用其称号", group.getName());
|
||||
return;
|
||||
}
|
||||
}
|
||||
player.setUsingGroupTitleID(group.getId());
|
||||
Notification.info(sender, "成功使用权限组 %s 称号", group.getName());
|
||||
}
|
||||
int page = getPage(args, 2);
|
||||
TitleList.show(sender, page);
|
||||
} catch (Exception e) {
|
||||
Notification.error(sender, "使用称号失败: " + e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -48,9 +48,9 @@ public interface AbstractOperator {
|
||||
|
||||
public @Nullable Location getLocation();
|
||||
|
||||
public Player getPlayer();
|
||||
public @Nullable Player getPlayer();
|
||||
|
||||
public BlockFace getDirection();
|
||||
public @Nullable BlockFace getDirection();
|
||||
|
||||
public CompletableFuture<Result> getResponse();
|
||||
}
|
@ -3,29 +3,43 @@ package cn.lunadeer.dominion.controllers;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.block.BlockFace;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
import java.util.Objects;
|
||||
import java.util.UUID;
|
||||
import java.util.concurrent.CompletableFuture;
|
||||
|
||||
public class BukkitPlayerOperator implements AbstractOperator {
|
||||
|
||||
private final org.bukkit.entity.Player player;
|
||||
private final CommandSender player;
|
||||
private final CompletableFuture<Result> response = new CompletableFuture<>();
|
||||
|
||||
public BukkitPlayerOperator(org.bukkit.entity.Player player) {
|
||||
public BukkitPlayerOperator(CommandSender player) {
|
||||
this.player = player;
|
||||
}
|
||||
|
||||
public boolean isConsole() {
|
||||
return !(player instanceof Player);
|
||||
}
|
||||
|
||||
@Override
|
||||
public UUID getUniqueId() {
|
||||
return player.getUniqueId();
|
||||
if (isConsole()) {
|
||||
return UUID.randomUUID();
|
||||
} else {
|
||||
return ((Player) player).getUniqueId();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isOp() {
|
||||
return player.isOp();
|
||||
if (isConsole()) {
|
||||
return true;
|
||||
} else {
|
||||
return ((Player) player).isOp() || player.hasPermission("dominion.admin");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -34,19 +48,30 @@ public class BukkitPlayerOperator implements AbstractOperator {
|
||||
}
|
||||
|
||||
@Override
|
||||
public Location getLocation() {
|
||||
return player.getLocation();
|
||||
public @Nullable Location getLocation() {
|
||||
if (isConsole()) {
|
||||
return null;
|
||||
} else {
|
||||
return ((Player) player).getLocation();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Player getPlayer() {
|
||||
return player;
|
||||
public @Nullable Player getPlayer() {
|
||||
if (isConsole()) {
|
||||
return null;
|
||||
} else {
|
||||
return (Player) player;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlockFace getDirection() {
|
||||
float yaw = player.getLocation().getYaw();
|
||||
float pitch = player.getLocation().getPitch();
|
||||
public @Nullable BlockFace getDirection() {
|
||||
if (isConsole() || getLocation() == null) {
|
||||
return null;
|
||||
}
|
||||
float yaw = getLocation().getYaw();
|
||||
float pitch = getLocation().getPitch();
|
||||
if (pitch > -45 && pitch < 45) {
|
||||
if (yaw > -45 && yaw < 45) {
|
||||
return BlockFace.SOUTH;
|
||||
@ -69,7 +94,7 @@ public class BukkitPlayerOperator implements AbstractOperator {
|
||||
return response;
|
||||
}
|
||||
|
||||
public static BukkitPlayerOperator create(org.bukkit.entity.Player player) {
|
||||
public static BukkitPlayerOperator create(CommandSender player) {
|
||||
BukkitPlayerOperator operator = new BukkitPlayerOperator(player);
|
||||
operator.getResponse().thenAccept(result -> {
|
||||
if (Objects.equals(result.getStatus(), BukkitPlayerOperator.Result.SUCCESS)) {
|
@ -4,27 +4,29 @@ import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.utils.Particle;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.ParticleRender;
|
||||
import cn.lunadeer.minecraftpluginutils.VaultConnect;
|
||||
import cn.lunadeer.minecraftpluginutils.VaultConnect.VaultConnect;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
import org.bukkit.block.BlockFace;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.DominionNode.isInDominion;
|
||||
import static cn.lunadeer.dominion.controllers.Apis.getPlayerCurrentDominion;
|
||||
import static cn.lunadeer.dominion.controllers.Apis.notOwner;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.getPlayerCurrentDominion;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.notOwner;
|
||||
|
||||
public class DominionController {
|
||||
|
||||
public static List<DominionDTO> all(Player owner) {
|
||||
return DominionDTO.selectAll(owner.getUniqueId());
|
||||
return DominionDTO.selectByOwner(owner.getUniqueId());
|
||||
}
|
||||
|
||||
public static List<DominionDTO> all() {
|
||||
@ -70,26 +72,27 @@ public class DominionController {
|
||||
* @param name 领地名称
|
||||
* @param loc1 位置1
|
||||
* @param loc2 位置2
|
||||
* @param parent_dominion_name 父领地名称
|
||||
* @param parent_dominion_name 父领地名称(留空表示为根领地)
|
||||
* @param skipEco 是否跳过经济检查
|
||||
*/
|
||||
public static void create(AbstractOperator operator, String name,
|
||||
Location loc1, Location loc2,
|
||||
String parent_dominion_name, boolean skipEco) {
|
||||
@NotNull String parent_dominion_name, boolean skipEco) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "创建领地失败");
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "成功创建领地 %s", name);
|
||||
if (name.isEmpty()) {
|
||||
operator.setResponse(FAIL.addMessage("领地名称不能为空"));
|
||||
return;
|
||||
}
|
||||
if (name.contains(" ")) {
|
||||
operator.setResponse(FAIL.addMessage("领地名称不能包含空格"));
|
||||
if (name.contains(" ") || name.contains(".")) {
|
||||
operator.setResponse(FAIL.addMessage("领地名称不能包含空格或点"));
|
||||
return;
|
||||
}
|
||||
if (DominionDTO.select(name) != null) {
|
||||
operator.setResponse(FAIL.addMessage("已经存在名称为 %s 的领地", name));
|
||||
return;
|
||||
}
|
||||
if (!loc1.getWorld().equals(loc2.getWorld())) {
|
||||
if (!loc1.getWorld().getUID().equals(loc2.getWorld().getUID())) {
|
||||
operator.setResponse(FAIL.addMessage("选点世界不一致"));
|
||||
return;
|
||||
}
|
||||
@ -100,21 +103,21 @@ public class DominionController {
|
||||
}
|
||||
// 检查领地数量是否达到上限
|
||||
if (amountNotValid(operator)) {
|
||||
operator.setResponse(FAIL.addMessage("你的领地数量已达上限(%d个)", Dominion.config.getLimitAmount()));
|
||||
operator.setResponse(FAIL.addMessage("你的领地数量已达上限(%d个)", Dominion.config.getLimitAmount(operator.getPlayer())));
|
||||
return;
|
||||
}
|
||||
int minX = Math.min(loc1.getBlockX(), loc2.getBlockX());
|
||||
int minY = Math.min(loc1.getBlockY(), loc2.getBlockY());
|
||||
int minZ = Math.min(loc1.getBlockZ(), loc2.getBlockZ());
|
||||
int maxX = Math.max(loc1.getBlockX(), loc2.getBlockX()) + 1;
|
||||
int maxY = Math.max(loc1.getBlockY(), loc2.getBlockY()) + 1;
|
||||
int maxZ = Math.max(loc1.getBlockZ(), loc2.getBlockZ()) + 1;
|
||||
// 检查领地大小是否合法
|
||||
if (sizeNotValid(operator,
|
||||
loc1.getBlockX(), loc1.getBlockY(), loc1.getBlockZ(),
|
||||
loc2.getBlockX(), loc2.getBlockY(), loc2.getBlockZ())) {
|
||||
if (sizeNotValid(operator, minX, minY, minZ, maxX, maxY, maxZ)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dominion = new DominionDTO(operator.getUniqueId(), name, loc1.getWorld().getName(),
|
||||
(int) Math.min(loc1.getX(), loc2.getX()), (int) Math.min(loc1.getY(), loc2.getY()),
|
||||
(int) Math.min(loc1.getZ(), loc2.getZ()), (int) Math.max(loc1.getX(), loc2.getX()),
|
||||
(int) Math.max(loc1.getY(), loc2.getY()), (int) Math.max(loc1.getZ(), loc2.getZ()));
|
||||
DominionDTO parent_dominion;
|
||||
if (parent_dominion_name.isEmpty()) {
|
||||
if (parent_dominion_name.isEmpty() || parent_dominion_name.equals("root")) {
|
||||
parent_dominion = DominionDTO.select(-1);
|
||||
} else {
|
||||
parent_dominion = DominionDTO.select(parent_dominion_name);
|
||||
@ -133,8 +136,11 @@ public class DominionController {
|
||||
return;
|
||||
}
|
||||
}
|
||||
// 创建 dominion (此步骤不会写入数据)
|
||||
DominionDTO dominion = DominionDTO.create(parent_dominion.getId() == -1 ? operator.getUniqueId() : parent_dominion.getOwner(), name, loc1.getWorld(),
|
||||
minX, minY, minZ, maxX, maxY, maxZ, parent_dominion);
|
||||
// 如果parent_dominion不为-1 检查是否在同一世界
|
||||
if (parent_dominion.getId() != -1 && !parent_dominion.getWorld().equals(dominion.getWorld())) {
|
||||
if (parent_dominion.getId() != -1 && !parent_dominion.getWorldUid().equals(dominion.getWorldUid())) {
|
||||
operator.setResponse(FAIL.addMessage("父领地与子领地不在同一世界。"));
|
||||
return;
|
||||
}
|
||||
@ -148,7 +154,12 @@ public class DominionController {
|
||||
return;
|
||||
}
|
||||
// 获取此领地的所有同级领地
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorld(), parent_dominion.getId());
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorldUid(), parent_dominion.getId());
|
||||
// 检查是否与出生点保护冲突
|
||||
if (isIntersectSpawn(operator, dominion)) {
|
||||
operator.setResponse(FAIL.addMessage("与出生点保护冲突"));
|
||||
return;
|
||||
}
|
||||
// 检查是否与其他子领地冲突
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
if (isIntersect(sub_dominion, dominion)) {
|
||||
@ -157,35 +168,49 @@ public class DominionController {
|
||||
}
|
||||
}
|
||||
// 检查经济
|
||||
if (Dominion.config.getEconomyEnable() && !skipEco) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
operator.setResponse(FAIL.addMessage("没有可用的经济插件系统,请联系服主。"));
|
||||
if (!skipEco) {
|
||||
if (handleEconomyFailed(operator, Dominion.config.getEconomyOnlyXZ(operator.getPlayer()) ? dominion.getSquare() : dominion.getVolume(), true, FAIL, SUCCESS)) {
|
||||
return;
|
||||
}
|
||||
int count;
|
||||
if (Dominion.config.getEconomyOnlyXZ()) {
|
||||
count = dominion.getSquare();
|
||||
} else {
|
||||
count = dominion.getVolume();
|
||||
}
|
||||
float price = count * Dominion.config.getEconomyPrice();
|
||||
if (VaultConnect.instance.getBalance(operator.getPlayer()) < price) {
|
||||
operator.setResponse(FAIL.addMessage("你的余额不足,创建此领地需要 %.2f %s", price, VaultConnect.instance.currencyNamePlural()));
|
||||
return;
|
||||
}
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "已扣除 %.2f %s", price, VaultConnect.instance.currencyNamePlural()));
|
||||
VaultConnect.instance.withdrawPlayer(operator.getPlayer(), price);
|
||||
}
|
||||
dominion = DominionDTO.insert(dominion);
|
||||
if (dominion == null) {
|
||||
operator.setResponse(FAIL.addMessage("创建领地失败,数据库错误,请联系管理员"));
|
||||
return;
|
||||
}
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
ParticleRender.showBoxFace(Dominion.instance, operator.getPlayer(), loc1, loc2);
|
||||
// 显示粒子效果
|
||||
handleParticle(operator, dominion);
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
private static boolean isIntersectSpawn(AbstractOperator operator, DominionDTO dominion) {
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return false;
|
||||
}
|
||||
dominion.setParentDomId(parent_dominion.getId());
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "成功创建领地 %s", name));
|
||||
int radius = Dominion.config.getSpawnProtection();
|
||||
if (radius == -1) {
|
||||
return false;
|
||||
}
|
||||
World world = dominion.getWorld();
|
||||
if (world == null) {
|
||||
return false;
|
||||
}
|
||||
Location spawn = world.getSpawnLocation();
|
||||
return isIntersect(dominion, spawn.getBlockX() - radius, spawn.getBlockY() - radius, spawn.getBlockZ() - radius
|
||||
, spawn.getBlockX() + radius, spawn.getBlockY() + radius, spawn.getBlockZ() + radius);
|
||||
}
|
||||
|
||||
private static boolean isIntersectSpawn(AbstractOperator operator, @NotNull World world, int[] cords) {
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return false;
|
||||
}
|
||||
int radius = Dominion.config.getSpawnProtection();
|
||||
if (radius == -1) {
|
||||
return false;
|
||||
}
|
||||
Location spawn = world.getSpawnLocation();
|
||||
return isIntersect(cords, spawn.getBlockX() - radius, spawn.getBlockY() - radius, spawn.getBlockZ() - radius
|
||||
, spawn.getBlockX() + radius, spawn.getBlockY() + radius, spawn.getBlockZ() + radius);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -214,48 +239,17 @@ public class DominionController {
|
||||
*/
|
||||
public static void expand(AbstractOperator operator, Integer size, String dominion_name) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "扩展领地失败");
|
||||
Location location = operator.getLocation();
|
||||
BlockFace face = operator.getDirection();
|
||||
DominionDTO dominion = getExistDomAndIsOwner(operator, dominion_name);
|
||||
DominionDTO dominion = expandContractPreCheck(operator, getExistDomAndIsOwner(operator, dominion_name), FAIL);
|
||||
if (dominion == null) {
|
||||
return;
|
||||
}
|
||||
if (location != null) {
|
||||
if (!location.getWorld().getName().equals(dominion.getWorld())) {
|
||||
operator.setResponse(FAIL.addMessage("禁止跨世界操作"));
|
||||
return;
|
||||
}
|
||||
int[] newCords = expandContractSizeChange(operator, dominion, true, size, FAIL);
|
||||
if (newCords == null) {
|
||||
return;
|
||||
}
|
||||
Integer x1 = dominion.getX1();
|
||||
Integer y1 = dominion.getY1();
|
||||
Integer z1 = dominion.getZ1();
|
||||
Integer x2 = dominion.getX2();
|
||||
Integer y2 = dominion.getY2();
|
||||
Integer z2 = dominion.getZ2();
|
||||
switch (face) {
|
||||
case NORTH:
|
||||
z1 -= size;
|
||||
break;
|
||||
case SOUTH:
|
||||
z2 += size;
|
||||
break;
|
||||
case WEST:
|
||||
x1 -= size;
|
||||
break;
|
||||
case EAST:
|
||||
x2 += size;
|
||||
break;
|
||||
case UP:
|
||||
y2 += size;
|
||||
break;
|
||||
case DOWN:
|
||||
y1 -= size;
|
||||
break;
|
||||
default:
|
||||
operator.setResponse(FAIL.addMessage("无效的方向"));
|
||||
return;
|
||||
}
|
||||
if (sizeNotValid(operator, x1, y1, z1, x2, y2, z2)) {
|
||||
// 检查是否与出生点保护冲突
|
||||
if (isIntersectSpawn(operator, dominion.getWorld(), newCords)) {
|
||||
operator.setResponse(FAIL.addMessage("与出生点保护冲突"));
|
||||
return;
|
||||
}
|
||||
// 校验是否超出父领地范围
|
||||
@ -264,14 +258,14 @@ public class DominionController {
|
||||
operator.setResponse(FAIL.addMessage("父领地丢失"));
|
||||
return;
|
||||
}
|
||||
if (!isContained(x1, y1, z1, x2, y2, z2, parent_dominion)) {
|
||||
if (!isContained(newCords, parent_dominion)) {
|
||||
operator.setResponse(FAIL.addMessage("超出父领地 %s 范围", parent_dominion.getName()));
|
||||
return;
|
||||
}
|
||||
// 获取同世界下的所有同级领地
|
||||
List<DominionDTO> exist_dominions = DominionDTO.selectByParentId(dominion.getWorld(), dominion.getParentDomId());
|
||||
List<DominionDTO> exist_dominions = DominionDTO.selectByParentId(dominion.getWorldUid(), dominion.getParentDomId());
|
||||
for (DominionDTO exist_dominion : exist_dominions) {
|
||||
if (isIntersect(exist_dominion, x1, y1, z1, x2, y2, z2)) {
|
||||
if (isIntersect(exist_dominion, newCords)) {
|
||||
// 如果是自己,跳过
|
||||
if (exist_dominion.getId().equals(dominion.getId())) continue;
|
||||
operator.setResponse(FAIL.addMessage("与领地 %s 冲突", exist_dominion.getName()));
|
||||
@ -280,32 +274,11 @@ public class DominionController {
|
||||
}
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "成功扩展领地 %s %d格", dominion_name, size);
|
||||
// 检查经济
|
||||
if (Dominion.config.getEconomyEnable()) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
operator.setResponse(FAIL.addMessage("没有可用的经济插件系统,请联系服主。"));
|
||||
return;
|
||||
}
|
||||
int count;
|
||||
if (Dominion.config.getEconomyOnlyXZ()) {
|
||||
count = (x2 - x1 + 1) * (z2 - z1 + 1) - dominion.getSquare();
|
||||
} else {
|
||||
count = (x2 - x1 + 1) * (y2 - y1 + 1) * (z2 - z1 + 1) - dominion.getVolume();
|
||||
}
|
||||
float price = count * Dominion.config.getEconomyPrice();
|
||||
if (VaultConnect.instance.getBalance(operator.getPlayer()) < price) {
|
||||
operator.setResponse(FAIL.addMessage("你的余额不足,扩展此领地需要 %.2f %s", price, VaultConnect.instance.currencyNamePlural()));
|
||||
return;
|
||||
}
|
||||
SUCCESS.addMessage("已扣除 %.2f %s", price, VaultConnect.instance.currencyNamePlural());
|
||||
VaultConnect.instance.withdrawPlayer(operator.getPlayer(), price);
|
||||
}
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
World world = Dominion.instance.getServer().getWorld(dominion.getWorld());
|
||||
ParticleRender.showBoxFace(Dominion.instance, operator.getPlayer(),
|
||||
new Location(world, x1, y1, z1),
|
||||
new Location(world, x2, y2, z2));
|
||||
}
|
||||
dominion.setXYZ(x1, y1, z1, x2, y2, z2);
|
||||
if (handleEconomyFailed(operator, Dominion.config.getEconomyOnlyXZ(operator.getPlayer()) ? sqr(newCords) - dominion.getSquare() : vol(newCords) - dominion.getVolume()
|
||||
, true, FAIL, SUCCESS)) return;
|
||||
// 显示粒子效果
|
||||
dominion = dominion.setXYZ(newCords);
|
||||
handleParticle(operator, dominion);
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
@ -335,90 +308,48 @@ public class DominionController {
|
||||
*/
|
||||
public static void contract(AbstractOperator operator, Integer size, String dominion_name) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "缩小领地失败");
|
||||
Location location = operator.getLocation();
|
||||
BlockFace face = operator.getDirection();
|
||||
DominionDTO dominion = getExistDomAndIsOwner(operator, dominion_name);
|
||||
DominionDTO dominion = expandContractPreCheck(operator, getExistDomAndIsOwner(operator, dominion_name), FAIL);
|
||||
if (dominion == null) {
|
||||
return;
|
||||
}
|
||||
if (location != null) {
|
||||
if (!location.getWorld().getName().equals(dominion.getWorld())) {
|
||||
operator.setResponse(FAIL.addMessage("禁止跨世界操作"));
|
||||
return;
|
||||
}
|
||||
}
|
||||
Integer x1 = dominion.getX1();
|
||||
Integer y1 = dominion.getY1();
|
||||
Integer z1 = dominion.getZ1();
|
||||
Integer x2 = dominion.getX2();
|
||||
Integer y2 = dominion.getY2();
|
||||
Integer z2 = dominion.getZ2();
|
||||
switch (face) {
|
||||
case SOUTH:
|
||||
z2 -= size;
|
||||
break;
|
||||
case NORTH:
|
||||
z1 += size;
|
||||
break;
|
||||
case EAST:
|
||||
x2 -= size;
|
||||
break;
|
||||
case WEST:
|
||||
x1 += size;
|
||||
break;
|
||||
case UP:
|
||||
y2 -= size;
|
||||
break;
|
||||
case DOWN:
|
||||
y1 += size;
|
||||
break;
|
||||
default:
|
||||
operator.setResponse(FAIL.addMessage("无效的方向"));
|
||||
return;
|
||||
}
|
||||
// 校验第二组坐标是否小于第一组坐标
|
||||
if (x1 >= x2 || y1 >= y2 || z1 >= z2) {
|
||||
operator.setResponse(FAIL.addMessage("缩小后的领地大小无效"));
|
||||
return;
|
||||
}
|
||||
if (sizeNotValid(operator, x1, y1, z1, x2, y2, z2)) {
|
||||
int[] newCords = expandContractSizeChange(operator, dominion, false, size, FAIL);
|
||||
if (newCords == null) {
|
||||
return;
|
||||
}
|
||||
// 获取所有的子领地
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorld(), dominion.getId());
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorldUid(), dominion.getId());
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
if (!isContained(sub_dominion, x1, y1, z1, x2, y2, z2)) {
|
||||
if (!isContained(sub_dominion, newCords)) {
|
||||
operator.setResponse(FAIL.addMessage("缩小后的领地无法包含子领地 %s", sub_dominion.getName()));
|
||||
return;
|
||||
}
|
||||
}
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "成功缩小领地 %s %d格", dominion_name, size);
|
||||
// 退还经济
|
||||
if (Dominion.config.getEconomyEnable()) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
operator.setResponse(FAIL.addMessage("没有可用的经济插件系统,请联系服主。"));
|
||||
return;
|
||||
}
|
||||
int count;
|
||||
if (Dominion.config.getEconomyOnlyXZ()) {
|
||||
count = dominion.getSquare() - (x2 - x1 + 1) * (z2 - z1 + 1);
|
||||
} else {
|
||||
count = dominion.getVolume() - (x2 - x1 + 1) * (y2 - y1 + 1) * (z2 - z1 + 1);
|
||||
}
|
||||
float refund = count * Dominion.config.getEconomyPrice() * Dominion.config.getEconomyRefund();
|
||||
VaultConnect.instance.depositPlayer(operator.getPlayer(), refund);
|
||||
SUCCESS.addMessage("已退还 %.2f %s", refund, VaultConnect.instance.currencyNamePlural());
|
||||
}
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
World world = Dominion.instance.getServer().getWorld(dominion.getWorld());
|
||||
ParticleRender.showBoxFace(Dominion.instance, operator.getPlayer(),
|
||||
new Location(world, x1, y1, z1),
|
||||
new Location(world, x2, y2, z2));
|
||||
}
|
||||
dominion.setXYZ(x1, y1, z1, x2, y2, z2);
|
||||
if (handleEconomyFailed(operator, Dominion.config.getEconomyOnlyXZ(operator.getPlayer()) ? dominion.getSquare() - sqr(newCords) : dominion.getVolume() - vol(newCords)
|
||||
, false, FAIL, SUCCESS)) return;
|
||||
// 显示粒子效果
|
||||
dominion = dominion.setXYZ(newCords);
|
||||
handleParticle(operator, dominion);
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
private static int vol(int x1, int y1, int z1, int x2, int y2, int z2) {
|
||||
return (x2 - x1) * (y2 - y1) * (z2 - z1);
|
||||
}
|
||||
|
||||
private static int vol(int[] cords) {
|
||||
return vol(cords[0], cords[1], cords[2], cords[3], cords[4], cords[5]);
|
||||
}
|
||||
|
||||
private static int sqr(int x1, int z1, int x2, int z2) {
|
||||
return (x2 - x1) * (z2 - z1);
|
||||
}
|
||||
|
||||
private static int sqr(int[] cords) {
|
||||
return sqr(cords[0], cords[2], cords[3], cords[5]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除领地 会同时删除其所有子领地
|
||||
*
|
||||
@ -427,6 +358,8 @@ public class DominionController {
|
||||
* @param force 是否强制删除
|
||||
*/
|
||||
public static void delete(AbstractOperator operator, String dominion_name, boolean force) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "删除领地失败");
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "领地 %s 及其所有子领地已删除", dominion_name);
|
||||
DominionDTO dominion = getExistDomAndIsOwner(operator, dominion_name);
|
||||
if (dominion == null) {
|
||||
return;
|
||||
@ -434,14 +367,7 @@ public class DominionController {
|
||||
List<DominionDTO> sub_dominions = getSubDominionsRecursive(dominion);
|
||||
if (!force) {
|
||||
AbstractOperator.Result WARNING = new AbstractOperator.Result(AbstractOperator.Result.WARNING, "删除领地 %s 会同时删除其所有子领地,是否继续?", dominion_name);
|
||||
String sub_names = "";
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
sub_names = sub_dominion.getName() + ", ";
|
||||
}
|
||||
if (sub_dominions.size() > 0) {
|
||||
sub_names = sub_names.substring(0, sub_names.length() - 2);
|
||||
WARNING.addMessage("(子领地:%s)", sub_names);
|
||||
}
|
||||
showSubNamesWarning(sub_dominions, WARNING);
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
Notification.warn(operator.getPlayer(), "输入 /dominion delete %s force 确认删除", dominion_name);
|
||||
}
|
||||
@ -449,27 +375,20 @@ public class DominionController {
|
||||
return;
|
||||
}
|
||||
DominionDTO.delete(dominion);
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "领地 %s 及其所有子领地已删除", dominion_name);
|
||||
// 退还经济
|
||||
if (Dominion.config.getEconomyEnable()) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "退款失败,没有可用的经济插件系统,请联系服主。"));
|
||||
return;
|
||||
int count;
|
||||
if (Dominion.config.getEconomyOnlyXZ(operator.getPlayer())) {
|
||||
count = dominion.getSquare();
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
count += sub_dominion.getSquare();
|
||||
}
|
||||
int count = 0;
|
||||
if (Dominion.config.getEconomyOnlyXZ()) {
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
count += sub_dominion.getSquare();
|
||||
}
|
||||
} else {
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
count += sub_dominion.getVolume();
|
||||
}
|
||||
} else {
|
||||
count = dominion.getVolume();
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
count += sub_dominion.getVolume();
|
||||
}
|
||||
float refund = count * Dominion.config.getEconomyPrice() * Dominion.config.getEconomyRefund();
|
||||
VaultConnect.instance.depositPlayer(operator.getPlayer(), refund);
|
||||
SUCCESS.addMessage("已退还 %.2f %s", refund, VaultConnect.instance.currencyNamePlural());
|
||||
}
|
||||
if (handleEconomyFailed(operator, count, false, FAIL, SUCCESS)) return;
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
@ -553,14 +472,15 @@ public class DominionController {
|
||||
* @param dominion_name 领地名称
|
||||
*/
|
||||
public static void setTpLocation(AbstractOperator operator, int x, int y, int z, String dominion_name) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "设置领地传送点失败");
|
||||
DominionDTO dominion = getExistDomAndIsOwner(operator, dominion_name);
|
||||
if (dominion == null) {
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "领地 %s 不存在", dominion_name));
|
||||
return;
|
||||
}
|
||||
World world = Dominion.instance.getServer().getWorld(dominion.getWorld());
|
||||
World world = dominion.getWorld();
|
||||
if (world == null) {
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "世界 %s 不存在", dominion.getWorld()));
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "领地所在世界不存在"));
|
||||
return;
|
||||
}
|
||||
Location loc = new Location(world, x, y, z);
|
||||
@ -572,7 +492,7 @@ public class DominionController {
|
||||
"成功设置领地 %s 的传送点 %d %d %d", dominion_name
|
||||
, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()));
|
||||
} else {
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "传送点不在领地 %s 内", dominion_name));
|
||||
operator.setResponse(FAIL.addMessage("传送点不在领地 %s 内", dominion_name));
|
||||
}
|
||||
}
|
||||
|
||||
@ -589,8 +509,8 @@ public class DominionController {
|
||||
operator.setResponse(FAIL.addMessage("新名称不能为空"));
|
||||
return;
|
||||
}
|
||||
if (new_name.contains(" ")) {
|
||||
operator.setResponse(FAIL.addMessage("领地名称不能包含空格"));
|
||||
if (new_name.contains(" ") || new_name.contains(".")) {
|
||||
operator.setResponse(FAIL.addMessage("领地名称不能包含空格或点"));
|
||||
return;
|
||||
}
|
||||
if (Objects.equals(old_name, new_name)) {
|
||||
@ -624,10 +544,6 @@ public class DominionController {
|
||||
operator.setResponse(FAIL.addMessage("操作者信息丢失,请联系管理员"));
|
||||
return;
|
||||
}
|
||||
if (Objects.equals(player_name, operatorDTO.getLastKnownName())) {
|
||||
operator.setResponse(FAIL.addMessage("不能将领地转让给自己"));
|
||||
return;
|
||||
}
|
||||
DominionDTO dominion = getExistDomAndIsOwner(operator, dom_name);
|
||||
if (dominion == null) {
|
||||
return;
|
||||
@ -637,6 +553,10 @@ public class DominionController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在", player_name));
|
||||
return;
|
||||
}
|
||||
if (Objects.equals(dominion.getOwner(), player.getUuid())) {
|
||||
operator.setResponse(FAIL.addMessage("领地 %s 已经属于 %s,无需转移", dom_name, player_name));
|
||||
return;
|
||||
}
|
||||
if (dominion.getParentDomId() != -1) {
|
||||
operator.setResponse(FAIL.addMessage("子领地无法转让,你可以通过将 %s 设置为管理员来让其管理领地 %s ", player_name, dom_name));
|
||||
return;
|
||||
@ -644,14 +564,7 @@ public class DominionController {
|
||||
List<DominionDTO> sub_dominions = getSubDominionsRecursive(dominion);
|
||||
if (!force) {
|
||||
AbstractOperator.Result WARNING = new AbstractOperator.Result(AbstractOperator.Result.WARNING, "转让领地 %s 给 %s 会同时转让其所有子领地,是否继续?", dom_name, player_name);
|
||||
String sub_names = "";
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
sub_names = sub_dominion.getName() + ", ";
|
||||
}
|
||||
if (sub_dominions.size() > 0) {
|
||||
sub_names = sub_names.substring(0, sub_names.length() - 2);
|
||||
WARNING.addMessage("(子领地:%s)", sub_names);
|
||||
}
|
||||
showSubNamesWarning(sub_dominions, WARNING);
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
Notification.warn(operator.getPlayer(), "输入 /dominion give %s %s force 确认转让", dom_name, player_name);
|
||||
}
|
||||
@ -711,9 +624,7 @@ public class DominionController {
|
||||
* 判断两个领地是否相交
|
||||
*/
|
||||
private static boolean isIntersect(DominionDTO a, DominionDTO b) {
|
||||
return a.getX1() < b.getX2() && a.getX2() > b.getX1() &&
|
||||
a.getY1() < b.getY2() && a.getY2() > b.getY1() &&
|
||||
a.getZ1() < b.getZ2() && a.getZ2() > b.getZ1();
|
||||
return isIntersect(a, b.getX1(), b.getY1(), b.getZ1(), b.getX2(), b.getY2(), b.getZ2());
|
||||
}
|
||||
|
||||
private static boolean isIntersect(DominionDTO a, Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2) {
|
||||
@ -722,6 +633,16 @@ public class DominionController {
|
||||
a.getZ1() < z2 && a.getZ2() > z1;
|
||||
}
|
||||
|
||||
private static boolean isIntersect(DominionDTO a, int[] cord) {
|
||||
return isIntersect(a, cord[0], cord[1], cord[2], cord[3], cord[4], cord[5]);
|
||||
}
|
||||
|
||||
private static boolean isIntersect(int[] cord, Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2) {
|
||||
return cord[0] < x2 && cord[3] > x1 &&
|
||||
cord[1] < y2 && cord[4] > y1 &&
|
||||
cord[2] < z2 && cord[5] > z1;
|
||||
}
|
||||
|
||||
/**
|
||||
* 判断 sub 是否完全被 parent 包裹
|
||||
*/
|
||||
@ -729,28 +650,36 @@ public class DominionController {
|
||||
if (parent.getId() == -1) {
|
||||
return true;
|
||||
}
|
||||
return sub.getX1() >= parent.getX1() && sub.getX2() <= parent.getX2() &&
|
||||
sub.getY1() >= parent.getY1() && sub.getY2() <= parent.getY2() &&
|
||||
sub.getZ1() >= parent.getZ1() && sub.getZ2() <= parent.getZ2();
|
||||
return isContained(sub.getX1(), sub.getY1(), sub.getZ1(), sub.getX2(), sub.getY2(), sub.getZ2(), parent.getX1(), parent.getY1(), parent.getZ1(), parent.getX2(), parent.getY2(), parent.getZ2());
|
||||
}
|
||||
|
||||
private static boolean isContained(int[] cords, DominionDTO parent) {
|
||||
return isContained(cords[0], cords[1], cords[2], cords[3], cords[4], cords[5], parent);
|
||||
}
|
||||
|
||||
private static boolean isContained(DominionDTO sub, int[] cords) {
|
||||
return isContained(sub, cords[0], cords[1], cords[2], cords[3], cords[4], cords[5]);
|
||||
}
|
||||
|
||||
private static boolean isContained(Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2, DominionDTO parent) {
|
||||
if (parent.getId() == -1) {
|
||||
return true;
|
||||
}
|
||||
return x1 >= parent.getX1() && x2 <= parent.getX2() &&
|
||||
y1 >= parent.getY1() && y2 <= parent.getY2() &&
|
||||
z1 >= parent.getZ1() && z2 <= parent.getZ2();
|
||||
return isContained(x1, y1, z1, x2, y2, z2, parent.getX1(), parent.getY1(), parent.getZ1(), parent.getX2(), parent.getY2(), parent.getZ2());
|
||||
}
|
||||
|
||||
private static boolean isContained(DominionDTO sub, Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2) {
|
||||
return sub.getX1() >= x1 && sub.getX2() <= x2 &&
|
||||
sub.getY1() >= y1 && sub.getY2() <= y2 &&
|
||||
sub.getZ1() >= z1 && sub.getZ2() <= z2;
|
||||
return isContained(sub.getX1(), sub.getY1(), sub.getZ1(), sub.getX2(), sub.getY2(), sub.getZ2(), x1, y1, z1, x2, y2, z2);
|
||||
}
|
||||
|
||||
private static boolean isContained(int sub_x1, int sub_y1, int sub_z1, int sub_x2, int sub_y2, int sub_z2, int parent_x1, int parent_y1, int parent_z1, int parent_x2, int parent_y2, int parent_z2) {
|
||||
return sub_x1 >= parent_x1 && sub_x2 <= parent_x2 &&
|
||||
sub_y1 >= parent_y1 && sub_y2 <= parent_y2 &&
|
||||
sub_z1 >= parent_z1 && sub_z2 <= parent_z2;
|
||||
}
|
||||
|
||||
private static List<DominionDTO> getSubDominionsRecursive(DominionDTO dominion) {
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorld(), dominion.getId());
|
||||
List<DominionDTO> sub_dominions = DominionDTO.selectByParentId(dominion.getWorldUid(), dominion.getId());
|
||||
List<DominionDTO> sub_sub_dominions = new ArrayList<>();
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
sub_sub_dominions.addAll(getSubDominionsRecursive(sub_dominion));
|
||||
@ -759,6 +688,10 @@ public class DominionController {
|
||||
return sub_dominions;
|
||||
}
|
||||
|
||||
private static boolean sizeNotValid(AbstractOperator operator, int[] cords) {
|
||||
return sizeNotValid(operator, cords[0], cords[1], cords[2], cords[3], cords[4], cords[5]);
|
||||
}
|
||||
|
||||
private static boolean sizeNotValid(AbstractOperator operator, int x1, int y1, int z1, int x2, int y2, int z2) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "尺寸不合法");
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
@ -787,24 +720,24 @@ public class DominionController {
|
||||
operator.setResponse(FAIL.addMessage("领地的任意一边长度不得小于4"));
|
||||
return true;
|
||||
}
|
||||
if (x_length > Dominion.config.getLimitSizeX() && Dominion.config.getLimitSizeX() > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地X方向长度不能超过 %d", Dominion.config.getLimitSizeX()));
|
||||
if (x_length > Dominion.config.getLimitSizeX(operator.getPlayer()) && Dominion.config.getLimitSizeX(operator.getPlayer()) > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地X方向长度不能超过 %d", Dominion.config.getLimitSizeX(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
if (y_length > Dominion.config.getLimitSizeY() && Dominion.config.getLimitSizeY() > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y方向高度不能超过 %d", Dominion.config.getLimitSizeY()));
|
||||
if (y_length > Dominion.config.getLimitSizeY(operator.getPlayer()) && Dominion.config.getLimitSizeY(operator.getPlayer()) > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y方向高度不能超过 %d", Dominion.config.getLimitSizeY(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
if (z_length > Dominion.config.getLimitSizeZ() && Dominion.config.getLimitSizeZ() > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地Z方向长度不能超过 %d", Dominion.config.getLimitSizeZ()));
|
||||
if (z_length > Dominion.config.getLimitSizeZ(operator.getPlayer()) && Dominion.config.getLimitSizeZ(operator.getPlayer()) > 0) {
|
||||
operator.setResponse(FAIL.addMessage("领地Z方向长度不能超过 %d", Dominion.config.getLimitSizeZ(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
if (y2 > Dominion.config.getLimitMaxY()) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y坐标不能超过 %d", Dominion.config.getLimitMaxY()));
|
||||
if (y2 > Dominion.config.getLimitMaxY(operator.getPlayer())) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y坐标不能超过 %d", Dominion.config.getLimitMaxY(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
if (y1 < Dominion.config.getLimitMinY()) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y坐标不能低于 %d", Dominion.config.getLimitMinY()));
|
||||
if (y1 < Dominion.config.getLimitMinY(operator.getPlayer())) {
|
||||
operator.setResponse(FAIL.addMessage("领地Y坐标不能低于 %d", Dominion.config.getLimitMinY(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
@ -815,10 +748,10 @@ public class DominionController {
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return false;
|
||||
}
|
||||
if (Dominion.config.getLimitDepth() == -1) {
|
||||
if (Dominion.config.getLimitDepth(operator.getPlayer()) == -1) {
|
||||
return false;
|
||||
}
|
||||
if (parent_dom.getId() != -1 && Dominion.config.getLimitDepth() == 0) {
|
||||
if (parent_dom.getId() != -1 && Dominion.config.getLimitDepth(operator.getPlayer()) == 0) {
|
||||
operator.setResponse(FAIL.addMessage("不允许创建子领地"));
|
||||
return true;
|
||||
}
|
||||
@ -830,8 +763,8 @@ public class DominionController {
|
||||
parent_dom = Cache.instance.getDominion(parent_dom.getParentDomId());
|
||||
level++;
|
||||
}
|
||||
if (level >= Dominion.config.getLimitDepth()) {
|
||||
operator.setResponse(FAIL.addMessage("子领地嵌套深度不能超过 %s", Dominion.config.getLimitDepth()));
|
||||
if (level >= Dominion.config.getLimitDepth(operator.getPlayer())) {
|
||||
operator.setResponse(FAIL.addMessage("子领地嵌套深度不能超过 %d", Dominion.config.getLimitDepth(operator.getPlayer())));
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
@ -841,14 +774,14 @@ public class DominionController {
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return false;
|
||||
}
|
||||
return Cache.instance.getPlayerDominionCount(operator.getUniqueId()) >= Dominion.config.getLimitAmount() && Dominion.config.getLimitAmount() != -1;
|
||||
return Cache.instance.getPlayerDominionCount(operator.getUniqueId()) >= Dominion.config.getLimitAmount(operator.getPlayer()) && Dominion.config.getLimitAmount(operator.getPlayer()) != -1;
|
||||
}
|
||||
|
||||
private static boolean worldNotValid(AbstractOperator operator, String world) {
|
||||
private static boolean worldNotValid(AbstractOperator operator, String worldName) {
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return false;
|
||||
}
|
||||
return Dominion.config.getWorldBlackList().contains(world);
|
||||
return Dominion.config.getWorldBlackList(operator.getPlayer()).contains(worldName);
|
||||
}
|
||||
|
||||
private static DominionDTO getExistDomAndIsOwner(AbstractOperator operator, String dominion_name) {
|
||||
@ -865,4 +798,141 @@ public class DominionController {
|
||||
return dominion;
|
||||
}
|
||||
|
||||
/**
|
||||
* 处理经济系统
|
||||
*
|
||||
* @param operator 操作者
|
||||
* @param count 数量
|
||||
* @param paid 操作类型 true 为扣费 false 为退费
|
||||
* @param FAIL 失败消息
|
||||
* @param SUCCESS 成功消息
|
||||
*/
|
||||
private static boolean handleEconomyFailed(AbstractOperator operator, Integer count, boolean paid, AbstractOperator.Result FAIL, AbstractOperator.Result SUCCESS) {
|
||||
if (Dominion.config.getEconomyEnable()) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
operator.setResponse(FAIL.addMessage("没有可用的经济插件系统,请联系服主。"));
|
||||
return true;
|
||||
}
|
||||
if (operator.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
SUCCESS.addMessage("你是OP,已跳过经济检查。");
|
||||
return false;
|
||||
}
|
||||
float priceOrRefund = count * Dominion.config.getEconomyPrice(operator.getPlayer());
|
||||
if (paid) {
|
||||
if (VaultConnect.instance.getBalance(operator.getPlayer()) < priceOrRefund) {
|
||||
operator.setResponse(FAIL.addMessage("你的余额不足,需要 %.2f %s", priceOrRefund, VaultConnect.instance.currencyNamePlural()));
|
||||
return true;
|
||||
}
|
||||
SUCCESS.addMessage("已扣除 %.2f %s", priceOrRefund, VaultConnect.instance.currencyNamePlural());
|
||||
VaultConnect.instance.withdrawPlayer(operator.getPlayer(), priceOrRefund);
|
||||
} else {
|
||||
float refund = priceOrRefund * Dominion.config.getEconomyRefund(operator.getPlayer());
|
||||
VaultConnect.instance.depositPlayer(operator.getPlayer(), refund);
|
||||
SUCCESS.addMessage("已退还 %.2f %s", refund, VaultConnect.instance.currencyNamePlural());
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* 显示粒子效果
|
||||
*
|
||||
* @param operator 操作者
|
||||
* @param dominion 领地
|
||||
*/
|
||||
private static void handleParticle(AbstractOperator operator, DominionDTO dominion) {
|
||||
if (operator instanceof BukkitPlayerOperator) {
|
||||
Particle.showBorder(operator.getPlayer(), dominion);
|
||||
}
|
||||
}
|
||||
|
||||
private static @Nullable DominionDTO expandContractPreCheck(AbstractOperator operator, @Nullable DominionDTO dominion, AbstractOperator.Result FAIL) {
|
||||
if (dominion == null) {
|
||||
return null;
|
||||
}
|
||||
if (operator.getLocation() == null) {
|
||||
operator.setResponse(FAIL.addMessage("无法获取你的位置"));
|
||||
return null;
|
||||
}
|
||||
if (!operator.getLocation().getWorld().getUID().equals(dominion.getWorldUid())) {
|
||||
operator.setResponse(FAIL.addMessage("禁止跨世界操作"));
|
||||
return null;
|
||||
}
|
||||
if (!isInDominion(dominion, operator.getLocation())) {
|
||||
operator.setResponse(FAIL.addMessage("你不在领地 %s 内,无法执行此操作", dominion.getName()));
|
||||
return null;
|
||||
}
|
||||
return dominion;
|
||||
}
|
||||
|
||||
private static int[] expandContractSizeChange(AbstractOperator operator, @NotNull DominionDTO dominion, boolean expand, int size, AbstractOperator.Result FAIL) {
|
||||
BlockFace face = operator.getDirection();
|
||||
if (face == null) {
|
||||
operator.setResponse(FAIL.addMessage("无法获取你的方向"));
|
||||
return null;
|
||||
}
|
||||
int[] result = new int[6];
|
||||
result[0] = dominion.getX1();
|
||||
result[1] = dominion.getY1();
|
||||
result[2] = dominion.getZ1();
|
||||
result[3] = dominion.getX2();
|
||||
result[4] = dominion.getY2();
|
||||
result[5] = dominion.getZ2();
|
||||
if (!expand) {
|
||||
size = size * -1;
|
||||
}
|
||||
switch (face) {
|
||||
case NORTH:
|
||||
result[2] -= size;
|
||||
break;
|
||||
case SOUTH:
|
||||
result[5] += size;
|
||||
break;
|
||||
case WEST:
|
||||
result[0] -= size;
|
||||
break;
|
||||
case EAST:
|
||||
result[3] += size;
|
||||
break;
|
||||
case UP:
|
||||
result[4] += size;
|
||||
break;
|
||||
case DOWN:
|
||||
result[1] -= size;
|
||||
break;
|
||||
default:
|
||||
operator.setResponse(FAIL.addMessage("无效的方向"));
|
||||
return null;
|
||||
}
|
||||
if (!expand) {
|
||||
// 校验第二组坐标是否小于第一组坐标
|
||||
if (result[0] > result[3] || result[1] > result[4] || result[2] > result[5]) {
|
||||
operator.setResponse(FAIL.addMessage("缩小后的领地大小无效"));
|
||||
return null;
|
||||
}
|
||||
}
|
||||
if (sizeNotValid(operator, result)) {
|
||||
return null;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 以警告形式打印所有子领地名称
|
||||
*
|
||||
* @param sub_dominions 子领地列表
|
||||
* @param WARNING 警告消息
|
||||
*/
|
||||
public static void showSubNamesWarning(List<DominionDTO> sub_dominions, AbstractOperator.Result WARNING) {
|
||||
String sub_names = "";
|
||||
for (DominionDTO sub_dominion : sub_dominions) {
|
||||
sub_names = sub_dominion.getName() + ", ";
|
||||
}
|
||||
if (!sub_dominions.isEmpty()) {
|
||||
sub_names = sub_names.substring(0, sub_names.length() - 2);
|
||||
WARNING.addMessage("(子领地:%s)", sub_names);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -2,8 +2,9 @@ package cn.lunadeer.dominion.controllers;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.utils.ControllerUtils;
|
||||
|
||||
import static cn.lunadeer.dominion.controllers.Apis.noAuthToChangeFlags;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.noAuthToChangeFlags;
|
||||
|
||||
public class FlagsController {
|
||||
|
||||
@ -13,10 +14,9 @@ public class FlagsController {
|
||||
* @param operator 操作者
|
||||
* @param flag 权限名称
|
||||
* @param value 权限值
|
||||
* @return 设置后的领地信息
|
||||
*/
|
||||
public static void setFlag(AbstractOperator operator, String flag, boolean value) {
|
||||
DominionDTO dominion = Apis.getPlayerCurrentDominion(operator);
|
||||
DominionDTO dominion = ControllerUtils.getPlayerCurrentDominion(operator);
|
||||
if (dominion == null) return;
|
||||
setFlag(operator, flag, value, dominion.getName());
|
||||
operator.setResponse(new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "设置领地权限 %s 为 %s", flag, value));
|
||||
@ -29,7 +29,6 @@ public class FlagsController {
|
||||
* @param flag 权限名称
|
||||
* @param value 权限值
|
||||
* @param dominionName 领地名称
|
||||
* @return 设置后的领地信息
|
||||
*/
|
||||
public static void setFlag(AbstractOperator operator, String flag, boolean value, String dominionName) {
|
||||
DominionDTO dominion = DominionDTO.select(dominionName);
|
@ -4,12 +4,12 @@ import cn.lunadeer.dominion.dtos.*;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.controllers.Apis.noAuthToChangeFlags;
|
||||
import static cn.lunadeer.dominion.controllers.Apis.notOwner;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.noAuthToChangeFlags;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.notOwner;
|
||||
|
||||
public class GroupController {
|
||||
|
||||
public static void createGroup(AbstractOperator operator, String domName, String groupName) {
|
||||
public static void createGroup(AbstractOperator operator, String domName, String groupName, String nameColored) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "创建权限组 %s 失败", groupName);
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "创建权限组 %s 成功", groupName);
|
||||
if (groupName.contains(" ")) {
|
||||
@ -30,7 +30,7 @@ public class GroupController {
|
||||
operator.setResponse(FAIL.addMessage("领地 %s 已存在名为 %s 的权限组", domName, groupName));
|
||||
return;
|
||||
}
|
||||
group = GroupDTO.create(groupName, dominion);
|
||||
group = GroupDTO.create(nameColored, dominion);
|
||||
if (group == null) {
|
||||
operator.setResponse(FAIL.addMessage("请联系服务器管理员"));
|
||||
return;
|
||||
@ -82,10 +82,6 @@ public class GroupController {
|
||||
if (flag.equals("admin")) {
|
||||
group = group.setAdmin(value);
|
||||
} else {
|
||||
if (group.getAdmin()) {
|
||||
operator.setResponse(FAIL.addMessage("管理员拥有所有权限,无需单独设置权限"));
|
||||
return;
|
||||
}
|
||||
Flag f = Flag.getFlag(flag);
|
||||
if (f == null) {
|
||||
operator.setResponse(FAIL.addMessage("未知的权限 %s", flag));
|
||||
@ -100,7 +96,7 @@ public class GroupController {
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
public static void renameGroup(AbstractOperator operator, String domName, String oldName, String newName) {
|
||||
public static void renameGroup(AbstractOperator operator, String domName, String oldName, String newName, String nameColored) {
|
||||
AbstractOperator.Result FAIL = new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "重命名权限组 %s 为 %s 失败", oldName, newName);
|
||||
AbstractOperator.Result SUCCESS = new AbstractOperator.Result(AbstractOperator.Result.SUCCESS, "重命名权限组 %s 为 %s 成功", oldName, newName);
|
||||
if (newName.contains(" ")) {
|
||||
@ -121,7 +117,7 @@ public class GroupController {
|
||||
operator.setResponse(FAIL.addMessage("领地 %s 不存在名为 %s 的权限组", domName, oldName));
|
||||
return;
|
||||
}
|
||||
group = group.setName(newName);
|
||||
group = group.setName(nameColored);
|
||||
if (group == null) {
|
||||
operator.setResponse(FAIL.addMessage("请联系服务器管理员"));
|
||||
return;
|
||||
@ -155,7 +151,7 @@ public class GroupController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在", playerName));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(player.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不是领地 %s 的成员,无法直接加入权限组", playerName, domName));
|
||||
return;
|
||||
@ -202,7 +198,7 @@ public class GroupController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在", playerName));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(player.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不是领地 %s 的成员", playerName, domName));
|
||||
return;
|
@ -2,8 +2,7 @@ package cn.lunadeer.dominion.controllers;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.*;
|
||||
|
||||
import static cn.lunadeer.dominion.controllers.Apis.noAuthToChangeFlags;
|
||||
import static cn.lunadeer.dominion.controllers.Apis.notOwner;
|
||||
import static cn.lunadeer.dominion.utils.ControllerUtils.*;
|
||||
|
||||
public class MemberController {
|
||||
|
||||
@ -28,16 +27,16 @@ public class MemberController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在或没有登录过", player_name));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(player.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不是领地 %s 的成员", player_name, dominionName));
|
||||
return;
|
||||
}
|
||||
if (privilege.getAdmin() && notOwner(operator, dominion)) {
|
||||
if (isAdmin(privilege) && notOwner(operator, dominion)) {
|
||||
operator.setResponse(FAIL.addMessage("你不是领地 %s 的拥有者,无法移除一个领地管理员", dominionName));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO.delete(player.getUuid(), dominion.getId());
|
||||
MemberDTO.delete(player.getUuid(), dominion.getId());
|
||||
operator.setResponse(SUCCESS);
|
||||
}
|
||||
|
||||
@ -64,22 +63,23 @@ public class MemberController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在或没有登录过", player_name));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(player.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不是领地 %s 的成员", player_name, dominionName));
|
||||
return;
|
||||
}
|
||||
if ((flag.equals("admin") || privilege.getAdmin()) && notOwner(operator, dominion)) {
|
||||
GroupDTO group = GroupDTO.select(privilege.getGroupId());
|
||||
if (group != null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 属于 %s 权限组,无法单独设置权限", player_name, group.getName()));
|
||||
return;
|
||||
}
|
||||
if ((flag.equals("admin") || isAdmin(privilege)) && notOwner(operator, dominion)) {
|
||||
operator.setResponse(FAIL.addMessage("你不是领地 %s 的拥有者,无法修改其他玩家管理员的权限", dominionName));
|
||||
return;
|
||||
}
|
||||
if (flag.equals("admin")) {
|
||||
privilege.setAdmin(value);
|
||||
} else {
|
||||
if (privilege.getAdmin()) {
|
||||
operator.setResponse(FAIL.addMessage("管理员拥有所有权限,无需单独设置权限"));
|
||||
return;
|
||||
}
|
||||
Flag f = Flag.getFlag(flag);
|
||||
if (f == null) {
|
||||
operator.setResponse(FAIL.addMessage("未知的领地权限 %s", flag));
|
||||
@ -104,7 +104,16 @@ public class MemberController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在或没有登录过", player_name));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.insert(new PlayerPrivilegeDTO(player.getUuid(), dominion));
|
||||
if (dominion.getOwner().equals(player.getUuid())) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 是领地 %s 的拥有者,不可以被添加为成员", player_name, dominionName));
|
||||
return;
|
||||
}
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege != null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 已经是领地 %s 的成员", player_name, dominionName));
|
||||
return;
|
||||
}
|
||||
privilege = MemberDTO.insert(new MemberDTO(player.getUuid(), dominion));
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL);
|
||||
} else {
|
||||
@ -126,7 +135,7 @@ public class MemberController {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不存在或没有登录过", playerName));
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(player.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(player.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
operator.setResponse(FAIL.addMessage("玩家 %s 不是领地 %s 的成员", playerName, dominionName));
|
||||
return;
|
||||
@ -136,7 +145,7 @@ public class MemberController {
|
||||
operator.setResponse(FAIL.addMessage("模板 %s 不存在", templateName));
|
||||
return;
|
||||
}
|
||||
if (notOwner(operator, dominion) && privilege.getAdmin()) {
|
||||
if (notOwner(operator, dominion) && (isAdmin(privilege) || template.getAdmin())) {
|
||||
operator.setResponse(FAIL.addMessage("你不是领地 %s 的拥有者,无法修改其他管理员的权限", dominionName));
|
||||
return;
|
||||
}
|
@ -1,11 +1,9 @@
|
||||
package cn.lunadeer.dominion.cuis;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.controllers.AbstractOperator;
|
||||
import cn.lunadeer.dominion.controllers.BukkitPlayerOperator;
|
||||
import cn.lunadeer.dominion.controllers.DominionController;
|
||||
import cn.lunadeer.dominion.tuis.dominion.DominionManage;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.Location;
|
||||
@ -15,8 +13,8 @@ import org.bukkit.entity.Player;
|
||||
import java.util.Map;
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.autoPoints;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.autoPoints;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class CreateDominion {
|
||||
|
||||
@ -30,13 +28,9 @@ public class CreateDominion {
|
||||
@Override
|
||||
public void handleData(String input) {
|
||||
XLogger.debug("createDominionCB.run: %s", input);
|
||||
autoPoints(sender);
|
||||
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
Map<Integer, Location> points = Dominion.pointsSelect.get(sender.getUniqueId());
|
||||
if (points == null || points.get(0) == null || points.get(1) == null) {
|
||||
Notification.error(sender, "自动选点失败");
|
||||
return;
|
||||
}
|
||||
Map<Integer, Location> points = autoPoints(sender);
|
||||
operator.getResponse().thenAccept(result -> {
|
||||
if (Objects.equals(result.getStatus(), AbstractOperator.Result.SUCCESS)) {
|
||||
DominionManage.show(sender, new String[]{"list"});
|
@ -4,13 +4,14 @@ import cn.lunadeer.dominion.controllers.BukkitPlayerOperator;
|
||||
import cn.lunadeer.dominion.controllers.GroupController;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.group.GroupList;
|
||||
import cn.lunadeer.minecraftpluginutils.ColorParser;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class CreateGroup {
|
||||
|
||||
@ -28,7 +29,7 @@ public class CreateGroup {
|
||||
public void handleData(String input) {
|
||||
XLogger.debug("createGroupCB.run: %s", input);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
GroupController.createGroup(operator, dominionName, input);
|
||||
GroupController.createGroup(operator, dominionName, ColorParser.getPlainText(input), input);
|
||||
GroupList.show(sender, dominionName);
|
||||
}
|
||||
}
|
@ -8,7 +8,7 @@ import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class CreateTemplate {
|
||||
|
@ -10,7 +10,7 @@ import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class EditJoinMessage {
|
||||
|
@ -10,7 +10,7 @@ import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class EditLeaveMessage {
|
||||
|
@ -14,7 +14,7 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class MemberAdd {
|
||||
|
@ -8,7 +8,7 @@ import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class RenameDominion {
|
||||
|
@ -4,13 +4,14 @@ import cn.lunadeer.dominion.controllers.BukkitPlayerOperator;
|
||||
import cn.lunadeer.dominion.controllers.GroupController;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.tuis.dominion.manage.group.GroupSetting;
|
||||
import cn.lunadeer.minecraftpluginutils.ColorParser;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class RenameGroup {
|
||||
|
||||
@ -30,8 +31,8 @@ public class RenameGroup {
|
||||
public void handleData(String input) {
|
||||
XLogger.debug("renameGroupCB.run: %s", input);
|
||||
BukkitPlayerOperator operator = BukkitPlayerOperator.create(sender);
|
||||
GroupController.renameGroup(operator, dominionName, oldName, input);
|
||||
GroupSetting.show(sender, dominionName, input);
|
||||
GroupController.renameGroup(operator, dominionName, oldName, ColorParser.getPlainText(input), input);
|
||||
GroupSetting.show(sender, dominionName, ColorParser.getPlainText(input));
|
||||
}
|
||||
}
|
||||
|
@ -10,7 +10,7 @@ import cn.lunadeer.minecraftpluginutils.scui.CuiTextInput;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class SetMapColor {
|
||||
|
@ -10,6 +10,8 @@ import cn.lunadeer.minecraftpluginutils.databse.syntax.InsertRow;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.UpdateRow;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
@ -33,7 +35,7 @@ public class DominionDTO {
|
||||
Integer id = rs.getInt("id");
|
||||
UUID owner = UUID.fromString(rs.getString("owner"));
|
||||
String name = rs.getString("name");
|
||||
String world = rs.getString("world");
|
||||
UUID world_uid = UUID.fromString(rs.getString("world_uid"));
|
||||
Integer x1 = rs.getInt("x1");
|
||||
Integer y1 = rs.getInt("y1");
|
||||
Integer z1 = rs.getInt("z1");
|
||||
@ -48,7 +50,7 @@ public class DominionDTO {
|
||||
}
|
||||
String color = rs.getString("color");
|
||||
|
||||
DominionDTO dominion = new DominionDTO(id, owner, name, world, x1, y1, z1, x2, y2, z2, parentDomId,
|
||||
DominionDTO dominion = new DominionDTO(id, owner, name, world_uid, x1, y1, z1, x2, y2, z2, parentDomId,
|
||||
rs.getString("join_message"),
|
||||
rs.getString("leave_message"),
|
||||
flags,
|
||||
@ -65,18 +67,13 @@ public class DominionDTO {
|
||||
return query(sql);
|
||||
}
|
||||
|
||||
public static List<DominionDTO> selectAll(String world) {
|
||||
String sql = "SELECT * FROM dominion WHERE world = ? AND id > 0;";
|
||||
return query(sql, world);
|
||||
}
|
||||
|
||||
public static List<DominionDTO> search(String name) {
|
||||
String sql = "SELECT * FROM dominion WHERE name LIKE ? AND id > 0;";
|
||||
return query(sql, "%" + name + "%");
|
||||
}
|
||||
|
||||
public static List<DominionDTO> selectAll(UUID owner) {
|
||||
String sql = "SELECT * FROM dominion WHERE owner = ? AND id > 0;";
|
||||
public static List<DominionDTO> selectByOwner(UUID owner) {
|
||||
String sql = "SELECT * FROM dominion WHERE owner = ? AND id > 0 ORDER BY id DESC;";
|
||||
return query(sql, owner.toString());
|
||||
}
|
||||
|
||||
@ -84,41 +81,45 @@ public class DominionDTO {
|
||||
if (id == -1) {
|
||||
return new DominionDTO(-1,
|
||||
UUID.fromString("00000000-0000-0000-0000-000000000000"),
|
||||
"根领地", "all",
|
||||
"根领地", UUID.fromString("00000000-0000-0000-0000-000000000000"),
|
||||
-2147483648, -2147483648, -2147483648,
|
||||
2147483647, 2147483647, 2147483647, -1);
|
||||
}
|
||||
String sql = "SELECT * FROM dominion WHERE id = ? AND id > 0;";
|
||||
List<DominionDTO> dominions = query(sql, id);
|
||||
if (dominions.size() == 0) return null;
|
||||
return dominions.get(0);
|
||||
if (dominions.isEmpty()) return null;
|
||||
return dominions.getFirst();
|
||||
}
|
||||
|
||||
public static List<DominionDTO> selectByParentId(String world, Integer parentId) {
|
||||
String sql = "SELECT * FROM dominion WHERE world = ? AND parent_dom_id = ? AND id > 0;";
|
||||
return query(sql, world, parentId);
|
||||
public static List<DominionDTO> selectByParentId(World world, Integer parentId){
|
||||
return selectByParentId(world.getUID(), parentId);
|
||||
}
|
||||
|
||||
public static List<DominionDTO> selectByLocation(String world, Integer x, Integer y, Integer z) {
|
||||
String sql = "SELECT * FROM dominion WHERE world = ? AND " +
|
||||
public static List<DominionDTO> selectByParentId(UUID world_uid, Integer parentId) {
|
||||
String sql = "SELECT * FROM dominion WHERE world_uid = ? AND parent_dom_id = ? AND id > 0;";
|
||||
return query(sql, world_uid.toString(), parentId);
|
||||
}
|
||||
|
||||
public static List<DominionDTO> selectByLocation(UUID world_uid, Integer x, Integer y, Integer z) {
|
||||
String sql = "SELECT * FROM dominion WHERE world_uid = ? AND " +
|
||||
"x1 <= ? AND x2 >= ? AND " +
|
||||
"y1 <= ? AND y2 >= ? AND " +
|
||||
"z1 <= ? AND z2 >= ? AND " + "id > 0;";
|
||||
return query(sql, world, x, x, y, y, z, z);
|
||||
return query(sql, world_uid.toString(), x, x, y, y, z, z);
|
||||
}
|
||||
|
||||
public static DominionDTO select(String name) {
|
||||
String sql = "SELECT * FROM dominion WHERE name = ? AND id > 0;";
|
||||
List<DominionDTO> dominions = query(sql, name);
|
||||
if (dominions.size() == 0) return null;
|
||||
return dominions.get(0);
|
||||
if (dominions.isEmpty()) return null;
|
||||
return dominions.getFirst();
|
||||
}
|
||||
|
||||
public static DominionDTO insert(DominionDTO dominion) {
|
||||
InsertRow insert = new InsertRow().returningAll().table("dominion").onConflictDoNothing(new Field("id", null));
|
||||
insert.field(dominion.owner)
|
||||
.field(dominion.name)
|
||||
.field(dominion.world)
|
||||
.field(dominion.world_uid)
|
||||
.field(dominion.x1).field(dominion.y1).field(dominion.z1)
|
||||
.field(dominion.x2).field(dominion.y2).field(dominion.z2)
|
||||
.field(dominion.parentDomId)
|
||||
@ -130,8 +131,8 @@ public class DominionDTO {
|
||||
try (ResultSet rs = insert.execute()) {
|
||||
Cache.instance.loadDominions();
|
||||
List<DominionDTO> dominions = getDTOFromRS(rs);
|
||||
if (dominions.size() == 0) return null;
|
||||
return dominions.get(0);
|
||||
if (dominions.isEmpty()) return null;
|
||||
return dominions.getFirst();
|
||||
} catch (SQLException e) {
|
||||
DatabaseManager.handleDatabaseError("数据库操作失败: ", e, insert.toString());
|
||||
return null;
|
||||
@ -144,7 +145,7 @@ public class DominionDTO {
|
||||
Cache.instance.loadDominions();
|
||||
}
|
||||
|
||||
private DominionDTO(Integer id, UUID owner, String name, String world,
|
||||
private DominionDTO(Integer id, UUID owner, String name, UUID world_uid,
|
||||
Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2,
|
||||
Integer parentDomId,
|
||||
String joinMessage, String leaveMessage,
|
||||
@ -154,7 +155,7 @@ public class DominionDTO {
|
||||
this.id.value = id;
|
||||
this.owner.value = owner.toString();
|
||||
this.name.value = name;
|
||||
this.world.value = world;
|
||||
this.world_uid.value = world_uid.toString();
|
||||
this.x1.value = x1;
|
||||
this.y1.value = y1;
|
||||
this.z1.value = z1;
|
||||
@ -170,13 +171,13 @@ public class DominionDTO {
|
||||
}
|
||||
|
||||
|
||||
private DominionDTO(Integer id, UUID owner, String name, String world,
|
||||
private DominionDTO(Integer id, UUID owner, String name, UUID world_uid,
|
||||
Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2,
|
||||
Integer parentDomId) {
|
||||
this.id.value = id;
|
||||
this.owner.value = owner.toString();
|
||||
this.name.value = name;
|
||||
this.world.value = world;
|
||||
this.world_uid.value = world_uid.toString();
|
||||
this.x1.value = x1;
|
||||
this.y1.value = y1;
|
||||
this.z1.value = z1;
|
||||
@ -186,15 +187,19 @@ public class DominionDTO {
|
||||
this.parentDomId.value = parentDomId;
|
||||
}
|
||||
|
||||
public DominionDTO(UUID owner, String name, String world,
|
||||
public DominionDTO(UUID owner, String name, @NotNull World world,
|
||||
Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2) {
|
||||
this(null, owner, name, world, x1, y1, z1, x2, y2, z2, -1);
|
||||
this(null, owner, name, world.getUID(), x1, y1, z1, x2, y2, z2, -1);
|
||||
}
|
||||
|
||||
public static DominionDTO create(UUID owner, String name, @NotNull World world,
|
||||
Integer x1, Integer y1, Integer z1, Integer x2, Integer y2, Integer z2, DominionDTO parent) {
|
||||
return new DominionDTO(null, owner, name, world.getUID(), x1, y1, z1, x2, y2, z2, parent == null ? -1 : parent.getId());
|
||||
}
|
||||
|
||||
private final Field id = new Field("id", FieldType.INT);
|
||||
private final Field owner = new Field("owner", FieldType.STRING);
|
||||
private final Field name = new Field("name", FieldType.STRING);
|
||||
private final Field world = new Field("world", FieldType.STRING);
|
||||
private final Field x1 = new Field("x1", FieldType.INT);
|
||||
private final Field y1 = new Field("y1", FieldType.INT);
|
||||
private final Field z1 = new Field("z1", FieldType.INT);
|
||||
@ -207,6 +212,7 @@ public class DominionDTO {
|
||||
private final Map<Flag, Boolean> flags = new HashMap<>();
|
||||
private final Field tp_location = new Field("tp_location", "default");
|
||||
private final Field color = new Field("color", "#00BFFF");
|
||||
private final Field world_uid = new Field("world_uid", FieldType.STRING);
|
||||
|
||||
|
||||
// getters and setters
|
||||
@ -224,9 +230,9 @@ public class DominionDTO {
|
||||
.where("id = ?", id.value);
|
||||
try (ResultSet rs = updateRow.execute()) {
|
||||
List<DominionDTO> dominions = getDTOFromRS(rs);
|
||||
if (dominions.size() == 0) return null;
|
||||
if (dominions.isEmpty()) return null;
|
||||
Cache.instance.loadDominions((Integer) id.value);
|
||||
return dominions.get(0);
|
||||
return dominions.getFirst();
|
||||
} catch (SQLException e) {
|
||||
DatabaseManager.handleDatabaseError("更新领地信息失败: ", e, updateRow.toString());
|
||||
return null;
|
||||
@ -247,8 +253,12 @@ public class DominionDTO {
|
||||
return doUpdate(new UpdateRow().field(this.name));
|
||||
}
|
||||
|
||||
public String getWorld() {
|
||||
return (String) world.value;
|
||||
public @Nullable World getWorld() {
|
||||
return Dominion.instance.getServer().getWorld(getWorldUid());
|
||||
}
|
||||
|
||||
public UUID getWorldUid() {
|
||||
return UUID.fromString((String) world_uid.value);
|
||||
}
|
||||
|
||||
public Integer getX1() {
|
||||
@ -306,34 +316,29 @@ public class DominionDTO {
|
||||
}
|
||||
|
||||
public Integer getSquare() {
|
||||
return (getX2() - getX1() + 1) * (getZ2() - getZ1() + 1);
|
||||
return getWidthX() * getWidthZ();
|
||||
}
|
||||
|
||||
public Integer getVolume() {
|
||||
return getSquare() * (getY2() - getY1() + 1);
|
||||
return getSquare() * getHeight();
|
||||
}
|
||||
|
||||
public Integer getWidthX() {
|
||||
return getX2() - getX1() + 1;
|
||||
return getX2() - getX1();
|
||||
}
|
||||
|
||||
public Integer getHeight() {
|
||||
return getY2() - getY1() + 1;
|
||||
return getY2() - getY1();
|
||||
}
|
||||
|
||||
public Integer getWidthZ() {
|
||||
return getZ2() - getZ1() + 1;
|
||||
return getZ2() - getZ1();
|
||||
}
|
||||
|
||||
public Integer getParentDomId() {
|
||||
return (Integer) parentDomId.value;
|
||||
}
|
||||
|
||||
public DominionDTO setParentDomId(Integer parentDomId) {
|
||||
this.parentDomId.value = parentDomId;
|
||||
return doUpdate(new UpdateRow().field(this.parentDomId));
|
||||
}
|
||||
|
||||
public String getJoinMessage() {
|
||||
return (String) joinMessage.value;
|
||||
}
|
||||
@ -373,18 +378,28 @@ public class DominionDTO {
|
||||
return doUpdate(new UpdateRow().field(this.x1).field(this.y1).field(this.z1).field(this.x2).field(this.y2).field(this.z2));
|
||||
}
|
||||
|
||||
public DominionDTO setXYZ(int[] cords) {
|
||||
if (cords.length == 6) {
|
||||
return setXYZ(cords[0], cords[1], cords[2], cords[3], cords[4], cords[5]);
|
||||
} else {
|
||||
XLogger.warn("领地坐标数据异常: %s", (Object) cords);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public Location getTpLocation() {
|
||||
if (Objects.equals(tp_location, "default")) {
|
||||
if (Objects.equals(tp_location.value, "default")) {
|
||||
return null;
|
||||
} else {
|
||||
// 0:0:0
|
||||
String[] loc = ((String) tp_location.value).split(":");
|
||||
World w = Dominion.instance.getServer().getWorld(getWorld());
|
||||
World w = getWorld();
|
||||
if (loc.length == 3 && w != null) {
|
||||
return new Location(w, Integer.parseInt(loc[0]), Integer.parseInt(loc[1]), Integer.parseInt(loc[2]));
|
||||
} else {
|
||||
XLogger.warn("领地传送点数据异常: %s", tp_location);
|
||||
XLogger.debug("world: %s, loc.length: %d", world, loc.length);
|
||||
XLogger.debug("world: %s, loc.length: %d", getWorld(), loc.length);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
@ -396,11 +411,11 @@ public class DominionDTO {
|
||||
}
|
||||
|
||||
public Location getLocation1() {
|
||||
return new Location(Dominion.instance.getServer().getWorld(getWorld()), getX1(), getY1(), getZ1());
|
||||
return new Location(getWorld(), getX1(), getY1(), getZ1());
|
||||
}
|
||||
|
||||
public Location getLocation2() {
|
||||
return new Location(Dominion.instance.getServer().getWorld(getWorld()), getX2(), getY2(), getZ2());
|
||||
return new Location(getWorld(), getX2(), getY2(), getZ2());
|
||||
}
|
||||
|
||||
public DominionDTO setColor(String color) {
|
||||
@ -423,4 +438,8 @@ public class DominionDTO {
|
||||
public String getColor() {
|
||||
return (String) color.value;
|
||||
}
|
||||
|
||||
public int getColorHex() {
|
||||
return (getColorR() << 16) + (getColorG() << 8) + getColorB();
|
||||
}
|
||||
}
|
@ -20,14 +20,17 @@ public enum Flag {
|
||||
BEACON("beacon", "信标交互", "是否允许与信标交互", false, false, true),
|
||||
BED("bed", "床交互", "是否允许使用床睡觉或设置重生点", false, false, true),
|
||||
BREW("brew", "使用酿造台", "是否可以使用酿造台", false, false, true),
|
||||
BREAK_BLOCK("break", "破坏方块", "是否可以破坏方块(包括:一般方块、展示框)", false, false, true),
|
||||
BREAK_BLOCK("break", "破坏方块", "是否可以破坏方块(包括:一般方块、展示框、盔甲架)", false, false, true),
|
||||
BUTTON("button", "使用按钮", "是否可以使用各种材质的按钮", false, false, true),
|
||||
CAKE("cake", "吃蛋糕", "是否可以吃蛋糕", false, false, true),
|
||||
CONTAINER("container", "一般容器", "包含:箱子/木桶/潜影盒/盔甲架/展示框", false, false, true),
|
||||
CRAFT("craft", "使用工作台", "是否可以使用工作台", false, false, true),
|
||||
CREEPER_EXPLODE("creeper_explode", "实体爆炸", "包含:苦力怕/凋零头颅/水晶爆炸", false, true, true),
|
||||
CRAFTER("crafter", "合成器", "是否可以修改自动合成器", false, false, true),
|
||||
CREEPER_EXPLODE("creeper_explode", "生物破坏", "包含:苦力怕/凋零头颅/末影水晶/火球爆炸等", false, true, true),
|
||||
COMPARER("comparer", "比较器交互", "是否可以修改比较器状态", false, false, true),
|
||||
DOOR("door", "门交互", "是否可以使用各种材质的门(包括活板门)", false, false, true),
|
||||
DRAGON_BREAK_BLOCK("dragon_break_block", "末影龙破坏方块", "末影龙冲撞是否可以破坏方块", false, true, true),
|
||||
DRAGON_EGG("dragon_egg", "触碰龙蛋", "是否可以触碰龙蛋", false, false, true),
|
||||
DYE("dye", "染色", "是否可以使用染料(对羊、狗项圈、猫项圈)染色", false, false, true),
|
||||
EDIT_SIGN("edit_sign", "编辑告示牌", "是否可以编辑告示牌", false, false, true),
|
||||
EGG("egg", "扔鸡蛋", "是否可以扔鸡蛋", false, false, true),
|
||||
@ -43,27 +46,35 @@ public enum Flag {
|
||||
HONEY("honey", "蜂巢交互", "是否可以采蜂蜜", false, false, true),
|
||||
HOOK("hook", "使用钓钩", "是否可以使用钓钩", false, false, true),
|
||||
HOPPER("hopper", "特殊容器", "包含:漏斗/熔炉/发射器/投掷器/高炉/烟熏炉", false, false, true),
|
||||
HOPPER_OUTSIDE("hopper_outside", "领地外漏斗对领地内箱子是否生效", "领地外的漏斗是否可以对领地内的箱子生效", false, true, true),
|
||||
IGNITE("ignite", "点燃", "是否可以使用打火石点火", false, false, true),
|
||||
ITEM_FRAME_INTERACTIVE("item_frame_interactive", "展示框交互", "是否可以与物品展示框交互(旋转展示框的东西)", false, false, true),
|
||||
ITEM_FRAME_PROJ_DAMAGE("item_frame_proj_damage", "投掷物是否可以破坏展示框/画", "非玩家发出的投掷物是否可以破坏展示框/画等悬挂物", false, true, true),
|
||||
LEVER("lever", "使用拉杆", "是否可以使用拉杆", false, false, true),
|
||||
MOB_DROP_ITEM("mob_drop_item", "生物战利品掉落", "生物死亡时是否产生凋落物", true, true, true),
|
||||
MOB_DROP_ITEM("mob_drop_item", "生物战利品掉落", "生物死亡时是否产生掉落物", true, true, true),
|
||||
MONSTER_KILLING("monster_killing", "对怪物造成伤害", "玩家是否可以对怪物造成伤害", false, false, true),
|
||||
MONSTER_SPAWN("monster_spawn", "怪物生成", "是否可以生成怪物", false, true, false),
|
||||
MOVE("move", "移动", "是否可以移动", true, false, true),
|
||||
NOTE_BLOCK("note_block", "点击音符盒", "红石音乐或者某些红石机器会用到...", false, false, true),
|
||||
PLACE("place", "放置方块", "是否可以放置方块(包括:一般方块、展示框、岩浆、水)", false, false, true),
|
||||
PISTON_OUTSIDE("piston_outside", "活塞是否可以跨领地推动方块", "活塞是否可以往领地内推东西或推东西到领地外", false, true, true),
|
||||
PRESSURE("pressure", "压力板交互", "是否可以触发各种材质的压力板", false, false, true),
|
||||
RIDING("riding", "骑乘载具", "是否可以骑乘各种载具", false, false, true),
|
||||
REPEATER("repeater", "中继器交互", "是否可以与中继器交互", false, false, true),
|
||||
SHEAR("shear", "剪羊毛", "是否可以剪羊毛", false, false, true),
|
||||
SHOOT("shoot", "发射类型武器", "包括:射箭/雪球/三叉戟", false, false, true),
|
||||
SHOOT("shoot", "投掷型武器", "包括:射箭/雪球/三叉戟/风弹", false, false, true),
|
||||
SHOW_BORDER("show_border", "显示领地边界", "是否显示领地边界", true, true, true),
|
||||
TELEPORT("teleport", "领地传送", "是否开启领地传送", false, false, true),
|
||||
TNT_EXPLODE("tnt_explode", "TNT爆炸", "TNT是否可以爆炸", false, true, true),
|
||||
TRADE("trade", "村民交易", "是否可以与村民交易", false, false, true),
|
||||
TRAMPLE("trample", "作物践踏", "是否可以践踏作物(关闭意味着保护耕地)", false, true, true),
|
||||
TRIG_PRESSURE_PROJ("trig_pressure_proj", "投掷物触发压力板", "投掷物(箭/风弹/雪球)是否可以触发压力板", false, true, true),
|
||||
TRIG_PRESSURE_MOB("trig_pressure_mob", "生物触发压力板", "生物(不包含玩家)是否可以触发压力板", false, true, true),
|
||||
TRIG_PRESSURE_DROP("trig_pressure_drop", "掉落物触发压力板", "掉落物是否可以触发压力板", false, true, true),
|
||||
VEHICLE_DESTROY("vehicle_destroy", "破坏载具", "是否可以破坏载具(主要是矿车)", false, false, true),
|
||||
VEHICLE_SPAWN("vehicle_spawn", "生成载具", "是否可以生成载具(主要是矿车)", false, false, true),
|
||||
VILLAGER_KILLING("villager_killing", "对村民造成伤害", "是否可以对村民造成伤害", false, false, true),
|
||||
VILLAGER_SPAWN("villager_spawn", "村民繁殖", "是否允许村民繁殖", true, true, true),
|
||||
VILLAGER_SPAWN("villager_spawn", "村民繁殖", "是否允许村民繁殖(包括村民蛋)", true, true, true),
|
||||
WITHER_SPAWN("wither_spawn", "凋零生成", "凋零生成", false, true, true),
|
||||
;
|
||||
private final String flag_name;
|
@ -1,11 +1,14 @@
|
||||
package cn.lunadeer.dominion.dtos;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.minecraftpluginutils.ColorParser;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseManager;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.Field;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.FieldType;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.InsertRow;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.UpdateRow;
|
||||
import net.kyori.adventure.text.Component;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.util.ArrayList;
|
||||
@ -19,6 +22,8 @@ public class GroupDTO {
|
||||
Field domID = new Field("dom_id", FieldType.INT);
|
||||
Field name = new Field("name", FieldType.STRING);
|
||||
Field admin = new Field("admin", FieldType.BOOLEAN);
|
||||
Field name_colored = new Field("name_colored", FieldType.STRING);
|
||||
|
||||
private final Map<Flag, Boolean> flags = new HashMap<>();
|
||||
|
||||
public Integer getId() {
|
||||
@ -33,6 +38,24 @@ public class GroupDTO {
|
||||
return (String) name.value;
|
||||
}
|
||||
|
||||
public Component getNameColoredComponent() {
|
||||
String with_pre_suf = "&#ffffff" +
|
||||
Dominion.config.getGroupTitlePrefix() +
|
||||
(String) name_colored.value +
|
||||
"&#ffffff" +
|
||||
Dominion.config.getGroupTitleSuffix();
|
||||
return ColorParser.getComponentType(with_pre_suf);
|
||||
}
|
||||
|
||||
public String getNameColoredBukkit() {
|
||||
String with_pre_suf = "&#ffffff" +
|
||||
Dominion.config.getGroupTitlePrefix() +
|
||||
(String) name_colored.value +
|
||||
"&#ffffff" +
|
||||
Dominion.config.getGroupTitleSuffix();
|
||||
return ColorParser.getBukkitType(with_pre_suf);
|
||||
}
|
||||
|
||||
public Boolean getAdmin() {
|
||||
return (Boolean) admin.value;
|
||||
}
|
||||
@ -43,8 +66,9 @@ public class GroupDTO {
|
||||
}
|
||||
|
||||
public GroupDTO setName(String name) {
|
||||
this.name.value = name;
|
||||
UpdateRow updateRow = new UpdateRow().field(this.name);
|
||||
this.name_colored.value = name;
|
||||
this.name.value = ColorParser.getPlainText(name);
|
||||
UpdateRow updateRow = new UpdateRow().field(this.name).field(this.name_colored);
|
||||
return doUpdate(updateRow);
|
||||
}
|
||||
|
||||
@ -67,15 +91,16 @@ public class GroupDTO {
|
||||
insertRow.table("dominion_group")
|
||||
.field(group.domID)
|
||||
.field(group.name)
|
||||
.field(group.admin);
|
||||
.field(group.admin)
|
||||
.field(group.name_colored);
|
||||
for (Flag f : Flag.getPrivilegeFlagsEnabled()) {
|
||||
insertRow.field(new Field(f.getFlagName(), dominionDTO.getFlagValue(f)));
|
||||
}
|
||||
try (ResultSet rs = insertRow.execute()) {
|
||||
List<GroupDTO> groups = getDTOFromRS(rs);
|
||||
if (groups.size() == 0) return null;
|
||||
Cache.instance.loadGroup(groups.get(0).getId());
|
||||
return groups.get(0);
|
||||
if (groups.isEmpty()) return null;
|
||||
Cache.instance.loadGroups(groups.getFirst().getId());
|
||||
return groups.getFirst();
|
||||
} catch (Exception e) {
|
||||
DatabaseManager.handleDatabaseError("创建权限组失败: ", e, "");
|
||||
return null;
|
||||
@ -89,9 +114,9 @@ public class GroupDTO {
|
||||
public static void delete(Integer id) {
|
||||
String sql = "DELETE FROM dominion_group WHERE id = ?;";
|
||||
DatabaseManager.instance.query(sql, id);
|
||||
Cache.instance.loadGroup(id);
|
||||
List<PlayerPrivilegeDTO> players = PlayerPrivilegeDTO.selectByGroupId(id);
|
||||
for (PlayerPrivilegeDTO player : players) {
|
||||
Cache.instance.loadGroups(id);
|
||||
List<MemberDTO> players = MemberDTO.selectByGroupId(id);
|
||||
for (MemberDTO player : players) {
|
||||
player.setGroupId(-1);
|
||||
}
|
||||
}
|
||||
@ -99,15 +124,15 @@ public class GroupDTO {
|
||||
public static GroupDTO select(Integer id) {
|
||||
String sql = "SELECT * FROM dominion_group WHERE id = ?;";
|
||||
List<GroupDTO> groups = getDTOFromRS(DatabaseManager.instance.query(sql, id));
|
||||
if (groups.size() == 0) return null;
|
||||
return groups.get(0);
|
||||
if (groups.isEmpty()) return null;
|
||||
return groups.getFirst();
|
||||
}
|
||||
|
||||
public static GroupDTO select(Integer domID, String name) {
|
||||
String sql = "SELECT * FROM dominion_group WHERE dom_id = ? AND name = ?;";
|
||||
List<GroupDTO> groups = getDTOFromRS(DatabaseManager.instance.query(sql, domID, name));
|
||||
if (groups.size() == 0) return null;
|
||||
return groups.get(0);
|
||||
if (groups.isEmpty()) return null;
|
||||
return groups.getFirst();
|
||||
}
|
||||
|
||||
public static List<GroupDTO> selectAll() {
|
||||
@ -122,19 +147,21 @@ public class GroupDTO {
|
||||
|
||||
private GroupDTO(String name, Integer domID) {
|
||||
this.domID.value = domID;
|
||||
this.name.value = name;
|
||||
this.name.value = ColorParser.getPlainText(name);
|
||||
this.name_colored.value = name;
|
||||
this.admin.value = false;
|
||||
for (Flag f : Flag.getPrivilegeFlagsEnabled()) {
|
||||
flags.put(f, f.getDefaultValue());
|
||||
}
|
||||
}
|
||||
|
||||
private GroupDTO(Integer id, Integer domID, String name, Boolean admin, Map<Flag, Boolean> flags) {
|
||||
private GroupDTO(Integer id, Integer domID, String name, Boolean admin, Map<Flag, Boolean> flags, String nameColored) {
|
||||
this.id.value = id;
|
||||
this.domID.value = domID;
|
||||
this.name.value = name;
|
||||
this.admin.value = admin;
|
||||
this.flags.putAll(flags);
|
||||
this.name_colored.value = nameColored;
|
||||
}
|
||||
|
||||
private static List<GroupDTO> getDTOFromRS(ResultSet rs) {
|
||||
@ -151,7 +178,8 @@ public class GroupDTO {
|
||||
rs.getInt("dom_id"),
|
||||
rs.getString("name"),
|
||||
rs.getBoolean("admin"),
|
||||
flags
|
||||
flags,
|
||||
rs.getString("name_colored")
|
||||
);
|
||||
list.add(group);
|
||||
}
|
||||
@ -167,9 +195,9 @@ public class GroupDTO {
|
||||
.where("id = ?", id.value);
|
||||
try (ResultSet rs = updateRow.execute()) {
|
||||
List<GroupDTO> groups = getDTOFromRS(rs);
|
||||
if (groups.size() == 0) return null;
|
||||
Cache.instance.loadGroup((Integer) id.value);
|
||||
return groups.get(0);
|
||||
if (groups.isEmpty()) return null;
|
||||
Cache.instance.loadGroups((Integer) id.value);
|
||||
return groups.getFirst();
|
||||
} catch (Exception e) {
|
||||
DatabaseManager.handleDatabaseError("更新权限组失败: ", e, "");
|
||||
return null;
|
@ -10,10 +10,10 @@ import cn.lunadeer.minecraftpluginutils.databse.syntax.UpdateRow;
|
||||
import java.sql.ResultSet;
|
||||
import java.util.*;
|
||||
|
||||
public class PlayerPrivilegeDTO {
|
||||
public class MemberDTO {
|
||||
|
||||
private static List<PlayerPrivilegeDTO> query(String sql, Object... params) {
|
||||
List<PlayerPrivilegeDTO> players = new ArrayList<>();
|
||||
private static List<MemberDTO> query(String sql, Object... params) {
|
||||
List<MemberDTO> players = new ArrayList<>();
|
||||
try (ResultSet rs = DatabaseManager.instance.query(sql, params)) {
|
||||
return getDTOFromRS(rs);
|
||||
} catch (Exception e) {
|
||||
@ -22,8 +22,8 @@ public class PlayerPrivilegeDTO {
|
||||
return players;
|
||||
}
|
||||
|
||||
private static List<PlayerPrivilegeDTO> getDTOFromRS(ResultSet rs) {
|
||||
List<PlayerPrivilegeDTO> players = new ArrayList<>();
|
||||
private static List<MemberDTO> getDTOFromRS(ResultSet rs) {
|
||||
List<MemberDTO> players = new ArrayList<>();
|
||||
if (rs == null) return players;
|
||||
try {
|
||||
while (rs.next()) {
|
||||
@ -31,7 +31,7 @@ public class PlayerPrivilegeDTO {
|
||||
for (Flag f : Flag.getPrivilegeFlagsEnabled()) {
|
||||
flags.put(f, rs.getBoolean(f.getFlagName()));
|
||||
}
|
||||
PlayerPrivilegeDTO player = new PlayerPrivilegeDTO(
|
||||
MemberDTO player = new MemberDTO(
|
||||
rs.getInt("id"),
|
||||
UUID.fromString(rs.getString("player_uuid")),
|
||||
rs.getBoolean("admin"),
|
||||
@ -47,14 +47,14 @@ public class PlayerPrivilegeDTO {
|
||||
return players;
|
||||
}
|
||||
|
||||
private PlayerPrivilegeDTO doUpdate(UpdateRow updateRow) {
|
||||
private MemberDTO doUpdate(UpdateRow updateRow) {
|
||||
updateRow.returningAll(id)
|
||||
.table("player_privilege")
|
||||
.table("dominion_member")
|
||||
.where("id = ?", id.value);
|
||||
try (ResultSet rs = updateRow.execute()) {
|
||||
List<PlayerPrivilegeDTO> players = getDTOFromRS(rs);
|
||||
List<MemberDTO> players = getDTOFromRS(rs);
|
||||
if (players.size() == 0) return null;
|
||||
Cache.instance.loadPlayerPrivileges(getPlayerUUID());
|
||||
Cache.instance.loadMembers(getPlayerUUID());
|
||||
return players.get(0);
|
||||
} catch (Exception e) {
|
||||
DatabaseManager.handleDatabaseError("更新玩家权限失败: ", e, "");
|
||||
@ -62,9 +62,9 @@ public class PlayerPrivilegeDTO {
|
||||
}
|
||||
}
|
||||
|
||||
public static PlayerPrivilegeDTO insert(PlayerPrivilegeDTO player) {
|
||||
public static MemberDTO insert(MemberDTO player) {
|
||||
InsertRow insertRow = new InsertRow().returningAll().onConflictDoNothing(new Field("id", null))
|
||||
.table("player_privilege")
|
||||
.table("dominion_member")
|
||||
.field(player.playerUUID)
|
||||
.field(player.admin)
|
||||
.field(player.domID);
|
||||
@ -72,8 +72,8 @@ public class PlayerPrivilegeDTO {
|
||||
insertRow.field(new Field(f.getFlagName(), player.getFlagValue(f)));
|
||||
}
|
||||
try (ResultSet rs = insertRow.execute()) {
|
||||
Cache.instance.loadPlayerPrivileges(player.getPlayerUUID());
|
||||
List<PlayerPrivilegeDTO> players = getDTOFromRS(rs);
|
||||
Cache.instance.loadMembers(player.getPlayerUUID());
|
||||
List<MemberDTO> players = getDTOFromRS(rs);
|
||||
if (players.size() == 0) return null;
|
||||
return players.get(0);
|
||||
} catch (Exception e) {
|
||||
@ -82,39 +82,44 @@ public class PlayerPrivilegeDTO {
|
||||
}
|
||||
}
|
||||
|
||||
public static PlayerPrivilegeDTO select(UUID playerUUID, Integer dom_id) {
|
||||
String sql = "SELECT * FROM player_privilege WHERE player_uuid = ? AND dom_id = ?;";
|
||||
List<PlayerPrivilegeDTO> p = query(sql, playerUUID.toString(), dom_id);
|
||||
public static MemberDTO select(UUID playerUUID, Integer dom_id) {
|
||||
String sql = "SELECT * FROM dominion_member WHERE player_uuid = ? AND dom_id = ?;";
|
||||
List<MemberDTO> p = query(sql, playerUUID.toString(), dom_id);
|
||||
if (p.size() == 0) return null;
|
||||
return p.get(0);
|
||||
}
|
||||
|
||||
public static List<PlayerPrivilegeDTO> select(Integer dom_id) {
|
||||
String sql = "SELECT * FROM player_privilege WHERE dom_id = ?;";
|
||||
public static List<MemberDTO> select(Integer dom_id) {
|
||||
String sql = "SELECT * FROM dominion_member WHERE dom_id = ?;";
|
||||
return query(sql, dom_id);
|
||||
}
|
||||
|
||||
public static void delete(UUID player, Integer domID) {
|
||||
String sql = "DELETE FROM player_privilege WHERE player_uuid = ? AND dom_id = ?;";
|
||||
String sql = "DELETE FROM dominion_member WHERE player_uuid = ? AND dom_id = ?;";
|
||||
query(sql, player.toString(), domID);
|
||||
Cache.instance.loadPlayerPrivileges(player);
|
||||
Cache.instance.loadMembers(player);
|
||||
}
|
||||
|
||||
public static List<PlayerPrivilegeDTO> selectAll() {
|
||||
String sql = "SELECT * FROM player_privilege;";
|
||||
public static List<MemberDTO> selectAll() {
|
||||
String sql = "SELECT * FROM dominion_member;";
|
||||
return query(sql);
|
||||
}
|
||||
|
||||
public static List<PlayerPrivilegeDTO> selectAll(UUID player) {
|
||||
String sql = "SELECT * FROM player_privilege WHERE player_uuid = ?;";
|
||||
public static List<MemberDTO> selectAll(UUID player) {
|
||||
String sql = "SELECT * FROM dominion_member WHERE player_uuid = ?;";
|
||||
return query(sql, player.toString());
|
||||
}
|
||||
|
||||
public static List<PlayerPrivilegeDTO> selectByGroupId(Integer groupId) {
|
||||
String sql = "SELECT * FROM player_privilege WHERE group_id = ?;";
|
||||
public static List<MemberDTO> selectByGroupId(Integer groupId) {
|
||||
String sql = "SELECT * FROM dominion_member WHERE group_id = ?;";
|
||||
return query(sql, groupId);
|
||||
}
|
||||
|
||||
public static List<MemberDTO> selectByDomGroupId(Integer domId, Integer groupId) {
|
||||
String sql = "SELECT * FROM dominion_member WHERE group_id = ? AND dom_id = ?;";
|
||||
return query(sql, groupId, domId);
|
||||
}
|
||||
|
||||
Field id = new Field("id", FieldType.INT);
|
||||
Field playerUUID = new Field("player_uuid", FieldType.STRING);
|
||||
Field admin = new Field("admin", FieldType.BOOLEAN);
|
||||
@ -148,26 +153,26 @@ public class PlayerPrivilegeDTO {
|
||||
return flags.get(flag);
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO setFlagValue(Flag flag, Boolean value) {
|
||||
public MemberDTO setFlagValue(Flag flag, Boolean value) {
|
||||
flags.put(flag, value);
|
||||
Field f = new Field(flag.getFlagName(), value);
|
||||
UpdateRow updateRow = new UpdateRow().field(f);
|
||||
return doUpdate(updateRow);
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO setAdmin(Boolean admin) {
|
||||
public MemberDTO setAdmin(Boolean admin) {
|
||||
this.admin.value = admin;
|
||||
UpdateRow updateRow = new UpdateRow().field(this.admin);
|
||||
return doUpdate(updateRow);
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO setGroupId(Integer groupId) {
|
||||
public MemberDTO setGroupId(Integer groupId) {
|
||||
this.groupId.value = groupId;
|
||||
UpdateRow updateRow = new UpdateRow().field(this.groupId);
|
||||
return doUpdate(updateRow);
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO applyTemplate(PrivilegeTemplateDTO template) {
|
||||
public MemberDTO applyTemplate(PrivilegeTemplateDTO template) {
|
||||
this.admin.value = template.getAdmin();
|
||||
UpdateRow updateRow = new UpdateRow().field(admin);
|
||||
for (Flag f : Flag.getPrivilegeFlagsEnabled()) {
|
||||
@ -177,7 +182,7 @@ public class PlayerPrivilegeDTO {
|
||||
return doUpdate(updateRow);
|
||||
}
|
||||
|
||||
private PlayerPrivilegeDTO(Integer id, UUID playerUUID, Boolean admin, Integer domID, Map<Flag, Boolean> flags, Integer groupId) {
|
||||
private MemberDTO(Integer id, UUID playerUUID, Boolean admin, Integer domID, Map<Flag, Boolean> flags, Integer groupId) {
|
||||
this.id.value = id;
|
||||
this.playerUUID.value = playerUUID.toString();
|
||||
this.admin.value = admin;
|
||||
@ -186,7 +191,7 @@ public class PlayerPrivilegeDTO {
|
||||
this.flags.putAll(flags);
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO(UUID playerUUID, DominionDTO dom) {
|
||||
public MemberDTO(UUID playerUUID, DominionDTO dom) {
|
||||
this.id.value = null;
|
||||
this.playerUUID.value = playerUUID.toString();
|
||||
this.admin.value = false;
|
@ -1,5 +1,6 @@
|
||||
package cn.lunadeer.dominion.dtos;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.DatabaseManager;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.Field;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.InsertRow;
|
||||
@ -65,7 +66,8 @@ public class PlayerDTO {
|
||||
UUID uuid = UUID.fromString(rs.getString("uuid"));
|
||||
String lastKnownName = rs.getString("last_known_name");
|
||||
Long lastJoinAt = rs.getTimestamp("last_join_at").getTime();
|
||||
PlayerDTO player = new PlayerDTO(id, uuid, lastKnownName, lastJoinAt);
|
||||
Integer usingGroupTitleID = rs.getInt("using_group_title_id");
|
||||
PlayerDTO player = new PlayerDTO(id, uuid, lastKnownName, lastJoinAt, usingGroupTitleID);
|
||||
players.add(player);
|
||||
}
|
||||
return players;
|
||||
@ -74,15 +76,15 @@ public class PlayerDTO {
|
||||
public static PlayerDTO select(UUID uuid) {
|
||||
String sql = "SELECT * FROM player_name WHERE uuid = ?;";
|
||||
List<PlayerDTO> players = query(sql, uuid.toString());
|
||||
if (players.size() == 0) return null;
|
||||
return players.get(0);
|
||||
if (players.isEmpty()) return null;
|
||||
return players.getFirst();
|
||||
}
|
||||
|
||||
public static PlayerDTO select(String name) {
|
||||
String sql = "SELECT * FROM player_name WHERE last_known_name = ?;";
|
||||
List<PlayerDTO> players = query(sql, name);
|
||||
if (players.size() == 0) return null;
|
||||
return players.get(0);
|
||||
if (players.isEmpty()) return null;
|
||||
return players.getFirst();
|
||||
}
|
||||
|
||||
public static List<PlayerDTO> search(String name) {
|
||||
@ -100,17 +102,19 @@ public class PlayerDTO {
|
||||
Field uuid = new Field("uuid", player.getUuid().toString());
|
||||
Field lastKnownName = new Field("last_known_name", player.getLastKnownName());
|
||||
Field lastJoinAt = new Field("last_join_at", Timestamp.valueOf(LocalDateTime.now()));
|
||||
Field usingGroupTitleID = new Field("using_group_title_id", player.getUsingGroupTitleID());
|
||||
InsertRow insertRow = new InsertRow()
|
||||
.table("player_name")
|
||||
.field(uuid)
|
||||
.field(lastKnownName)
|
||||
.field(lastJoinAt)
|
||||
.field(usingGroupTitleID)
|
||||
.returningAll()
|
||||
.onConflictOverwrite(new Field("id", null));
|
||||
try (ResultSet rs = insertRow.execute()) {
|
||||
List<PlayerDTO> players = getDTOFromRS(rs);
|
||||
if (players.size() == 0) return null;
|
||||
return players.get(0);
|
||||
if (players.isEmpty()) return null;
|
||||
return players.getFirst();
|
||||
} catch (SQLException e) {
|
||||
DatabaseManager.handleDatabaseError("插入玩家信息失败: ", e, insertRow.toString());
|
||||
return null;
|
||||
@ -121,31 +125,34 @@ public class PlayerDTO {
|
||||
Field lastKnownName = new Field("last_known_name", player.getLastKnownName());
|
||||
Field uuid = new Field("uuid", player.getUuid().toString());
|
||||
Field lastJoinAt = new Field("last_join_at", Timestamp.valueOf(LocalDateTime.now()));
|
||||
Field usingGroupTitleID = new Field("using_group_title_id", player.getUsingGroupTitleID());
|
||||
UpdateRow updateRow = new UpdateRow()
|
||||
.table("player_name")
|
||||
.field(lastKnownName)
|
||||
.field(lastJoinAt)
|
||||
.field(usingGroupTitleID)
|
||||
.where("uuid = ?", uuid.value)
|
||||
.returningAll(uuid);
|
||||
try (ResultSet rs = updateRow.execute()) {
|
||||
List<PlayerDTO> players = getDTOFromRS(rs);
|
||||
if (players.size() == 0) return null;
|
||||
return players.get(0);
|
||||
if (players.isEmpty()) return null;
|
||||
return players.getFirst();
|
||||
} catch (SQLException e) {
|
||||
DatabaseManager.handleDatabaseError("更新玩家信息失败: ", e, updateRow.toString());
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
private PlayerDTO(Integer id, UUID uuid, String lastKnownName, Long lastJoinAt) {
|
||||
private PlayerDTO(Integer id, UUID uuid, String lastKnownName, Long lastJoinAt, Integer using_group_title_id) {
|
||||
this.id = id;
|
||||
this.uuid = uuid;
|
||||
this.lastKnownName = lastKnownName;
|
||||
this.lastJoinAt = lastJoinAt;
|
||||
this.using_group_title_id = using_group_title_id;
|
||||
}
|
||||
|
||||
private PlayerDTO(UUID uuid, String lastKnownName, Long lastJoinAt) {
|
||||
this(null, uuid, lastKnownName, lastJoinAt);
|
||||
this(null, uuid, lastKnownName, lastJoinAt, -1);
|
||||
}
|
||||
|
||||
public Integer getId() {
|
||||
@ -180,8 +187,19 @@ public class PlayerDTO {
|
||||
this.lastJoinAt = lastJoinAt;
|
||||
}
|
||||
|
||||
public Integer getUsingGroupTitleID() {
|
||||
return using_group_title_id;
|
||||
}
|
||||
|
||||
public void setUsingGroupTitleID(Integer usingGroupTitleID) {
|
||||
this.using_group_title_id = usingGroupTitleID;
|
||||
update(this);
|
||||
Cache.instance.updatePlayerUsingGroupTitle(uuid, usingGroupTitleID);
|
||||
}
|
||||
|
||||
private Integer id;
|
||||
private UUID uuid;
|
||||
private String lastKnownName;
|
||||
private Long lastJoinAt;
|
||||
private Integer using_group_title_id;
|
||||
}
|
@ -2,11 +2,17 @@ package cn.lunadeer.dominion.managers;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.minecraftpluginutils.VaultConnect.VaultConnect;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.configuration.file.FileConfiguration;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
import java.io.File;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public class ConfigManager {
|
||||
public ConfigManager(Dominion plugin) {
|
||||
@ -20,6 +26,7 @@ public class ConfigManager {
|
||||
_plugin.reloadConfig();
|
||||
_file = _plugin.getConfig();
|
||||
_debug = _file.getBoolean("Debug", false);
|
||||
_timer = _file.getBoolean("Timer", false);
|
||||
XLogger.setDebug(_debug);
|
||||
_db_type = _file.getString("Database.Type", "sqlite");
|
||||
_db_host = _file.getString("Database.Host", "localhost");
|
||||
@ -32,43 +39,15 @@ public class ConfigManager {
|
||||
XLogger.err("AutoCreateRadius 不能等于 0,已重置为 10");
|
||||
setAutoCreateRadius(10);
|
||||
}
|
||||
_limit_size_x = _file.getInt("Limit.SizeX", 128);
|
||||
if (_limit_size_x <= 4 && _limit_size_x != -1) {
|
||||
XLogger.err("Limit.SizeX 尺寸不能小于 4,已重置为 128");
|
||||
setLimitSizeX(128);
|
||||
}
|
||||
_limit_size_y = _file.getInt("Limit.SizeY", 64);
|
||||
if (_limit_size_y <= 4 && _limit_size_y != -1) {
|
||||
XLogger.err("Limit.SizeY 尺寸不能小于 4,已重置为 64");
|
||||
setLimitSizeY(64);
|
||||
}
|
||||
_limit_size_z = _file.getInt("Limit.SizeZ", 128);
|
||||
if (_limit_size_z <= 4 && _limit_size_z != -1) {
|
||||
XLogger.err("Limit.SizeZ 尺寸不能小于 4,已重置为 128");
|
||||
setLimitSizeZ(128);
|
||||
}
|
||||
_blue_map = _file.getBoolean("BlueMap", true);
|
||||
_spawn_protection = _file.getInt("Limit.SpawnProtection", 10);
|
||||
_blue_map = _file.getBoolean("BlueMap", false);
|
||||
_dynmap = _file.getBoolean("Dynmap", false);
|
||||
_auto_clean_after_days = _file.getInt("AutoCleanAfterDays", 180);
|
||||
if (_auto_clean_after_days == 0) {
|
||||
XLogger.err("AutoCleanAfterDays 不能等于 0,已重置为 180");
|
||||
setAutoCleanAfterDays(180);
|
||||
}
|
||||
_limit_min_y = _file.getInt("Limit.MinY", -64);
|
||||
_limit_max_y = _file.getInt("Limit.MaxY", 320);
|
||||
if (_limit_min_y >= _limit_max_y) {
|
||||
XLogger.err("Limit.MinY 不能大于或等于 Limit.MaxY,已重置为 -64 320");
|
||||
setLimitMinY(-64);
|
||||
setLimitMaxY(320);
|
||||
}
|
||||
_limit_amount = _file.getInt("Limit.Amount", 10);
|
||||
_limit_depth = _file.getInt("Limit.Depth", 10);
|
||||
_limit_vert = _file.getBoolean("Limit.Vert", false);
|
||||
if (_limit_vert && _limit_size_y <= _limit_max_y - _limit_min_y) {
|
||||
setLimitSizeY(_limit_max_y - _limit_min_y + 1);
|
||||
XLogger.warn("启用 Limit.Vert 时 Limit.SizeY 不能小于 Limit.MaxY - Limit.MinY,已自动调整为 " + (_limit_max_y - _limit_min_y + 1));
|
||||
}
|
||||
_limit_op_bypass = _file.getBoolean("Limit.OpByPass", true);
|
||||
_world_black_list = _file.getStringList("Limit.WorldBlackList");
|
||||
_check_update = _file.getBoolean("CheckUpdate", true);
|
||||
_tp_enable = _file.getBoolean("Teleport.Enable", false);
|
||||
_tp_delay = _file.getInt("Teleport.Delay", 0);
|
||||
@ -79,40 +58,133 @@ public class ConfigManager {
|
||||
setTool("ARROW");
|
||||
}
|
||||
_economy_enable = _file.getBoolean("Economy.Enable", false);
|
||||
_economy_price = (float) _file.getDouble("Economy.Price", 10.0);
|
||||
_economy_only_xz = _file.getBoolean("Economy.OnlyXZ", false);
|
||||
_economy_refund = (float) _file.getDouble("Economy.Refund", 0.85);
|
||||
if (getEconomyEnable()) {
|
||||
new VaultConnect(this._plugin);
|
||||
}
|
||||
_fly_permission_nodes = _file.getStringList("FlyPermissionNodes");
|
||||
_residence_migration = _file.getBoolean("ResidenceMigration", false);
|
||||
_group_title_enable = _file.getBoolean("GroupTitle.Enable", false);
|
||||
_group_title_prefix = _file.getString("GroupTitle.Prefix", "&#ffffff[");
|
||||
_group_title_suffix = _file.getString("GroupTitle.Suffix", "&#ffffff]");
|
||||
|
||||
GroupLimit defaultGroup = new GroupLimit();
|
||||
defaultGroup.setLimitSizeX(_file.getInt("Limit.SizeX", 128));
|
||||
defaultGroup.setLimitSizeY(_file.getInt("Limit.SizeY", 64));
|
||||
defaultGroup.setLimitSizeZ(_file.getInt("Limit.SizeZ", 128));
|
||||
defaultGroup.setLimitMinY(_file.getInt("Limit.MinY", -64));
|
||||
defaultGroup.setLimitMaxY(_file.getInt("Limit.MaxY", 320));
|
||||
defaultGroup.setLimitAmount(_file.getInt("Limit.Amount", 10));
|
||||
defaultGroup.setLimitDepth(_file.getInt("Limit.Depth", 3));
|
||||
defaultGroup.setLimitVert(_file.getBoolean("Limit.Vert", false));
|
||||
defaultGroup.setWorldBlackList(_file.getStringList("Limit.WorldBlackList"));
|
||||
defaultGroup.setPrice(_file.getDouble("Economy.Price", 10.0));
|
||||
defaultGroup.setPriceOnlyXZ(_file.getBoolean("Economy.OnlyXZ", false));
|
||||
defaultGroup.setRefundRatio(_file.getDouble("Economy.Refund", 0.85));
|
||||
limits.put("default", defaultGroup);
|
||||
if (defaultGroup.getLimitSizeX() <= 4 && defaultGroup.getLimitSizeX() != -1) {
|
||||
XLogger.err("Limit.SizeX 尺寸不能小于 4,已重置为 128");
|
||||
setLimitSizeX(128);
|
||||
}
|
||||
if (defaultGroup.getLimitSizeY() <= 4 && defaultGroup.getLimitSizeY() != -1) {
|
||||
XLogger.err("Limit.SizeY 尺寸不能小于 4,已重置为 64");
|
||||
setLimitSizeY(64);
|
||||
}
|
||||
if (defaultGroup.getLimitSizeZ() <= 4 && defaultGroup.getLimitSizeZ() != -1) {
|
||||
XLogger.err("Limit.SizeZ 尺寸不能小于 4,已重置为 128");
|
||||
setLimitSizeZ(128);
|
||||
}
|
||||
if (defaultGroup.getLimitMinY() >= defaultGroup.getLimitMaxY()) {
|
||||
XLogger.err("Limit.MinY 不能大于或等于 Limit.MaxY,已重置为 -64 320");
|
||||
setLimitMinY(-64);
|
||||
setLimitMaxY(320);
|
||||
}
|
||||
if (defaultGroup.getRefundRatio() < 0.0 || defaultGroup.getRefundRatio() > 1.0) {
|
||||
XLogger.err("Economy.Refund 设置不合法,已重置为 0.85");
|
||||
setEconomyRefund(0.85f);
|
||||
}
|
||||
if (defaultGroup.getPrice() < 0.0) {
|
||||
XLogger.err("Economy.Price 设置不合法,已重置为 10.0");
|
||||
setEconomyPrice(10.0f);
|
||||
}
|
||||
if (defaultGroup.getLimitVert() && defaultGroup.getLimitSizeY() <= defaultGroup.getLimitMaxY() - defaultGroup.getLimitMinY()) {
|
||||
XLogger.warn("启用 Limit.Vert 时 Limit.SizeY 不能小于 Limit.MaxY - Limit.MinY,已自动调整为 " + (defaultGroup.getLimitMaxY() - defaultGroup.getLimitMinY() + 1));
|
||||
setLimitSizeY(defaultGroup.getLimitMaxY() - defaultGroup.getLimitMinY() + 1);
|
||||
}
|
||||
if (defaultGroup.getLimitAmount() < 0 && defaultGroup.getLimitAmount() != -1) {
|
||||
XLogger.err("Limit.Amount 设置不合法,已重置为 10");
|
||||
setLimitAmount(10);
|
||||
}
|
||||
if (defaultGroup.getLimitDepth() < 0 && defaultGroup.getLimitDepth() != -1) {
|
||||
XLogger.err("Limit.Depth 设置不合法,已重置为 3");
|
||||
setLimitDepth(3);
|
||||
}
|
||||
|
||||
limits.putAll(GroupLimit.loadGroups(_plugin));
|
||||
|
||||
saveAll(); // 回写文件 防止文件中的数据不完整
|
||||
Flag.loadFromJson();
|
||||
Flag.loadFromJson(); // 加载 Flag 配置
|
||||
}
|
||||
|
||||
public void saveAll() {
|
||||
// 删除旧文件
|
||||
new File(_plugin.getDataFolder(), "config.yml").delete();
|
||||
// 保存新文件
|
||||
_plugin.saveDefaultConfig();
|
||||
// 重新加载
|
||||
_plugin.reloadConfig();
|
||||
_file = _plugin.getConfig();
|
||||
|
||||
// 保存配置
|
||||
_file.set("Database.Type", _db_type);
|
||||
_file.set("Database.Host", _db_host);
|
||||
_file.set("Database.Port", _db_port);
|
||||
_file.set("Database.Name", _db_name);
|
||||
_file.set("Database.User", _db_user);
|
||||
_file.set("Database.Pass", _db_pass);
|
||||
|
||||
_file.set("AutoCreateRadius", _auto_create_radius);
|
||||
_file.set("Limit.SizeX", _limit_size_x);
|
||||
_file.set("Limit.SizeY", _limit_size_y);
|
||||
_file.set("Limit.SizeZ", _limit_size_z);
|
||||
_file.set("BlueMap", _blue_map);
|
||||
_file.set("AutoCleanAfterDays", _auto_clean_after_days);
|
||||
_file.set("Limit.MinY", _limit_min_y);
|
||||
_file.set("Limit.MaxY", _limit_max_y);
|
||||
_file.set("Limit.Amount", _limit_amount);
|
||||
_file.set("Limit.Depth", _limit_depth);
|
||||
_file.set("Limit.Vert", _limit_vert);
|
||||
|
||||
_file.set("Limit.SpawnProtection", _spawn_protection);
|
||||
_file.set("Limit.MinY", limits.get("default").getLimitMinY());
|
||||
_file.set("Limit.MaxY", limits.get("default").getLimitMaxY());
|
||||
_file.set("Limit.SizeX", limits.get("default").getLimitSizeX());
|
||||
_file.set("Limit.SizeY", limits.get("default").getLimitSizeY());
|
||||
_file.set("Limit.SizeZ", limits.get("default").getLimitSizeZ());
|
||||
_file.set("Limit.Amount", limits.get("default").getLimitAmount());
|
||||
_file.set("Limit.Depth", limits.get("default").getLimitDepth());
|
||||
_file.set("Limit.Vert", limits.get("default").getLimitVert());
|
||||
_file.set("Limit.WorldBlackList", limits.get("default").getWorldBlackList());
|
||||
_file.set("Limit.OpByPass", _limit_op_bypass);
|
||||
_file.set("Limit.WorldBlackList", _world_black_list);
|
||||
_file.set("CheckUpdate", _check_update);
|
||||
|
||||
_file.set("Teleport.Enable", _tp_enable);
|
||||
_file.set("Teleport.Delay", _tp_delay);
|
||||
_file.set("Teleport.CoolDown", _tp_cool_down);
|
||||
|
||||
_file.set("AutoCleanAfterDays", _auto_clean_after_days);
|
||||
|
||||
_file.set("Tool", _tool);
|
||||
|
||||
_file.set("Economy.Enable", _economy_enable);
|
||||
_file.set("Economy.Price", _economy_price);
|
||||
_file.set("Economy.OnlyXZ", _economy_only_xz);
|
||||
_file.set("Economy.Refund", _economy_refund);
|
||||
_file.set("Economy.Price", limits.get("default").getPrice());
|
||||
_file.set("Economy.OnlyXZ", limits.get("default").getPriceOnlyXZ());
|
||||
_file.set("Economy.Refund", limits.get("default").getRefundRatio());
|
||||
|
||||
_file.set("FlyPermissionNodes", _fly_permission_nodes);
|
||||
|
||||
_file.set("ResidenceMigration", _residence_migration);
|
||||
|
||||
_file.set("GroupTitle.Enable", _group_title_enable);
|
||||
_file.set("GroupTitle.Prefix", _group_title_prefix);
|
||||
_file.set("GroupTitle.Suffix", _group_title_suffix);
|
||||
|
||||
_file.set("BlueMap", _blue_map);
|
||||
_file.set("Dynmap", _dynmap);
|
||||
|
||||
_file.set("CheckUpdate", _check_update);
|
||||
|
||||
_file.set("Debug", _debug);
|
||||
_file.set("Timer", _timer);
|
||||
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
@ -127,6 +199,10 @@ public class ConfigManager {
|
||||
XLogger.setDebug(debug);
|
||||
}
|
||||
|
||||
public Boolean TimerEnabled() {
|
||||
return _timer;
|
||||
}
|
||||
|
||||
public String getDbType() {
|
||||
return _db_type;
|
||||
}
|
||||
@ -172,32 +248,32 @@ public class ConfigManager {
|
||||
return _db_pass;
|
||||
}
|
||||
|
||||
public Integer getLimitSizeX() {
|
||||
return _limit_size_x;
|
||||
public Integer getLimitSizeX(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitSizeX();
|
||||
}
|
||||
|
||||
public void setLimitSizeX(Integer max_x) {
|
||||
_limit_size_x = max_x;
|
||||
limits.get("default").setLimitSizeX(max_x);
|
||||
_file.set("Limit.SizeX", max_x);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitSizeY() {
|
||||
return _limit_size_y;
|
||||
public Integer getLimitSizeY(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitSizeY();
|
||||
}
|
||||
|
||||
public void setLimitSizeY(Integer max_y) {
|
||||
_limit_size_y = max_y;
|
||||
limits.get("default").setLimitSizeY(max_y);
|
||||
_file.set("Limit.SizeY", max_y);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitSizeZ() {
|
||||
return _limit_size_z;
|
||||
public Integer getLimitSizeZ(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitSizeZ();
|
||||
}
|
||||
|
||||
public void setLimitSizeZ(Integer max_z) {
|
||||
_limit_size_z = max_z;
|
||||
limits.get("default").setLimitSizeZ(max_z);
|
||||
_file.set("Limit.SizeZ", max_z);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
@ -216,10 +292,8 @@ public class ConfigManager {
|
||||
return _blue_map;
|
||||
}
|
||||
|
||||
public void setBlueMap(Boolean blue_map) {
|
||||
_blue_map = blue_map;
|
||||
_file.set("BlueMap", blue_map);
|
||||
_plugin.saveConfig();
|
||||
public Boolean getDynmap() {
|
||||
return _dynmap;
|
||||
}
|
||||
|
||||
public Integer getAutoCleanAfterDays() {
|
||||
@ -232,58 +306,58 @@ public class ConfigManager {
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitMinY() {
|
||||
return _limit_min_y;
|
||||
public Integer getLimitMinY(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitMinY();
|
||||
}
|
||||
|
||||
public void setLimitMinY(Integer limit_bottom) {
|
||||
_limit_min_y = limit_bottom;
|
||||
limits.get("default").setLimitMinY(limit_bottom);
|
||||
_file.set("Limit.MinY", limit_bottom);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitMaxY() {
|
||||
return _limit_max_y;
|
||||
public Integer getLimitMaxY(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitMaxY();
|
||||
}
|
||||
|
||||
public void setLimitMaxY(Integer limit_top) {
|
||||
_limit_max_y = limit_top;
|
||||
limits.get("default").setLimitMaxY(limit_top);
|
||||
_file.set("Limit.MaxY", limit_top);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitAmount() {
|
||||
return _limit_amount;
|
||||
public Integer getLimitAmount(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitAmount();
|
||||
}
|
||||
|
||||
public void setLimitAmount(Integer limit_amount) {
|
||||
_limit_amount = limit_amount;
|
||||
limits.get("default").setLimitAmount(limit_amount);
|
||||
_file.set("Limit.Amount", limit_amount);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getLimitDepth() {
|
||||
return _limit_depth;
|
||||
public Integer getLimitDepth(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitDepth();
|
||||
}
|
||||
|
||||
public void setLimitDepth(Integer limit_depth) {
|
||||
_limit_depth = limit_depth;
|
||||
limits.get("default").setLimitDepth(limit_depth);
|
||||
_file.set("Limit.Depth", limit_depth);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Boolean getLimitVert() {
|
||||
return _limit_vert;
|
||||
public Boolean getLimitVert(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getLimitVert();
|
||||
}
|
||||
|
||||
public void setLimitVert(Boolean limit_vert) {
|
||||
_limit_vert = limit_vert;
|
||||
limits.get("default").setLimitVert(limit_vert);
|
||||
_file.set("Limit.Vert", limit_vert);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public List<String> getWorldBlackList() {
|
||||
return _world_black_list;
|
||||
public List<String> getWorldBlackList(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getWorldBlackList();
|
||||
}
|
||||
|
||||
public Boolean getLimitOpBypass() {
|
||||
@ -350,32 +424,32 @@ public class ConfigManager {
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Float getEconomyPrice() {
|
||||
return _economy_price;
|
||||
public Float getEconomyPrice(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getPrice().floatValue();
|
||||
}
|
||||
|
||||
public void setEconomyPrice(Float economy_price) {
|
||||
_economy_price = economy_price;
|
||||
limits.get("default").setPrice((double) economy_price);
|
||||
_file.set("Economy.Price", economy_price);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Boolean getEconomyOnlyXZ() {
|
||||
return _economy_only_xz;
|
||||
public Boolean getEconomyOnlyXZ(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getPriceOnlyXZ();
|
||||
}
|
||||
|
||||
public void setEconomyOnlyXZ(Boolean economy_only_xz) {
|
||||
_economy_only_xz = economy_only_xz;
|
||||
limits.get("default").setPriceOnlyXZ(economy_only_xz);
|
||||
_file.set("Economy.OnlyXZ", economy_only_xz);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Float getEconomyRefund() {
|
||||
return _economy_refund;
|
||||
public Float getEconomyRefund(Player player) {
|
||||
return limits.get(getPlayerGroup(player)).getRefundRatio().floatValue();
|
||||
}
|
||||
|
||||
public void setEconomyRefund(Float economy_refund) {
|
||||
_economy_refund = economy_refund;
|
||||
limits.get("default").setRefundRatio((double) economy_refund);
|
||||
_file.set("Economy.Refund", economy_refund);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
@ -400,9 +474,50 @@ public class ConfigManager {
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Integer getSpawnProtection() {
|
||||
return _spawn_protection;
|
||||
}
|
||||
|
||||
public void setSpawnProtection(Integer spawn_protection) {
|
||||
_spawn_protection = spawn_protection;
|
||||
_file.set("Limit.SpawnProtection", spawn_protection);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public Boolean getGroupTitleEnable() {
|
||||
return _group_title_enable;
|
||||
}
|
||||
|
||||
public void setGroupTitleEnable(Boolean group_title_enable) {
|
||||
_group_title_enable = group_title_enable;
|
||||
_file.set("GroupTitle.Enable", group_title_enable);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public String getGroupTitlePrefix() {
|
||||
return _group_title_prefix;
|
||||
}
|
||||
|
||||
public void setGroupTitlePrefix(String group_title_prefix) {
|
||||
_group_title_prefix = group_title_prefix;
|
||||
_file.set("GroupTitle.Prefix", group_title_prefix);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
public String getGroupTitleSuffix() {
|
||||
return _group_title_suffix;
|
||||
}
|
||||
|
||||
public void setGroupTitleSuffix(String group_title_suffix) {
|
||||
_group_title_suffix = group_title_suffix;
|
||||
_file.set("GroupTitle.Suffix", group_title_suffix);
|
||||
_plugin.saveConfig();
|
||||
}
|
||||
|
||||
private final Dominion _plugin;
|
||||
private FileConfiguration _file;
|
||||
private Boolean _debug;
|
||||
private Boolean _timer;
|
||||
|
||||
private String _db_type;
|
||||
private String _db_host;
|
||||
@ -413,19 +528,12 @@ public class ConfigManager {
|
||||
|
||||
private Integer _auto_create_radius;
|
||||
|
||||
private Integer _limit_size_x;
|
||||
private Integer _limit_size_y;
|
||||
private Integer _limit_size_z;
|
||||
private Boolean _limit_op_bypass;
|
||||
|
||||
private Boolean _blue_map;
|
||||
private Boolean _dynmap;
|
||||
private Integer _auto_clean_after_days;
|
||||
private Integer _limit_min_y;
|
||||
private Integer _limit_max_y;
|
||||
private Integer _limit_amount;
|
||||
private Integer _limit_depth;
|
||||
private Boolean _limit_vert;
|
||||
private List<String> _world_black_list;
|
||||
|
||||
private Boolean _check_update;
|
||||
|
||||
private Boolean _tp_enable;
|
||||
@ -434,9 +542,29 @@ public class ConfigManager {
|
||||
private String _tool;
|
||||
|
||||
private Boolean _economy_enable;
|
||||
private Float _economy_price;
|
||||
private Boolean _economy_only_xz;
|
||||
private Float _economy_refund;
|
||||
|
||||
private List<String> _fly_permission_nodes;
|
||||
private Boolean _residence_migration;
|
||||
private Integer _spawn_protection;
|
||||
|
||||
private Boolean _group_title_enable;
|
||||
private String _group_title_prefix;
|
||||
private String _group_title_suffix;
|
||||
|
||||
private final Map<String, GroupLimit> limits = new HashMap<>();
|
||||
|
||||
private String getPlayerGroup(@Nullable Player player) {
|
||||
if (player == null) {
|
||||
return "default";
|
||||
}
|
||||
for (String group : limits.keySet()) {
|
||||
if (group.equals("default")) {
|
||||
continue;
|
||||
}
|
||||
if (player.hasPermission("group." + group)) {
|
||||
return group;
|
||||
}
|
||||
}
|
||||
return "default";
|
||||
}
|
||||
}
|
@ -1,12 +1,16 @@
|
||||
package cn.lunadeer.dominion.managers;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.Field;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.FieldType;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.TableColumn;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.*;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.AddColumn;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.CreateTable;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.InsertRow;
|
||||
import cn.lunadeer.minecraftpluginutils.databse.syntax.RemoveColumn;
|
||||
import org.bukkit.World;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.util.List;
|
||||
|
||||
public class DatabaseTables {
|
||||
public static void migrate() {
|
||||
@ -58,23 +62,35 @@ public class DatabaseTables {
|
||||
.foreignKey(dominion_parent_dom_id_fk);
|
||||
dominion.execute();
|
||||
|
||||
for (Flag flag : Flag.getAllDominionFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("dominion").ifNotExists().execute();
|
||||
}
|
||||
|
||||
// player privilege
|
||||
TableColumn player_privilege_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn player_privilege_player_uuid = new TableColumn("player_uuid", FieldType.STRING, false, false, true, false, "''");
|
||||
TableColumn player_privilege_dom_id = new TableColumn("dom_id", FieldType.INT, false, false, true, false, -1);
|
||||
TableColumn player_privilege_admin = new TableColumn("admin", FieldType.BOOLEAN, false, false, true, false, false);
|
||||
CreateTable.ForeignKey player_privilege_player_uuid_fk = new CreateTable.ForeignKey(player_privilege_player_uuid, "player_name", player_name_uuid, true);
|
||||
CreateTable.ForeignKey player_privilege_dom_id_fk = new CreateTable.ForeignKey(player_privilege_dom_id, "dominion", dominion_id, true);
|
||||
CreateTable player_privilege = new CreateTable().ifNotExists();
|
||||
player_privilege.table("player_privilege")
|
||||
.field(player_privilege_id)
|
||||
.field(player_privilege_player_uuid)
|
||||
.field(player_privilege_dom_id)
|
||||
.field(player_privilege_admin)
|
||||
.foreignKey(player_privilege_player_uuid_fk)
|
||||
.foreignKey(player_privilege_dom_id_fk)
|
||||
.unique(player_privilege_player_uuid, player_privilege_dom_id);
|
||||
player_privilege.execute();
|
||||
if (!Common.IsTableExist("dominion_member")) {
|
||||
TableColumn player_privilege_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn player_privilege_player_uuid = new TableColumn("player_uuid", FieldType.STRING, false, false, true, false, "''");
|
||||
TableColumn player_privilege_dom_id = new TableColumn("dom_id", FieldType.INT, false, false, true, false, -1);
|
||||
TableColumn player_privilege_admin = new TableColumn("admin", FieldType.BOOLEAN, false, false, true, false, false);
|
||||
CreateTable.ForeignKey player_privilege_player_uuid_fk = new CreateTable.ForeignKey(player_privilege_player_uuid, "player_name", player_name_uuid, true);
|
||||
CreateTable.ForeignKey player_privilege_dom_id_fk = new CreateTable.ForeignKey(player_privilege_dom_id, "dominion", dominion_id, true);
|
||||
CreateTable player_privilege = new CreateTable().ifNotExists();
|
||||
player_privilege.table("player_privilege")
|
||||
.field(player_privilege_id)
|
||||
.field(player_privilege_player_uuid)
|
||||
.field(player_privilege_dom_id)
|
||||
.field(player_privilege_admin)
|
||||
.foreignKey(player_privilege_player_uuid_fk)
|
||||
.foreignKey(player_privilege_dom_id_fk)
|
||||
.unique(player_privilege_player_uuid, player_privilege_dom_id);
|
||||
player_privilege.execute();
|
||||
|
||||
for (Flag flag : Flag.getAllPrivilegeFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("player_privilege").ifNotExists().execute();
|
||||
}
|
||||
}
|
||||
|
||||
// server root player name
|
||||
Field server_player_name_id_field = new Field("id", -1);
|
||||
@ -116,21 +132,11 @@ public class DatabaseTables {
|
||||
.field(server_dom_leave_message_field);
|
||||
insert_server_dom.execute();
|
||||
|
||||
for (Flag flag : Flag.getAllDominionFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("dominion").ifNotExists().execute();
|
||||
}
|
||||
|
||||
for (Flag flag : Flag.getAllPrivilegeFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("player_privilege").ifNotExists().execute();
|
||||
}
|
||||
|
||||
// 1.18.0
|
||||
// 1.18.0 dominion add tp_location
|
||||
TableColumn dominion_tp_location = new TableColumn("tp_location", FieldType.STRING, false, false, true, false, "'default'");
|
||||
new AddColumn(dominion_tp_location).table("dominion").ifNotExists().execute();
|
||||
|
||||
// 1.31.0
|
||||
// 1.31.0 add privilege_template
|
||||
TableColumn privilege_template_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn privilege_template_creator = new TableColumn("creator", FieldType.STRING, false, false, true, false, "''");
|
||||
TableColumn privilege_template_name = new TableColumn("name", FieldType.STRING, false, false, true, false, "'未命名'");
|
||||
@ -152,31 +158,106 @@ public class DatabaseTables {
|
||||
new AddColumn(column).table("privilege_template").ifNotExists().execute();
|
||||
}
|
||||
|
||||
// 1.31.6
|
||||
// 1.31.6 dominion add blue-map tile color
|
||||
TableColumn dominion_color = new TableColumn("color", FieldType.STRING, false, false, true, false, "'#00BFFF'");
|
||||
new AddColumn(dominion_color).table("dominion").ifNotExists().execute();
|
||||
|
||||
// 1.34.0
|
||||
TableColumn player_privilege_group_id = new TableColumn("group_id", FieldType.INT, false, false, true, false, -1);
|
||||
new AddColumn(player_privilege_group_id).table("player_privilege").ifNotExists().execute();
|
||||
// 1.34.0 add dominion_group
|
||||
if (!Common.IsTableExist("dominion_member")) {
|
||||
TableColumn player_privilege_group_id = new TableColumn("group_id", FieldType.INT, false, false, true, false, -1);
|
||||
new AddColumn(player_privilege_group_id).table("player_privilege").ifNotExists().execute();
|
||||
}
|
||||
|
||||
TableColumn group_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn group_dom_id = new TableColumn("dom_id", FieldType.INT, false, false, true, false, -1);
|
||||
TableColumn group_name = new TableColumn("name", FieldType.STRING, false, false, true, false, "'未命名'");
|
||||
TableColumn group_admin = new TableColumn("admin", FieldType.BOOLEAN, false, false, true, false, false);
|
||||
CreateTable.ForeignKey group_dom_id_fk = new CreateTable.ForeignKey(group_dom_id, "dominion", dominion_id, true);
|
||||
TableColumn dominion_group_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn dominion_group_dom_id = new TableColumn("dom_id", FieldType.INT, false, false, true, false, -1);
|
||||
TableColumn dominion_group_name = new TableColumn("name", FieldType.STRING, false, false, true, false, "'未命名'");
|
||||
TableColumn dominion_group_admin = new TableColumn("admin", FieldType.BOOLEAN, false, false, true, false, false);
|
||||
CreateTable.ForeignKey group_dom_id_fk = new CreateTable.ForeignKey(dominion_group_dom_id, "dominion", dominion_id, true);
|
||||
CreateTable group = new CreateTable().ifNotExists();
|
||||
group.table("dominion_group")
|
||||
.field(group_id)
|
||||
.field(group_dom_id)
|
||||
.field(group_name)
|
||||
.field(group_admin)
|
||||
.field(dominion_group_id)
|
||||
.field(dominion_group_dom_id)
|
||||
.field(dominion_group_name)
|
||||
.field(dominion_group_admin)
|
||||
.foreignKey(group_dom_id_fk)
|
||||
.unique(group_dom_id, group_name);
|
||||
.unique(dominion_group_dom_id, dominion_group_name);
|
||||
group.execute();
|
||||
for (Flag flag : Flag.getAllPrivilegeFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("dominion_group").ifNotExists().execute();
|
||||
}
|
||||
|
||||
// 1.35.0 migrate player_privilege -> dominion_member
|
||||
TableColumn dominion_member_id = new TableColumn("id", FieldType.INT, true, true, true, true, 0);
|
||||
TableColumn dominion_member_player_uuid = new TableColumn("player_uuid", FieldType.STRING, false, false, true, false, "''");
|
||||
TableColumn dominion_member_dom_id = new TableColumn("dom_id", FieldType.INT, false, false, true, false, -1);
|
||||
TableColumn dominion_member_admin = new TableColumn("admin", FieldType.BOOLEAN, false, false, true, false, false);
|
||||
TableColumn dominion_member_group_id = new TableColumn("group_id", FieldType.INT, false, false, true, false, -1);
|
||||
CreateTable.ForeignKey dominion_member_player_uuid_fk = new CreateTable.ForeignKey(dominion_member_player_uuid, "player_name", player_name_uuid, true);
|
||||
CreateTable.ForeignKey dominion_member_dom_id_fk = new CreateTable.ForeignKey(dominion_member_dom_id, "dominion", dominion_id, true);
|
||||
CreateTable dominion_member = new CreateTable().ifNotExists();
|
||||
dominion_member.table("dominion_member")
|
||||
.field(dominion_member_id)
|
||||
.field(dominion_member_player_uuid)
|
||||
.field(dominion_member_dom_id)
|
||||
.field(dominion_member_admin)
|
||||
.field(dominion_member_group_id)
|
||||
.foreignKey(dominion_member_player_uuid_fk)
|
||||
.foreignKey(dominion_member_dom_id_fk)
|
||||
.unique(dominion_member_player_uuid, dominion_member_dom_id);
|
||||
dominion_member.execute();
|
||||
for (Flag flag : Flag.getAllPrivilegeFlags()) {
|
||||
TableColumn column = new TableColumn(flag.getFlagName(), FieldType.BOOLEAN, false, false, true, false, flag.getDefaultValue());
|
||||
new AddColumn(column).table("dominion_member").ifNotExists().execute();
|
||||
}
|
||||
if (Common.IsTableExist("player_privilege")) {
|
||||
// migrate from player_privilege to dominion_member
|
||||
String sql = "SELECT * FROM player_privilege;";
|
||||
try (ResultSet rs = DatabaseManager.instance.query(sql)) {
|
||||
while (rs.next()) {
|
||||
String player_uuid = rs.getString("player_uuid");
|
||||
int dom_id = rs.getInt("dom_id");
|
||||
boolean admin = rs.getBoolean("admin");
|
||||
int group_id = rs.getInt("group_id");
|
||||
InsertRow insert = new InsertRow().table("dominion_member")
|
||||
.field(new Field("player_uuid", player_uuid))
|
||||
.field(new Field("dom_id", dom_id))
|
||||
.field(new Field("group_id", group_id))
|
||||
.field(new Field("admin", admin));
|
||||
for (Flag flag : Flag.getAllPrivilegeFlags()) {
|
||||
insert.field(new Field(flag.getFlagName(), rs.getBoolean(flag.getFlagName())));
|
||||
}
|
||||
insert.execute();
|
||||
}
|
||||
sql = "DROP TABLE player_privilege;";
|
||||
DatabaseManager.instance.query(sql);
|
||||
} catch (Exception e) {
|
||||
DatabaseManager.handleDatabaseError("迁移 player_privilege 到 dominion_member 失败", e, sql);
|
||||
}
|
||||
}
|
||||
|
||||
// 2.1.0-beta add group name colored
|
||||
if (!Common.IsFieldExist("dominion_group", "name_colored")) {
|
||||
TableColumn dominion_group_name_colored = new TableColumn("name_colored", FieldType.STRING, false, false, true, false, "'未命名'");
|
||||
new AddColumn(dominion_group_name_colored).table("dominion_group").ifNotExists().execute();
|
||||
String copy_sql = "UPDATE dominion_group SET name_colored = name;";
|
||||
DatabaseManager.instance.query(copy_sql);
|
||||
|
||||
TableColumn player_name_using_group_title_id = new TableColumn("using_group_title_id", FieldType.INT, false, false, true, false, -1);
|
||||
new AddColumn(player_name_using_group_title_id).table("player_name").ifNotExists().execute();
|
||||
}
|
||||
|
||||
// 2.3.0 change world name to world uid
|
||||
if (!Common.IsFieldExist("dominion", "world_uid")) {
|
||||
TableColumn dominion_world_uid = new TableColumn("world_uid", FieldType.STRING, false, false, true, false, "'00000000-0000-0000-0000-000000000000'");
|
||||
new AddColumn(dominion_world_uid).table("dominion").ifNotExists().execute();
|
||||
List<World> worlds = Dominion.instance.getServer().getWorlds();
|
||||
for (World world : worlds) {
|
||||
String sql = String.format("UPDATE dominion SET world_uid = '%s' WHERE world = '%s';", world.getUID().toString(), world.getName());
|
||||
DatabaseManager.instance.query(sql);
|
||||
}
|
||||
DatabaseManager.instance.query("UPDATE dominion SET world_uid = '00000000-0000-0000-0000-000000000000' WHERE world = 'all';");
|
||||
new RemoveColumn("world").table("dominion").IfExists().execute();
|
||||
}
|
||||
}
|
||||
}
|
241
core/src/main/java/cn/lunadeer/dominion/managers/GroupLimit.java
Normal file
241
core/src/main/java/cn/lunadeer/dominion/managers/GroupLimit.java
Normal file
@ -0,0 +1,241 @@
|
||||
package cn.lunadeer.dominion.managers;
|
||||
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.configuration.file.YamlConfiguration;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
|
||||
import java.io.File;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public class GroupLimit {
|
||||
private final YamlConfiguration config;
|
||||
private final File file_path;
|
||||
private Integer min_y;
|
||||
private Integer max_y;
|
||||
private Integer size_x;
|
||||
private Integer size_y;
|
||||
private Integer size_z;
|
||||
private Integer amount;
|
||||
private Integer depth;
|
||||
private Boolean vert;
|
||||
private List<String> world_black_list;
|
||||
private Double price;
|
||||
private Boolean only_xz;
|
||||
private Double refund;
|
||||
|
||||
public GroupLimit() {
|
||||
this.file_path = null;
|
||||
this.config = new YamlConfiguration();
|
||||
}
|
||||
|
||||
public GroupLimit(File filePath) {
|
||||
this.file_path = filePath;
|
||||
config = YamlConfiguration.loadConfiguration(this.file_path);
|
||||
setLimitMinY(config.getInt("MinY", -64));
|
||||
setLimitMaxY(config.getInt("MaxY", 320));
|
||||
if (getLimitMinY() >= getLimitMaxY()) {
|
||||
XLogger.err("权限组 %s 的 MinY 不能大于等于 MaxY,已重置为 -64 和 320", this.file_path.getName());
|
||||
setLimitMinY(-64);
|
||||
setLimitMaxY(320);
|
||||
}
|
||||
setLimitSizeX(config.getInt("SizeX", 128));
|
||||
if (getLimitSizeX() <= 4 && getLimitSizeX() != -1) {
|
||||
XLogger.err("权限组 %s 的 SizeX 设置过小,已重置为 128", this.file_path.getName());
|
||||
setLimitSizeX(128);
|
||||
}
|
||||
setLimitSizeY(config.getInt("SizeY", 64));
|
||||
if (getLimitSizeY() <= 4 && getLimitSizeY() != -1) {
|
||||
XLogger.err("权限组 %s 的 SizeY 设置过小,已重置为 64", this.file_path.getName());
|
||||
setLimitSizeY(64);
|
||||
}
|
||||
setLimitSizeZ(config.getInt("SizeZ", 128));
|
||||
if (getLimitSizeZ() <= 4 && getLimitSizeZ() != -1) {
|
||||
XLogger.err("权限组 %s 的 SizeZ 设置过小,已重置为 128", this.file_path.getName());
|
||||
setLimitSizeZ(128);
|
||||
}
|
||||
setLimitAmount(config.getInt("Amount", 10));
|
||||
if (getLimitAmount() <= 0 && getLimitAmount() != -1) {
|
||||
XLogger.err("权限组 %s 的 Amount 设置不合法,已重置为 10", this.file_path.getName());
|
||||
setLimitAmount(10);
|
||||
}
|
||||
setLimitDepth(config.getInt("Depth", 3));
|
||||
if (getLimitDepth() <= 0 && getLimitDepth() != -1) {
|
||||
XLogger.err("权限组 %s 的 Depth 设置不合法,已重置为 3", this.file_path.getName());
|
||||
setLimitDepth(3);
|
||||
}
|
||||
setLimitVert(config.getBoolean("Vert", false));
|
||||
setWorldBlackList(config.getStringList("WorldBlackList"));
|
||||
setPrice(config.getDouble("Price", 10.0));
|
||||
if (getPrice() < 0.0) {
|
||||
XLogger.err("权限组 %s 的 Price 设置不合法,已重置为 10.0", this.file_path.getName());
|
||||
setPrice(10.0);
|
||||
}
|
||||
setPriceOnlyXZ(config.getBoolean("OnlyXZ", false));
|
||||
setRefundRatio(config.getDouble("Refund", 0.85));
|
||||
if (getRefundRatio() < 0.0 || getRefundRatio() > 1.0) {
|
||||
XLogger.err("权限组 %s 的 Refund 设置不合法,已重置为 0.85", this.file_path.getName());
|
||||
setRefundRatio(0.85);
|
||||
}
|
||||
save(); // 保存一次,确保文件中的数据是合法的
|
||||
}
|
||||
|
||||
public Integer getLimitMinY() {
|
||||
return min_y;
|
||||
}
|
||||
|
||||
public Integer getLimitMaxY() {
|
||||
return max_y;
|
||||
}
|
||||
|
||||
public Integer getLimitSizeX() {
|
||||
return size_x;
|
||||
}
|
||||
|
||||
public Integer getLimitSizeY() {
|
||||
return size_y;
|
||||
}
|
||||
|
||||
public Integer getLimitSizeZ() {
|
||||
return size_z;
|
||||
}
|
||||
|
||||
public Integer getLimitAmount() {
|
||||
return amount;
|
||||
}
|
||||
|
||||
public Integer getLimitDepth() {
|
||||
return depth;
|
||||
}
|
||||
|
||||
public Boolean getLimitVert() {
|
||||
return vert;
|
||||
}
|
||||
|
||||
public List<String> getWorldBlackList() {
|
||||
return world_black_list;
|
||||
}
|
||||
|
||||
public Double getPrice() {
|
||||
return price;
|
||||
}
|
||||
|
||||
public Boolean getPriceOnlyXZ() {
|
||||
return only_xz;
|
||||
}
|
||||
|
||||
public Double getRefundRatio() {
|
||||
return refund;
|
||||
}
|
||||
|
||||
|
||||
public void setLimitMinY(Integer min_y) {
|
||||
this.min_y = min_y;
|
||||
this.config.set("MinY", min_y);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitMaxY(Integer max_y) {
|
||||
this.max_y = max_y;
|
||||
this.config.set("MaxY", max_y);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitSizeX(Integer size_x) {
|
||||
this.size_x = size_x;
|
||||
this.config.set("SizeX", size_x);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitSizeY(Integer size_y) {
|
||||
this.size_y = size_y;
|
||||
this.config.set("SizeY", size_y);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitSizeZ(Integer size_z) {
|
||||
this.size_z = size_z;
|
||||
this.config.set("SizeZ", size_z);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitAmount(Integer amount) {
|
||||
this.amount = amount;
|
||||
this.config.set("Amount", amount);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitDepth(Integer depth) {
|
||||
this.depth = depth;
|
||||
this.config.set("Depth", depth);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setLimitVert(Boolean vert) {
|
||||
this.vert = vert;
|
||||
this.config.set("Vert", vert);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setWorldBlackList(List<String> world_black_list) {
|
||||
this.world_black_list = world_black_list;
|
||||
this.config.set("WorldBlackList", world_black_list);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setPrice(Double price) {
|
||||
this.price = price;
|
||||
this.config.set("Price", price);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setPriceOnlyXZ(Boolean only_xz) {
|
||||
this.only_xz = only_xz;
|
||||
this.config.set("OnlyXZ", only_xz);
|
||||
this.save();
|
||||
}
|
||||
|
||||
public void setRefundRatio(Double refund) {
|
||||
this.refund = refund;
|
||||
this.config.set("Refund", refund);
|
||||
this.save();
|
||||
}
|
||||
|
||||
private void save() {
|
||||
if (file_path == null) {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
config.save(file_path);
|
||||
} catch (Exception e) {
|
||||
XLogger.err("Failed to save group limit file: " + file_path.getName());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static Map<String, GroupLimit> loadGroups(JavaPlugin plugin) {
|
||||
Map<String, GroupLimit> groups = new HashMap<>();
|
||||
File root = plugin.getDataFolder();
|
||||
File groupsDir = new File(root, "groups");
|
||||
if (!groupsDir.exists()) {
|
||||
// 创建文件夹 并且从jar中复制文件
|
||||
plugin.saveResource("groups/sponsor.yml", true);
|
||||
}
|
||||
File[] files = groupsDir.listFiles();
|
||||
if (files == null) {
|
||||
return groups;
|
||||
}
|
||||
for (File file : files) {
|
||||
String name = file.getName();
|
||||
if (!name.endsWith(".yml")) {
|
||||
continue;
|
||||
}
|
||||
String groupName = name.substring(0, name.length() - 4);
|
||||
GroupLimit group = new GroupLimit(file);
|
||||
groups.put(groupName, group);
|
||||
}
|
||||
XLogger.info("共加载了 %d 个领地组。", groups.size());
|
||||
return groups;
|
||||
}
|
||||
}
|
@ -0,0 +1,51 @@
|
||||
package cn.lunadeer.dominion.managers;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
public class PlaceHolderApi extends PlaceholderExpansion {
|
||||
|
||||
private final JavaPlugin plugin;
|
||||
|
||||
public static PlaceHolderApi instance;
|
||||
|
||||
public PlaceHolderApi(JavaPlugin plugin) {
|
||||
this.plugin = plugin;
|
||||
this.register();
|
||||
instance = this;
|
||||
XLogger.info("成功注册 PlaceholderAPI 扩展");
|
||||
}
|
||||
|
||||
@Override
|
||||
public String onPlaceholderRequest(Player bukkitPlayer, @NotNull String params) {
|
||||
if (params.equalsIgnoreCase("group_title")) {
|
||||
GroupDTO group = Cache.instance.getPlayerUsingGroupTitle(bukkitPlayer.getUniqueId());
|
||||
if (group == null) {
|
||||
return "";
|
||||
}
|
||||
return group.getNameColoredBukkit();
|
||||
}
|
||||
return null; //
|
||||
}
|
||||
|
||||
@Override
|
||||
public @NotNull String getIdentifier() {
|
||||
return "dominion";
|
||||
}
|
||||
|
||||
@Override
|
||||
public @NotNull String getAuthor() {
|
||||
return "zhangyuheng";
|
||||
}
|
||||
|
||||
@Override
|
||||
public @NotNull String getVersion() {
|
||||
return plugin.getPluginMeta().getVersion();
|
||||
}
|
||||
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
package cn.lunadeer.dominion.tuis;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.DominionNode;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Line;
|
||||
@ -10,9 +10,9 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.notOp;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.notOp;
|
||||
import static cn.lunadeer.dominion.tuis.dominion.DominionList.BuildTreeLines;
|
||||
|
||||
public class AllDominion {
|
||||
@ -23,7 +23,7 @@ public class AllDominion {
|
||||
if (notOp(player)) return;
|
||||
int page = getPage(args, 1);
|
||||
|
||||
List<DominionNode> allDominions = Cache.instance.getAllDominionTree();
|
||||
List<DominionNode> allDominions = DominionNode.BuildNodeTree(-1, DominionDTO.selectAll());
|
||||
|
||||
ListView view = ListView.create(10, "/dominion all_dominion");
|
||||
|
@ -9,7 +9,7 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class Menu {
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
@ -30,12 +30,15 @@ public class Menu {
|
||||
Line list = Line.create()
|
||||
.append(Button.create("我的领地").setExecuteCommand("/dominion list").build())
|
||||
.append("查看我的领地");
|
||||
Line title = Line.create()
|
||||
.append(Button.create("称号列表").setExecuteCommand("/dominion title_list").build())
|
||||
.append("查看/使用权限组称号");
|
||||
Line template = Line.create()
|
||||
.append(Button.create("模板列表").setExecuteCommand("/dominion template list").build())
|
||||
.append("成员权限模板列表");
|
||||
Line help = Line.create()
|
||||
.append(Button.create("指令帮助").setExecuteCommand("/dominion help").build())
|
||||
.append("查看指令帮助");
|
||||
// Line help = Line.create()
|
||||
// .append(Button.create("指令帮助").setExecuteCommand("/dominion help").build())
|
||||
// .append("查看指令帮助");
|
||||
Line link = Line.create()
|
||||
.append(Button.create("使用文档").setOpenURL("https://ssl.lunadeer.cn:14448/doc/23/").build())
|
||||
.append("在浏览器中打开使用文档");
|
||||
@ -46,7 +49,7 @@ public class Menu {
|
||||
.append(Button.create("所有领地").setExecuteCommand("/dominion all_dominion").build())
|
||||
.append("查看所有领地");
|
||||
Line config = Line.create()
|
||||
.append(Button.create("系统配置").setExecuteCommand("/dominion config").build())
|
||||
.append(Button.create("系统配置").setExecuteCommand("/dominion sys_config").build())
|
||||
.append("查看/修改系统配置");
|
||||
Line reload_cache = Line.create()
|
||||
.append(Button.create("重载缓存").setExecuteCommand("/dominion reload_cache").build())
|
||||
@ -55,13 +58,14 @@ public class Menu {
|
||||
.append(Button.create("重载配置").setExecuteCommand("/dominion reload_config").build())
|
||||
.append("重载配置文件");
|
||||
ListView view = ListView.create(10, "/dominion menu");
|
||||
view.title("Dominion 领地系统")
|
||||
.navigator(Line.create().append("主菜单"))
|
||||
.add(create)
|
||||
.add(list)
|
||||
.add(template)
|
||||
.add(help)
|
||||
.add(link);
|
||||
view.title("Dominion 领地系统");
|
||||
view.navigator(Line.create().append("主菜单"));
|
||||
view.add(create);
|
||||
view.add(list);
|
||||
if (Dominion.config.getGroupTitleEnable()) view.add(title);
|
||||
view.add(template);
|
||||
// view.add(help);
|
||||
view.add(link);
|
||||
if (Dominion.config.getResidenceMigration()) {
|
||||
view.add(migrate);
|
||||
}
|
@ -3,6 +3,7 @@ package cn.lunadeer.dominion.tuis;
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.utils.ResMigration;
|
||||
import cn.lunadeer.dominion.utils.TuiUtils;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -18,7 +19,7 @@ import org.bukkit.entity.Player;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class MigrateList {
|
||||
|
||||
@ -31,7 +32,7 @@ public class MigrateList {
|
||||
return;
|
||||
}
|
||||
|
||||
int page = Apis.getPage(args, 1);
|
||||
int page = TuiUtils.getPage(args, 1);
|
||||
|
||||
ListView view = ListView.create(10, "/dominion migrate_list");
|
||||
|
@ -11,9 +11,9 @@ import net.kyori.adventure.text.format.TextDecoration;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.notOp;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.notOp;
|
||||
|
||||
public class SysConfig {
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
@ -28,40 +28,51 @@ public class SysConfig {
|
||||
Line limitSize = Line.create()
|
||||
.append(Component.text("领地尺寸限制"));
|
||||
view.add(limitSize);
|
||||
|
||||
Line spawnProtect = Line.create()
|
||||
.append(Component.text(" 出生点保护范围"));
|
||||
if (Dominion.config.getSpawnProtection() == -1) {
|
||||
spawnProtect.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config spawn_protection 10 " + page).build());
|
||||
} else {
|
||||
spawnProtect.append(NumChanger.create(Dominion.config.getSpawnProtection(), "/dominion set_config spawn_protection").setPageNumber(page).build());
|
||||
spawnProtect.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config spawn_protection -1 " + page).build());
|
||||
}
|
||||
view.add(spawnProtect);
|
||||
|
||||
Line limitSizeX = Line.create()
|
||||
.append(Component.text(" X轴(东西)"));
|
||||
if (Dominion.config.getLimitSizeX() == -1) {
|
||||
if (Dominion.config.getLimitSizeX(null) == -1) {
|
||||
limitSizeX.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config limit_size_x 64 " + page).build());
|
||||
} else {
|
||||
limitSizeX.append(NumChanger.create(Dominion.config.getLimitSizeX(), "/dominion set_config limit_size_x").setPageNumber(page).build());
|
||||
limitSizeX.append(NumChanger.create(Dominion.config.getLimitSizeX(null), "/dominion set_config limit_size_x").setPageNumber(page).build());
|
||||
limitSizeX.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config limit_size_x -1 " + page).build());
|
||||
}
|
||||
view.add(limitSizeX);
|
||||
Line limitSizeZ = Line.create()
|
||||
.append(Component.text(" Z轴(南北)"));
|
||||
if (Dominion.config.getLimitSizeZ() == -1) {
|
||||
if (Dominion.config.getLimitSizeZ(null) == -1) {
|
||||
limitSizeZ.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config limit_size_z 64 " + page).build());
|
||||
} else {
|
||||
limitSizeZ.append(NumChanger.create(Dominion.config.getLimitSizeZ(), "/dominion set_config limit_size_z").setPageNumber(page).build());
|
||||
limitSizeZ.append(NumChanger.create(Dominion.config.getLimitSizeZ(null), "/dominion set_config limit_size_z").setPageNumber(page).build());
|
||||
limitSizeZ.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config limit_size_z -1 " + page).build());
|
||||
}
|
||||
view.add(limitSizeZ);
|
||||
Line limitSizeY = Line.create()
|
||||
.append(Component.text(" Y轴(垂直)"));
|
||||
if (!Dominion.config.getLimitVert()) {
|
||||
if (Dominion.config.getLimitSizeY() == -1) {
|
||||
if (!Dominion.config.getLimitVert(null)) {
|
||||
if (Dominion.config.getLimitSizeY(null) == -1) {
|
||||
limitSizeY.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config limit_size_y 64 " + page).build());
|
||||
} else {
|
||||
limitSizeY.append(NumChanger.create(Dominion.config.getLimitSizeY(), "/dominion set_config limit_size_y").setPageNumber(page).build());
|
||||
limitSizeY.append(NumChanger.create(Dominion.config.getLimitSizeY(null), "/dominion set_config limit_size_y").setPageNumber(page).build());
|
||||
limitSizeY.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config limit_size_y -1 " + page).build());
|
||||
}
|
||||
} else {
|
||||
limitSizeY.append(Component.text(Dominion.config.getLimitSizeY())
|
||||
limitSizeY.append(Component.text(Dominion.config.getLimitSizeY(null))
|
||||
.style(Style.style(TextDecoration.STRIKETHROUGH))
|
||||
.hoverEvent(Component.text("因为垂直自动延伸已开启,此设置不可手动修改")));
|
||||
}
|
||||
view.add(limitSizeY);
|
||||
if (Dominion.config.getLimitVert()) {
|
||||
if (Dominion.config.getLimitVert(null)) {
|
||||
view.add(Line.create()
|
||||
.append("垂直自动延伸")
|
||||
.append(Button.createGreen("☑").setExecuteCommand("/dominion set_config limit_vert false " + page).build()));
|
||||
@ -72,27 +83,27 @@ public class SysConfig {
|
||||
}
|
||||
Line limitMaxY = Line.create()
|
||||
.append(Component.text("最高Y坐标限制"));
|
||||
limitMaxY.append(NumChanger.create(Dominion.config.getLimitMaxY(), "/dominion set_config limit_max_y").setPageNumber(page).build());
|
||||
limitMaxY.append(NumChanger.create(Dominion.config.getLimitMaxY(null), "/dominion set_config limit_max_y").setPageNumber(page).build());
|
||||
view.add(limitMaxY);
|
||||
Line limitMinY = Line.create()
|
||||
.append(Component.text("最低Y坐标限制"));
|
||||
limitMinY.append(NumChanger.create(Dominion.config.getLimitMinY(), "/dominion set_config limit_min_y").setPageNumber(page).build());
|
||||
limitMinY.append(NumChanger.create(Dominion.config.getLimitMinY(null), "/dominion set_config limit_min_y").setPageNumber(page).build());
|
||||
view.add(limitMinY);
|
||||
Line limitAmount = Line.create()
|
||||
.append(Component.text("每个玩家领地数量限制"));
|
||||
if (Dominion.config.getLimitAmount() == -1) {
|
||||
if (Dominion.config.getLimitAmount(null) == -1) {
|
||||
limitAmount.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config limit_amount 3 " + page).build());
|
||||
} else {
|
||||
limitAmount.append(NumChanger.create(Dominion.config.getLimitAmount(), "/dominion set_config limit_amount").setPageNumber(page).build());
|
||||
limitAmount.append(NumChanger.create(Dominion.config.getLimitAmount(null), "/dominion set_config limit_amount").setPageNumber(page).build());
|
||||
limitAmount.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config limit_amount -1 " + page).build());
|
||||
}
|
||||
view.add(limitAmount);
|
||||
Line limitDepth = Line.create()
|
||||
.append(Component.text("领地深度限制"));
|
||||
if (Dominion.config.getLimitDepth() == -1) {
|
||||
if (Dominion.config.getLimitDepth(null) == -1) {
|
||||
limitDepth.append(Component.text("无限制")).append(Button.create("设置数值").setExecuteCommand("/dominion set_config limit_depth 64 " + page).build());
|
||||
} else {
|
||||
limitDepth.append(NumChanger.create(Dominion.config.getLimitDepth(), "/dominion set_config limit_depth").setPageNumber(page).build());
|
||||
limitDepth.append(NumChanger.create(Dominion.config.getLimitDepth(null), "/dominion set_config limit_depth").setPageNumber(page).build());
|
||||
limitDepth.append(Button.create("设置无限制").setExecuteCommand("/dominion set_config limit_depth -1 " + page).build());
|
||||
}
|
||||
view.add(limitDepth);
|
||||
@ -135,9 +146,9 @@ public class SysConfig {
|
||||
view.add(economy);
|
||||
Line price = Line.create()
|
||||
.append(Component.text(" 每方块单价"))
|
||||
.append(NumChanger.create(Dominion.config.getEconomyPrice(), "/dominion set_config economy_price", 0.1).setPageNumber(page).build());
|
||||
.append(NumChanger.create(Dominion.config.getEconomyPrice(null), "/dominion set_config economy_price", 0.1).setPageNumber(page).build());
|
||||
view.add(price);
|
||||
if (Dominion.config.getEconomyOnlyXZ()) {
|
||||
if (Dominion.config.getEconomyOnlyXZ(null)) {
|
||||
view.add(Line.create()
|
||||
.append(" 仅计价平面积")
|
||||
.append(Button.createGreen("☑").setExecuteCommand("/dominion set_config economy_only_xz false " + page).build()));
|
||||
@ -148,7 +159,7 @@ public class SysConfig {
|
||||
}
|
||||
Line refund = Line.create()
|
||||
.append(Component.text(" 删除/缩小领地退还比例"))
|
||||
.append(NumChanger.create(Dominion.config.getEconomyRefund(), "/dominion set_config economy_refund", 0.01).setPageNumber(page).build());
|
||||
.append(NumChanger.create(Dominion.config.getEconomyRefund(null), "/dominion set_config economy_refund", 0.01).setPageNumber(page).build());
|
||||
view.add(refund);
|
||||
}
|
||||
if (Dominion.config.getResidenceMigration()) {
|
57
core/src/main/java/cn/lunadeer/dominion/tuis/TitleList.java
Normal file
57
core/src/main/java/cn/lunadeer/dominion/tuis/TitleList.java
Normal file
@ -0,0 +1,57 @@
|
||||
package cn.lunadeer.dominion.tuis;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Line;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class TitleList {
|
||||
|
||||
public static void show(CommandSender sender, int page) {
|
||||
show(sender, new String[]{String.valueOf(page)});
|
||||
}
|
||||
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
Player player = playerOnly(sender);
|
||||
if (player == null) return;
|
||||
int page = getPage(args, 1);
|
||||
ListView view = ListView.create(10, "/dominion title_list");
|
||||
|
||||
view.title("我可使用的权限组称号");
|
||||
view.navigator(Line.create().append(Button.create("主菜单").setExecuteCommand("/dominion menu").build()).append("权限组称号列表"));
|
||||
|
||||
List<GroupDTO> groups = Cache.instance.getBelongGroupsOf(player.getUniqueId());
|
||||
GroupDTO using = Cache.instance.getPlayerUsingGroupTitle(player.getUniqueId());
|
||||
|
||||
// 将其拥有的所有领地的权限组称号都加入列表 - 领地所有者可以使用其领地的任意权限组称号
|
||||
List<DominionDTO> dominions = DominionDTO.selectByOwner(player.getUniqueId());
|
||||
for (DominionDTO dominion : dominions) {
|
||||
List<GroupDTO> groupsOfDom = GroupDTO.selectByDominionId(dominion.getId());
|
||||
groups.addAll(groupsOfDom);
|
||||
}
|
||||
|
||||
for (GroupDTO group : groups) {
|
||||
DominionDTO dominion = Cache.instance.getDominion(group.getDomID());
|
||||
Line line = Line.create();
|
||||
if (using != null && using.getId().equals(group.getId())) {
|
||||
line.append(Button.createRed("卸下").setExecuteCommand("/dominion use_title -1").build());
|
||||
} else {
|
||||
line.append(Button.createGreen("使用").setExecuteCommand("/dominion use_title " + group.getId()).build());
|
||||
}
|
||||
line.append(group.getNameColoredComponent()).append("来自领地:" + dominion.getName());
|
||||
view.add(line);
|
||||
}
|
||||
|
||||
view.showOn(player, page);
|
||||
}
|
||||
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
package cn.lunadeer.dominion.tuis.dominion;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.DominionNode;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ViewStyles;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -14,9 +14,9 @@ import org.bukkit.entity.Player;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.commands.Helper.playerAdminDominions;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class DominionList {
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
@ -27,9 +27,9 @@ public class DominionList {
|
||||
|
||||
view.title("我的领地列表");
|
||||
view.navigator(Line.create().append(Button.create("主菜单").setExecuteCommand("/dominion menu").build()).append("我的领地"));
|
||||
view.addLines(BuildTreeLines(Cache.instance.getDominionTreeByPlayer(player.getName()), 0));
|
||||
view.addLines(BuildTreeLines(DominionNode.BuildNodeTree(-1, DominionDTO.selectByOwner(player.getUniqueId())), 0));
|
||||
List<String> admin_dominions = playerAdminDominions(sender);
|
||||
if (admin_dominions.size() != 0) {
|
||||
if (!admin_dominions.isEmpty()) {
|
||||
view.add(Line.create().append(""));
|
||||
view.add(Line.create().append(Component.text("--- 以下为你拥有管理员权限的领地 ---", ViewStyles.main_color)));
|
||||
}
|
||||
@ -43,9 +43,7 @@ public class DominionList {
|
||||
public static List<Line> BuildTreeLines(List<DominionNode> dominionTree, Integer depth) {
|
||||
List<Line> lines = new ArrayList<>();
|
||||
StringBuilder prefix = new StringBuilder();
|
||||
for (int i = 0; i < depth; i++) {
|
||||
prefix.append(" | ");
|
||||
}
|
||||
prefix.append(" | ".repeat(Math.max(0, depth)));
|
||||
for (DominionNode node : dominionTree) {
|
||||
TextComponent manage = Button.createGreen("管理").setExecuteCommand("/dominion manage " + node.getDominion().getName()).build();
|
||||
TextComponent delete = Button.createRed("删除").setExecuteCommand("/dominion delete " + node.getDominion().getName()).build();
|
@ -11,8 +11,8 @@ import net.kyori.adventure.text.format.TextColor;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.*;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.*;
|
||||
|
||||
public class DominionManage {
|
||||
public static void show(CommandSender sender, String[] args) {
|
@ -10,8 +10,8 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class EnvSetting {
|
||||
|
@ -10,8 +10,8 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class GuestSetting {
|
||||
|
@ -1,19 +1,18 @@
|
||||
package cn.lunadeer.dominion.tuis.dominion.manage;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.controllers.PlayerController;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.utils.Particle;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.ParticleRender;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.View;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Line;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getDominionNameArg_1;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getDominionNameArg_1;
|
||||
|
||||
public class SizeInfo {
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
@ -49,8 +48,6 @@ public class SizeInfo {
|
||||
.append(Button.create("管理界面").setExecuteCommand("/dominion manage " + dominion.getName()).build())
|
||||
.append(Button.create("访客权限").setExecuteCommand("/dominion guest_setting " + dominion.getName()).build()))
|
||||
.showOn(player);
|
||||
ParticleRender.showBoxFace(Dominion.instance, player,
|
||||
dominion.getLocation1(),
|
||||
dominion.getLocation2());
|
||||
Particle.showBorder(player, dominion);
|
||||
}
|
||||
}
|
@ -2,9 +2,9 @@ package cn.lunadeer.dominion.tuis.dominion.manage.group;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.dominion.tuis.Apis;
|
||||
import cn.lunadeer.dominion.utils.TuiUtils;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
@ -16,8 +16,8 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.noAuthToManage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.noAuthToManage;
|
||||
|
||||
public class GroupList {
|
||||
|
||||
@ -42,7 +42,7 @@ public class GroupList {
|
||||
return;
|
||||
}
|
||||
if (noAuthToManage(player, dominion)) return;
|
||||
int page = Apis.getPage(args, 3);
|
||||
int page = TuiUtils.getPage(args, 3);
|
||||
List<GroupDTO> groups = GroupDTO.selectByDominionId(dominion.getId());
|
||||
ListView view = ListView.create(10, "/dominion group list " + dominion.getName());
|
||||
view.title("权限组列表");
|
||||
@ -70,11 +70,11 @@ public class GroupList {
|
||||
Button add = Button.createGreen("+")
|
||||
.setHoverText("添加成员到权限组 " + group.getName())
|
||||
.setExecuteCommand("/dominion group select_member " + dominion.getName() + " " + group.getName() + " " + page);
|
||||
line.append(del.build()).append(edit.build()).append(group.getName()).append(add.build());
|
||||
line.append(del.build()).append(edit.build()).append(group.getNameColoredComponent()).append(add.build());
|
||||
view.add(line);
|
||||
List<PlayerPrivilegeDTO> players = PlayerPrivilegeDTO.selectByGroupId(group.getId());
|
||||
List<MemberDTO> players = MemberDTO.selectByGroupId(group.getId());
|
||||
XLogger.debug("players: " + players.size());
|
||||
for (PlayerPrivilegeDTO playerPrivilege : players) {
|
||||
for (MemberDTO playerPrivilege : players) {
|
||||
PlayerDTO p = PlayerDTO.select(playerPrivilege.getPlayerUUID());
|
||||
if (p == null) continue;
|
||||
Button remove = Button.createRed("-")
|
@ -3,7 +3,7 @@ package cn.lunadeer.dominion.tuis.dominion.manage.group;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.tuis.Apis;
|
||||
import cn.lunadeer.dominion.utils.TuiUtils;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -12,8 +12,8 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.noAuthToManage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.noAuthToManage;
|
||||
|
||||
public class GroupSetting {
|
||||
public static void show(CommandSender sender, String dominionName, String groupName) {
|
||||
@ -37,7 +37,7 @@ public class GroupSetting {
|
||||
return;
|
||||
}
|
||||
if (noAuthToManage(player, dominion)) return;
|
||||
int page = Apis.getPage(args, 4);
|
||||
int page = TuiUtils.getPage(args, 4);
|
||||
GroupDTO group = GroupDTO.select(dominion.getId(), args[3]);
|
||||
if (group == null) {
|
||||
Notification.error(sender, "权限组 %s 不存在", args[3]);
|
||||
@ -45,7 +45,7 @@ public class GroupSetting {
|
||||
}
|
||||
|
||||
ListView view = ListView.create(10, "/dominion group setting " + dominion.getName() + " " + group.getName());
|
||||
view.title("权限组 " + group.getName() + " 管理");
|
||||
view.title(Component.text("权限组 ").append(group.getNameColoredComponent()).append(Component.text(" 管理")));
|
||||
view.navigator(
|
||||
Line.create()
|
||||
.append(Button.create("主菜单").setExecuteCommand("/dominion menu").build())
|
@ -2,8 +2,8 @@ package cn.lunadeer.dominion.tuis.dominion.manage.group;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -13,14 +13,14 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.noAuthToManage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.noAuthToManage;
|
||||
|
||||
public class SelectMember {
|
||||
public static void show(CommandSender sender, String[] args) {
|
||||
if (args.length < 4) {
|
||||
Notification.error(sender, "用法: /dominion group select_member <领地名称> <权限组名称> [页码]");
|
||||
Notification.error(sender, "用法: /dominion group select_member <领地名称> <权限组名称> [回显页码] [页码]");
|
||||
return;
|
||||
}
|
||||
Player player = playerOnly(sender);
|
||||
@ -37,13 +37,14 @@ public class SelectMember {
|
||||
return;
|
||||
}
|
||||
int backPage = getPage(args, 4);
|
||||
int page = getPage(args, 5);
|
||||
ListView view = ListView.create(10, "/dominion group select_member " + dominion.getName() + " " + group.getName() + " " + backPage);
|
||||
view.title("选择成员");
|
||||
Line sub = Line.create().append("选择成员添加到权限组 " + group.getName())
|
||||
.append(Button.create("返回").setExecuteCommand("/dominion group list " + dominion.getName() + " " + backPage).build());
|
||||
view.subtitle(sub);
|
||||
List<PlayerPrivilegeDTO> members = PlayerPrivilegeDTO.selectByGroupId(-1);
|
||||
for (PlayerPrivilegeDTO member : members) {
|
||||
List<MemberDTO> members = MemberDTO.selectByDomGroupId(dominion.getId(), -1);
|
||||
for (MemberDTO member : members) {
|
||||
PlayerDTO p = PlayerDTO.select(member.getPlayerUUID());
|
||||
if (p == null) continue;
|
||||
view.add(Line.create()
|
||||
@ -51,6 +52,6 @@ public class SelectMember {
|
||||
.setExecuteCommand("/dominion group add_member " + dominion.getName() + " " + group.getName() + " " + p.getLastKnownName() + " " + backPage)
|
||||
.build()));
|
||||
}
|
||||
view.showOn(player, backPage);
|
||||
view.showOn(player, page);
|
||||
}
|
||||
}
|
@ -15,10 +15,10 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.CommandParser;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.noAuthToManage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.CommandParser;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.noAuthToManage;
|
||||
|
||||
public class MemberList {
|
||||
|
||||
@ -45,7 +45,7 @@ public class MemberList {
|
||||
int page = getPage(args, 3);
|
||||
ListView view = ListView.create(10, "/dominion member list " + dominion.getName());
|
||||
if (noAuthToManage(player, dominion)) return;
|
||||
List<PlayerPrivilegeDTO> privileges = PlayerPrivilegeDTO.select(dominion.getId());
|
||||
List<MemberDTO> privileges = MemberDTO.select(dominion.getId());
|
||||
view.title("领地 " + dominion.getName() + " 成员列表");
|
||||
view.navigator(
|
||||
Line.create()
|
||||
@ -56,7 +56,7 @@ public class MemberList {
|
||||
);
|
||||
view.add(Line.create().append(Button.create("添加成员")
|
||||
.setExecuteCommand(CommandParser("/dominion member select_player %s", dominion.getName())).build()));
|
||||
for (PlayerPrivilegeDTO privilege : privileges) {
|
||||
for (MemberDTO privilege : privileges) {
|
||||
PlayerDTO p_player = PlayerDTO.select(privilege.getPlayerUUID());
|
||||
if (p_player == null) continue;
|
||||
GroupDTO group = Cache.instance.getGroup(privilege.getGroupId());
|
@ -2,8 +2,8 @@ package cn.lunadeer.dominion.tuis.dominion.manage.member;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -12,9 +12,9 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.noAuthToManage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.noAuthToManage;
|
||||
|
||||
public class MemberSetting {
|
||||
public static void show(CommandSender sender, String dominionName, String playerName, Integer page) {
|
||||
@ -46,7 +46,7 @@ public class MemberSetting {
|
||||
Notification.error(sender, "玩家 %s 不存在", playerName);
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = PlayerPrivilegeDTO.select(playerDTO.getUuid(), dominion.getId());
|
||||
MemberDTO privilege = MemberDTO.select(playerDTO.getUuid(), dominion.getId());
|
||||
if (privilege == null) {
|
||||
Notification.warn(sender, "玩家 %s 不是领地 %s 的成员", playerName, dominion.getName());
|
||||
return;
|
@ -11,9 +11,9 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.CommandParser;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.CommandParser;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class SelectPlayer {
|
||||
public static void show(CommandSender sender, String dominionName, Integer page) {
|
@ -11,9 +11,9 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.CommandParser;
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.CommandParser;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class SelectTemplate {
|
||||
|
@ -9,8 +9,8 @@ import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class TemplateList {
|
||||
|
@ -10,8 +10,8 @@ import net.kyori.adventure.text.Component;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.tuis.Apis.getPage;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.TuiUtils.getPage;
|
||||
|
||||
public class TemplateSetting {
|
||||
|
||||
@ -34,7 +34,7 @@ public class TemplateSetting {
|
||||
return;
|
||||
}
|
||||
|
||||
ListView view = ListView.create(10, "/dominion template manage " + template.getName());
|
||||
ListView view = ListView.create(10, "/dominion template setting " + template.getName());
|
||||
view.title("模板 " + args[1] + " 权限管理");
|
||||
view.navigator(Line.create()
|
||||
.append(Button.create("主菜单").setExecuteCommand("/dominion menu").build())
|
@ -1,5 +1,6 @@
|
||||
package cn.lunadeer.dominion;
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
@ -15,18 +16,18 @@ import java.util.*;
|
||||
|
||||
public class BlueMapConnect {
|
||||
public static void render() {
|
||||
if (!Dominion.config.getBlueMap()) {
|
||||
return;
|
||||
}
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
try {
|
||||
BlueMapAPI.getInstance().ifPresent(api -> {
|
||||
Map<String, List<DominionDTO>> world_dominions = new HashMap<>();
|
||||
for (DominionDTO dominion : Cache.instance.getDominions()) {
|
||||
if (!world_dominions.containsKey(dominion.getWorld())) {
|
||||
world_dominions.put(dominion.getWorld(), new ArrayList<>());
|
||||
if (dominion.getWorld() == null) {
|
||||
continue;
|
||||
}
|
||||
world_dominions.get(dominion.getWorld()).add(dominion);
|
||||
if (!world_dominions.containsKey(dominion.getWorld().getName())) {
|
||||
world_dominions.put(dominion.getWorld().getName(), new ArrayList<>());
|
||||
}
|
||||
world_dominions.get(dominion.getWorld().getName()).add(dominion);
|
||||
}
|
||||
for (Map.Entry<String, List<DominionDTO>> d : world_dominions.entrySet()) {
|
||||
api.getWorld(d.getKey()).ifPresent(world -> {
|
||||
@ -76,9 +77,6 @@ public class BlueMapConnect {
|
||||
}
|
||||
|
||||
public static void renderMCA(Map<String, List<String>> mca_files) {
|
||||
if (!Dominion.config.getBlueMap()) {
|
||||
return;
|
||||
}
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
try {
|
||||
BlueMapAPI.getInstance().ifPresent(api -> {
|
@ -0,0 +1,49 @@
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
public class CommandUtils {
|
||||
public static Player playerOnly(CommandSender sender) {
|
||||
if (!(sender instanceof Player)) {
|
||||
Notification.error(sender, "该命令只能由玩家执行");
|
||||
return null;
|
||||
}
|
||||
return (Player) sender;
|
||||
}
|
||||
|
||||
public static boolean hasPermission(CommandSender sender, String permission) {
|
||||
if (!sender.hasPermission(permission)) {
|
||||
Notification.error(sender, "你没有 %s 权限执行此命令", permission);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static Map<Integer, Location> autoPoints(Player player) {
|
||||
Integer size = Dominion.config.getAutoCreateRadius();
|
||||
Location location = player.getLocation();
|
||||
Location location1 = new Location(location.getWorld(), location.getX() - size, location.getY() - size, location.getZ() - size);
|
||||
Location location2 = new Location(location.getWorld(), location.getX() + size, location.getY() + size, location.getZ() + size);
|
||||
if (Dominion.config.getLimitVert(player)) {
|
||||
location1.setY(Dominion.config.getLimitMinY(player));
|
||||
location2.setY(Dominion.config.getLimitMaxY(player) - 1);
|
||||
}
|
||||
Map<Integer, Location> points = new HashMap<>();
|
||||
points.put(0, location1);
|
||||
points.put(1, location2);
|
||||
Dominion.pointsSelect.put(player.getUniqueId(), points);
|
||||
return points;
|
||||
}
|
||||
|
||||
public static String CommandParser(String command, Object... args) {
|
||||
return String.format(command, args);
|
||||
}
|
||||
|
||||
}
|
@ -1,21 +1,25 @@
|
||||
package cn.lunadeer.dominion.controllers;
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.controllers.AbstractOperator;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import org.bukkit.Location;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
public class Apis {
|
||||
public class ControllerUtils {
|
||||
|
||||
public static boolean notOwner(AbstractOperator player, DominionDTO dominion) {
|
||||
if (player.isOp()) return false;
|
||||
if (player.isOp() && Dominion.config.getLimitOpBypass()) return false;
|
||||
return !dominion.getOwner().equals(player.getUniqueId());
|
||||
}
|
||||
|
||||
public static boolean noAuthToChangeFlags(AbstractOperator player, DominionDTO dominion) {
|
||||
if (player.isOp()) return false;
|
||||
if (player.isOp() && Dominion.config.getLimitOpBypass()) return false;
|
||||
if (!dominion.getOwner().equals(player.getUniqueId())) {
|
||||
PlayerPrivilegeDTO privileges = PlayerPrivilegeDTO.select(player.getUniqueId(), dominion.getId());
|
||||
MemberDTO privileges = MemberDTO.select(player.getUniqueId(), dominion.getId());
|
||||
if (privileges == null || !privileges.getAdmin()) {
|
||||
player.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "你不是领地 %s 的拥有者或管理员,无权修改权限", dominion.getName()));
|
||||
return true;
|
||||
@ -37,7 +41,7 @@ public class Apis {
|
||||
player.setResponse(new AbstractOperator.Result(AbstractOperator.Result.FAILURE, "无法获取你的位置信息"));
|
||||
return null;
|
||||
}
|
||||
DominionDTO dominion = Cache.instance.getDominion(location);
|
||||
DominionDTO dominion = Cache.instance.getDominionByLoc(location);
|
||||
if (dominion == null) {
|
||||
return null;
|
||||
}
|
||||
@ -49,4 +53,20 @@ public class Apis {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 检查一个成员是否是管理员
|
||||
* 此方法会同时尝试搜索玩家所在的权限组是否是管理员
|
||||
*
|
||||
* @param member 成员权限
|
||||
* @return 是否是管理员
|
||||
*/
|
||||
public static boolean isAdmin(@NotNull MemberDTO member) {
|
||||
GroupDTO group = GroupDTO.select(member.getGroupId());
|
||||
if (group == null) {
|
||||
return member.getAdmin();
|
||||
} else {
|
||||
return group.getAdmin();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
108
core/src/main/java/cn/lunadeer/dominion/utils/DynmapConnect.java
Normal file
108
core/src/main/java/cn/lunadeer/dominion/utils/DynmapConnect.java
Normal file
@ -0,0 +1,108 @@
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.dynmap.DynmapCommonAPI;
|
||||
import org.dynmap.DynmapCommonAPIListener;
|
||||
import org.dynmap.markers.AreaMarker;
|
||||
import org.dynmap.markers.MarkerAPI;
|
||||
import org.dynmap.markers.MarkerSet;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public class DynmapConnect extends DynmapCommonAPIListener {
|
||||
|
||||
public static DynmapConnect instance;
|
||||
|
||||
private MarkerSet markerSet_dominion = null;
|
||||
private MarkerSet markerSet_mca = null;
|
||||
|
||||
public DynmapConnect() {
|
||||
DynmapCommonAPIListener.register(this);
|
||||
instance = this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void apiEnabled(DynmapCommonAPI dynmapCommonAPI) {
|
||||
MarkerAPI markerAPI = dynmapCommonAPI.getMarkerAPI();
|
||||
this.markerSet_dominion = markerAPI.getMarkerSet("dominion");
|
||||
if (this.markerSet_dominion == null) {
|
||||
this.markerSet_dominion = markerAPI.createMarkerSet("dominion", "Dominion领地", null, false);
|
||||
}
|
||||
this.markerSet_mca = markerAPI.getMarkerSet("mca");
|
||||
if (this.markerSet_mca == null) {
|
||||
this.markerSet_mca = markerAPI.createMarkerSet("mca", "MCA文件", null, false);
|
||||
}
|
||||
XLogger.info("Dynmap 成功注册");
|
||||
}
|
||||
|
||||
private void setDominionMarker(DominionDTO dominion) {
|
||||
String nameLabel = "<div>" + dominion.getName() + "</div>";
|
||||
double[] xx = {dominion.getX1(), dominion.getX2()};
|
||||
double[] zz = {dominion.getZ1(), dominion.getZ2()};
|
||||
if (dominion.getWorld() == null) {
|
||||
return;
|
||||
}
|
||||
AreaMarker marker = this.markerSet_dominion.createAreaMarker(
|
||||
dominion.getId().toString(),
|
||||
nameLabel,
|
||||
true,
|
||||
dominion.getWorld().getName(),
|
||||
xx,
|
||||
zz,
|
||||
false
|
||||
);
|
||||
marker.setFillStyle(0.2, dominion.getColorHex());
|
||||
marker.setLineStyle(1, 0.8, dominion.getColorHex());
|
||||
XLogger.debug("Add dominion marker: " + dominion.getName());
|
||||
}
|
||||
|
||||
public void setDominionMarkers(List<DominionDTO> dominions) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
if (this.markerSet_dominion == null) {
|
||||
XLogger.warn("无法连接到 Dynmap,如果你不打算使用卫星地图渲染建议前往配置文件关闭此功能。");
|
||||
return;
|
||||
}
|
||||
this.markerSet_dominion.getAreaMarkers().forEach(AreaMarker::deleteMarker);
|
||||
for (DominionDTO dominion : dominions) {
|
||||
this.setDominionMarker(dominion);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public void setMCAMarkers(Map<String, List<String>> mca_files) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
if (this.markerSet_mca == null) {
|
||||
XLogger.warn("无法连接到 Dynmap,如果你不打算使用卫星地图渲染建议前往配置文件关闭此功能。");
|
||||
return;
|
||||
}
|
||||
this.markerSet_mca.getAreaMarkers().forEach(AreaMarker::deleteMarker);
|
||||
for (Map.Entry<String, List<String>> entry : mca_files.entrySet()) {
|
||||
for (String file : entry.getValue()) {
|
||||
String[] cords = file.split("\\.");
|
||||
int world_x1 = Integer.parseInt(cords[1]) * 512;
|
||||
int world_x2 = (Integer.parseInt(cords[1]) + 1) * 512;
|
||||
int world_z1 = Integer.parseInt(cords[2]) * 512;
|
||||
int world_z2 = (Integer.parseInt(cords[2]) + 1) * 512;
|
||||
String nameLabel = "<div>" + file + "</div>";
|
||||
double[] xx = {world_x1, world_x2};
|
||||
double[] zz = {world_z1, world_z2};
|
||||
AreaMarker marker = this.markerSet_mca.createAreaMarker(
|
||||
file,
|
||||
nameLabel,
|
||||
true,
|
||||
entry.getKey(),
|
||||
xx,
|
||||
zz,
|
||||
false
|
||||
);
|
||||
marker.setFillStyle(0.2, 0x00CC00);
|
||||
marker.setLineStyle(1, 0.8, 0x00CC00);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
}
|
@ -1,11 +1,11 @@
|
||||
package cn.lunadeer.dominion.events;
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.dtos.GroupDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import net.kyori.adventure.text.Component;
|
||||
import net.kyori.adventure.text.TextComponent;
|
||||
@ -15,9 +15,12 @@ import net.kyori.adventure.text.format.TextDecoration;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.Cancellable;
|
||||
import org.bukkit.inventory.Inventory;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
public class Apis {
|
||||
public static boolean canByPass(Player player, DominionDTO dom, PlayerPrivilegeDTO prev) {
|
||||
import javax.annotation.Nullable;
|
||||
|
||||
public class EventUtils {
|
||||
public static boolean canByPass(Player player, DominionDTO dom, MemberDTO prev) {
|
||||
if (player.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return true;
|
||||
}
|
||||
@ -28,7 +31,12 @@ public class Apis {
|
||||
return true;
|
||||
}
|
||||
if (prev != null) {
|
||||
return prev.getAdmin();
|
||||
if (prev.getGroupId() == -1) {
|
||||
return prev.getAdmin();
|
||||
} else {
|
||||
GroupDTO group = Cache.instance.getGroup(prev.getGroupId());
|
||||
return group != null && group.getAdmin();
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
@ -37,7 +45,7 @@ public class Apis {
|
||||
if (inv.getLocation() == null) {
|
||||
return null;
|
||||
} else {
|
||||
return Cache.instance.getDominion(inv.getLocation());
|
||||
return Cache.instance.getDominionByLoc(inv.getLocation());
|
||||
}
|
||||
}
|
||||
|
||||
@ -48,21 +56,18 @@ public class Apis {
|
||||
if (dom == null) {
|
||||
return true;
|
||||
}
|
||||
PlayerPrivilegeDTO prev = Cache.instance.getPlayerPrivilege(player, dom);
|
||||
MemberDTO prev = Cache.instance.getMember(player, dom);
|
||||
if (canByPass(player, dom, prev)) {
|
||||
return true;
|
||||
}
|
||||
if (prev != null) {
|
||||
if (prev.getGroupId() == -1) {
|
||||
if (prev.getFlagValue(flag)) {
|
||||
GroupDTO group = Cache.instance.getGroup(prev.getGroupId());
|
||||
if (prev.getGroupId() != -1 && group != null) {
|
||||
if (group.getFlagValue(flag)) {
|
||||
return true;
|
||||
}
|
||||
} else {
|
||||
GroupDTO group = Cache.instance.getGroup(prev.getGroupId());
|
||||
if (group == null) {
|
||||
return false;
|
||||
}
|
||||
if (group.getFlagValue(flag)) {
|
||||
if (prev.getFlagValue(flag)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@ -82,7 +87,7 @@ public class Apis {
|
||||
return false;
|
||||
}
|
||||
|
||||
public static boolean checkFlag(DominionDTO dom, Flag flag, Cancellable event) {
|
||||
public static boolean checkFlag(@Nullable DominionDTO dom, @NotNull Flag flag, @Nullable Cancellable event) {
|
||||
if (!flag.getEnable()) {
|
||||
return true;
|
||||
}
|
||||
@ -92,7 +97,9 @@ public class Apis {
|
||||
if (dom.getFlagValue(flag)) {
|
||||
return true;
|
||||
}
|
||||
event.setCancelled(true);
|
||||
if (event != null) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
31
core/src/main/java/cn/lunadeer/dominion/utils/MapRender.java
Normal file
31
core/src/main/java/cn/lunadeer/dominion/utils/MapRender.java
Normal file
@ -0,0 +1,31 @@
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public class MapRender {
|
||||
|
||||
public static void render() {
|
||||
if (Dominion.config.getBlueMap()) {
|
||||
BlueMapConnect.render();
|
||||
}
|
||||
|
||||
if (Dominion.config.getDynmap()) {
|
||||
DynmapConnect.instance.setDominionMarkers(Cache.instance.getDominions());
|
||||
}
|
||||
}
|
||||
|
||||
public static void renderMCA(Map<String, List<String>> mca_files) {
|
||||
if (Dominion.config.getBlueMap()) {
|
||||
BlueMapConnect.renderMCA(mca_files);
|
||||
}
|
||||
|
||||
if (Dominion.config.getDynmap()) {
|
||||
DynmapConnect.instance.setMCAMarkers(mca_files);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
21
core/src/main/java/cn/lunadeer/dominion/utils/Particle.java
Normal file
21
core/src/main/java/cn/lunadeer/dominion/utils/Particle.java
Normal file
@ -0,0 +1,21 @@
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.ParticleRender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
public class Particle {
|
||||
|
||||
public static void showBorder(Player player, DominionDTO dominion) {
|
||||
ParticleRender.showBoxFace(player,
|
||||
dominion.getLocation1().getWorld(),
|
||||
dominion.getLocation1().getBlockX(),
|
||||
dominion.getLocation1().getBlockY(),
|
||||
dominion.getLocation1().getBlockZ(),
|
||||
dominion.getLocation2().getBlockX(),
|
||||
dominion.getLocation2().getBlockY(),
|
||||
dominion.getLocation2().getBlockZ()
|
||||
);
|
||||
}
|
||||
|
||||
}
|
@ -1,14 +1,12 @@
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.dominion.utils.Residence.Message;
|
||||
import cn.lunadeer.dominion.utils.Residence.Permission;
|
||||
import cn.lunadeer.dominion.utils.Residence.Residence;
|
||||
import cn.lunadeer.dominion.utils.Residence.SaveFile;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.OfflinePlayer;
|
||||
import org.bukkit.World;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.yaml.snakeyaml.Yaml;
|
||||
@ -58,19 +56,13 @@ public class ResMigration {
|
||||
}
|
||||
|
||||
private static ResidenceNode parseDominion(String name, World world, Residence res, SaveFile save) {
|
||||
OfflinePlayer bukkitOwner = Dominion.instance.getServer().getOfflinePlayer(UUID.fromString(res.Permissions.OwnerUUID));
|
||||
PlayerDTO owner = PlayerDTO.get(bukkitOwner);
|
||||
if (owner == null) {
|
||||
XLogger.warn("Owner not found: " + res.Permissions.OwnerUUID);
|
||||
return null;
|
||||
}
|
||||
String[] loc = res.Areas.values().toArray()[0].toString().split(":");
|
||||
if (loc.length != 6) {
|
||||
XLogger.warn("Invalid location: " + res.Areas.get("main"));
|
||||
return null;
|
||||
}
|
||||
ResidenceNode dominionNode = new ResidenceNode();
|
||||
dominionNode.owner = owner.getUuid();
|
||||
dominionNode.owner = UUID.fromString(res.Permissions.OwnerUUID);
|
||||
dominionNode.world = world;
|
||||
dominionNode.name = name;
|
||||
dominionNode.joinMessage = save.Messages.get(res.Messages).EnterMessage;
|
@ -1,8 +1,8 @@
|
||||
package cn.lunadeer.dominion.tuis;
|
||||
package cn.lunadeer.dominion.utils;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.PlayerPrivilegeDTO;
|
||||
import cn.lunadeer.dominion.dtos.MemberDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.ListView;
|
||||
import cn.lunadeer.minecraftpluginutils.stui.components.Button;
|
||||
@ -10,9 +10,9 @@ import cn.lunadeer.minecraftpluginutils.stui.components.Line;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import static cn.lunadeer.dominion.commands.Apis.playerOnly;
|
||||
import static cn.lunadeer.dominion.utils.CommandUtils.playerOnly;
|
||||
|
||||
public class Apis {
|
||||
public class TuiUtils {
|
||||
|
||||
public static int getPage(String[] args, int pos) {
|
||||
int page = 1;
|
||||
@ -45,7 +45,7 @@ public class Apis {
|
||||
public static boolean noAuthToManage(Player player, DominionDTO dominion) {
|
||||
if (player.isOp()) return false;
|
||||
if (!dominion.getOwner().equals(player.getUniqueId())) {
|
||||
PlayerPrivilegeDTO privileges = PlayerPrivilegeDTO.select(player.getUniqueId(), dominion.getId());
|
||||
MemberDTO privileges = MemberDTO.select(player.getUniqueId(), dominion.getId());
|
||||
if (privileges == null || !privileges.getAdmin()) {
|
||||
Notification.error(player, "你不是领地 %s 的拥有者或管理员,无权访问此页面", dominion.getName());
|
||||
return true;
|
@ -10,6 +10,7 @@ Database:
|
||||
AutoCreateRadius: 10 #-1 表示不开启
|
||||
|
||||
Limit:
|
||||
SpawnProtection: 10 # 出生点保护半径 出生点此范围内不允许圈地 -1 表示不开启
|
||||
MinY: -64 # 最小Y坐标
|
||||
MaxY: 320 # 最大Y坐标
|
||||
SizeX: 128 # X方向最大长度 -1:表示不限制
|
||||
@ -52,8 +53,19 @@ FlyPermissionNodes:
|
||||
# 是否允许玩家从 Residence 迁移领地数据
|
||||
ResidenceMigration: false
|
||||
|
||||
BlueMap: true
|
||||
# 权限组称号 - 使用权限组当作称号(需要PlaceholderAPI插件)
|
||||
# Papi: %dominion_group_title%
|
||||
# 前后缀如需要加颜色请使用这种格式 &#ffffff
|
||||
GroupTitle:
|
||||
Enable: false
|
||||
Prefix: "["
|
||||
Suffix: "]"
|
||||
|
||||
BlueMap: false
|
||||
Dynmap: false
|
||||
|
||||
CheckUpdate: true
|
||||
|
||||
Debug: false
|
||||
Debug: false
|
||||
|
||||
Timer: false # 性能测试计时器
|
20
core/src/main/resources/groups/sponsor.yml
Normal file
20
core/src/main/resources/groups/sponsor.yml
Normal file
@ -0,0 +1,20 @@
|
||||
# >---------------------------------<
|
||||
# | 圈地限制特殊权限组配置 |
|
||||
# >---------------------------------<
|
||||
# 此文件可以作为模板,你可以将此文件复制后重命名为你想要的权限组名,然后修改里面的配置
|
||||
# 如果你想给赞助玩家(或者VIP)一些特殊优惠,例如更少的圈地价格、更大的领地等,你可以在这里配置
|
||||
# 详细说明参阅 > https://ssl.lunadeer.cn:14448/doc/82/
|
||||
|
||||
|
||||
MinY: -64 # 最小Y坐标
|
||||
MaxY: 320 # 最大Y坐标
|
||||
SizeX: 128 # X方向最大长度 -1:表示不限制
|
||||
SizeY: 64 # Y方向最大长度 -1:表示不限制
|
||||
SizeZ: 128 # Z方向最大长度 -1:表示不限制
|
||||
Amount: 10 # 最大领地数量 -1:表示不限制
|
||||
Depth: 3 # 子领地深度 0:不允许子领地 -1:不限制
|
||||
Vert: false # 是否自动延伸到 MaxY 和 MinY
|
||||
WorldBlackList: [ ] # 不允许领地的世界
|
||||
Price: 10.0 # 方块单价
|
||||
OnlyXZ: false # 是否只计算xz平面积
|
||||
Refund: 0.85 # 删除领地退还比例
|
21
core/src/main/resources/plugin.yml
Normal file
21
core/src/main/resources/plugin.yml
Normal file
@ -0,0 +1,21 @@
|
||||
name: Dominion
|
||||
version: @version@
|
||||
main: cn.lunadeer.dominion.Dominion
|
||||
api-version: '1.20'
|
||||
folia-supported: true
|
||||
softdepend:
|
||||
- Vault
|
||||
- dynmap
|
||||
- PlaceholderAPI
|
||||
commands:
|
||||
Dominion:
|
||||
description: 领地插件命令
|
||||
usage: /dominion <cmd>
|
||||
aliases: [ dominion, dom ]
|
||||
permissions:
|
||||
dominion.admin:
|
||||
description: 领地插件管理员权限
|
||||
default: op
|
||||
dominion.default:
|
||||
description: 领地插件用户权限
|
||||
default: true
|
0
gradle.properties
Normal file
0
gradle.properties
Normal file
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
Binary file not shown.
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@ -0,0 +1 @@
|
||||
distributionUrl=https://mirrors.cloud.tencent.com/gradle/gradle-8.8-bin.zip
|
234
gradlew
vendored
Executable file
234
gradlew
vendored
Executable file
@ -0,0 +1,234 @@
|
||||
#!/bin/sh
|
||||
|
||||
#
|
||||
# Copyright © 2015-2021 the original authors.
|
||||
#
|
||||
# Licensed 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
|
||||
#
|
||||
# https://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.
|
||||
#
|
||||
|
||||
##############################################################################
|
||||
#
|
||||
# Gradle start up script for POSIX generated by Gradle.
|
||||
#
|
||||
# Important for running:
|
||||
#
|
||||
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
|
||||
# noncompliant, but you have some other compliant shell such as ksh or
|
||||
# bash, then to run this script, type that shell name before the whole
|
||||
# command line, like:
|
||||
#
|
||||
# ksh Gradle
|
||||
#
|
||||
# Busybox and similar reduced shells will NOT work, because this script
|
||||
# requires all of these POSIX shell features:
|
||||
# * functions;
|
||||
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
|
||||
# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
|
||||
# * compound commands having a testable exit status, especially «case»;
|
||||
# * various built-in commands including «command», «set», and «ulimit».
|
||||
#
|
||||
# Important for patching:
|
||||
#
|
||||
# (2) This script targets any POSIX shell, so it avoids extensions provided
|
||||
# by Bash, Ksh, etc; in particular arrays are avoided.
|
||||
#
|
||||
# The "traditional" practice of packing multiple parameters into a
|
||||
# space-separated string is a well documented source of bugs and security
|
||||
# problems, so this is (mostly) avoided, by progressively accumulating
|
||||
# options in "$@", and eventually passing that to Java.
|
||||
#
|
||||
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
|
||||
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
|
||||
# see the in-line comments for details.
|
||||
#
|
||||
# There are tweaks for specific operating systems such as AIX, CygWin,
|
||||
# Darwin, MinGW, and NonStop.
|
||||
#
|
||||
# (3) This script is generated from the Groovy template
|
||||
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
||||
# within the Gradle project.
|
||||
#
|
||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
||||
#
|
||||
##############################################################################
|
||||
|
||||
# Attempt to set APP_HOME
|
||||
|
||||
# Resolve links: $0 may be a link
|
||||
app_path=$0
|
||||
|
||||
# Need this for daisy-chained symlinks.
|
||||
while
|
||||
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
|
||||
[ -h "$app_path" ]
|
||||
do
|
||||
ls=$( ls -ld "$app_path" )
|
||||
link=${ls#*' -> '}
|
||||
case $link in #(
|
||||
/*) app_path=$link ;; #(
|
||||
*) app_path=$APP_HOME$link ;;
|
||||
esac
|
||||
done
|
||||
|
||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
||||
|
||||
APP_NAME="Gradle"
|
||||
APP_BASE_NAME=${0##*/}
|
||||
|
||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||
|
||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||
MAX_FD=maximum
|
||||
|
||||
warn () {
|
||||
echo "$*"
|
||||
} >&2
|
||||
|
||||
die () {
|
||||
echo
|
||||
echo "$*"
|
||||
echo
|
||||
exit 1
|
||||
} >&2
|
||||
|
||||
# OS specific support (must be 'true' or 'false').
|
||||
cygwin=false
|
||||
msys=false
|
||||
darwin=false
|
||||
nonstop=false
|
||||
case "$( uname )" in #(
|
||||
CYGWIN* ) cygwin=true ;; #(
|
||||
Darwin* ) darwin=true ;; #(
|
||||
MSYS* | MINGW* ) msys=true ;; #(
|
||||
NONSTOP* ) nonstop=true ;;
|
||||
esac
|
||||
|
||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||
|
||||
|
||||
# Determine the Java command to use to start the JVM.
|
||||
if [ -n "$JAVA_HOME" ] ; then
|
||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
||||
# IBM's JDK on AIX uses strange locations for the executables
|
||||
JAVACMD=$JAVA_HOME/jre/sh/java
|
||||
else
|
||||
JAVACMD=$JAVA_HOME/bin/java
|
||||
fi
|
||||
if [ ! -x "$JAVACMD" ] ; then
|
||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
else
|
||||
JAVACMD=java
|
||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
|
||||
# Increase the maximum file descriptors if we can.
|
||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
||||
case $MAX_FD in #(
|
||||
max*)
|
||||
MAX_FD=$( ulimit -H -n ) ||
|
||||
warn "Could not query maximum file descriptor limit"
|
||||
esac
|
||||
case $MAX_FD in #(
|
||||
'' | soft) :;; #(
|
||||
*)
|
||||
ulimit -n "$MAX_FD" ||
|
||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||
esac
|
||||
fi
|
||||
|
||||
# Collect all arguments for the java command, stacking in reverse order:
|
||||
# * args from the command line
|
||||
# * the main class name
|
||||
# * -classpath
|
||||
# * -D...appname settings
|
||||
# * --module-path (only if needed)
|
||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
|
||||
|
||||
# For Cygwin or MSYS, switch paths to Windows format before running java
|
||||
if "$cygwin" || "$msys" ; then
|
||||
APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
|
||||
CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
|
||||
|
||||
JAVACMD=$( cygpath --unix "$JAVACMD" )
|
||||
|
||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||
for arg do
|
||||
if
|
||||
case $arg in #(
|
||||
-*) false ;; # don't mess with options #(
|
||||
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
|
||||
[ -e "$t" ] ;; #(
|
||||
*) false ;;
|
||||
esac
|
||||
then
|
||||
arg=$( cygpath --path --ignore --mixed "$arg" )
|
||||
fi
|
||||
# Roll the args list around exactly as many times as the number of
|
||||
# args, so each arg winds up back in the position where it started, but
|
||||
# possibly modified.
|
||||
#
|
||||
# NB: a `for` loop captures its iteration list before it begins, so
|
||||
# changing the positional parameters here affects neither the number of
|
||||
# iterations, nor the values presented in `arg`.
|
||||
shift # remove old arg
|
||||
set -- "$@" "$arg" # push replacement arg
|
||||
done
|
||||
fi
|
||||
|
||||
# Collect all arguments for the java command;
|
||||
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
|
||||
# shell script including quotes and variable substitutions, so put them in
|
||||
# double quotes to make sure that they get re-expanded; and
|
||||
# * put everything else in single quotes, so that it's not re-expanded.
|
||||
|
||||
set -- \
|
||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \
|
||||
-classpath "$CLASSPATH" \
|
||||
org.gradle.wrapper.GradleWrapperMain \
|
||||
"$@"
|
||||
|
||||
# Use "xargs" to parse quoted args.
|
||||
#
|
||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
|
||||
#
|
||||
# In Bash we could simply go:
|
||||
#
|
||||
# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
|
||||
# set -- "${ARGS[@]}" "$@"
|
||||
#
|
||||
# but POSIX shell has neither arrays nor command substitution, so instead we
|
||||
# post-process each arg (as a line of input to sed) to backslash-escape any
|
||||
# character that might be a shell metacharacter, then use eval to reverse
|
||||
# that process (while maintaining the separation between arguments), and wrap
|
||||
# the whole thing up as a single "set" statement.
|
||||
#
|
||||
# This will of course break if any of these variables contains a newline or
|
||||
# an unmatched quote.
|
||||
#
|
||||
|
||||
eval "set -- $(
|
||||
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
|
||||
xargs -n1 |
|
||||
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
|
||||
tr '\n' ' '
|
||||
)" '"$@"'
|
||||
|
||||
exec "$JAVACMD" "$@"
|
89
gradlew.bat
vendored
Normal file
89
gradlew.bat
vendored
Normal file
@ -0,0 +1,89 @@
|
||||
@rem
|
||||
@rem Copyright 2015 the original author or authors.
|
||||
@rem
|
||||
@rem Licensed under the Apache License, Version 2.0 (the "License");
|
||||
@rem you may not use this file except in compliance with the License.
|
||||
@rem You may obtain a copy of the License at
|
||||
@rem
|
||||
@rem https://www.apache.org/licenses/LICENSE-2.0
|
||||
@rem
|
||||
@rem Unless required by applicable law or agreed to in writing, software
|
||||
@rem distributed under the License is distributed on an "AS IS" BASIS,
|
||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
@rem See the License for the specific language governing permissions and
|
||||
@rem limitations under the License.
|
||||
@rem
|
||||
|
||||
@if "%DEBUG%" == "" @echo off
|
||||
@rem ##########################################################################
|
||||
@rem
|
||||
@rem Gradle startup script for Windows
|
||||
@rem
|
||||
@rem ##########################################################################
|
||||
|
||||
@rem Set local scope for the variables with windows NT shell
|
||||
if "%OS%"=="Windows_NT" setlocal
|
||||
|
||||
set DIRNAME=%~dp0
|
||||
if "%DIRNAME%" == "" set DIRNAME=.
|
||||
set APP_BASE_NAME=%~n0
|
||||
set APP_HOME=%DIRNAME%
|
||||
|
||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
|
||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
|
||||
|
||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
|
||||
|
||||
@rem Find java.exe
|
||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||
|
||||
set JAVA_EXE=java.exe
|
||||
%JAVA_EXE% -version >NUL 2>&1
|
||||
if "%ERRORLEVEL%" == "0" goto execute
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:findJavaFromJavaHome
|
||||
set JAVA_HOME=%JAVA_HOME:"=%
|
||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||
|
||||
if exist "%JAVA_EXE%" goto execute
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:execute
|
||||
@rem Setup the command line
|
||||
|
||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||
|
||||
|
||||
@rem Execute Gradle
|
||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
|
||||
|
||||
:end
|
||||
@rem End local scope for the variables with windows NT shell
|
||||
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||
|
||||
:fail
|
||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||
rem the _cmd.exe /c_ return code!
|
||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||
exit /b 1
|
||||
|
||||
:mainEnd
|
||||
if "%OS%"=="Windows_NT" endlocal
|
||||
|
||||
:omega
|
99
pom.xml
99
pom.xml
@ -1,99 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>cn.lunadeer</groupId>
|
||||
<artifactId>Dominion</artifactId>
|
||||
<version>1.34.4-beta</version>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<name>Dominion</name>
|
||||
|
||||
<properties>
|
||||
<java.version>1.8</java.version>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
</properties>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<version>3.8.1</version>
|
||||
<configuration>
|
||||
<source>${java.version}</source>
|
||||
<target>${java.version}</target>
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-shade-plugin</artifactId>
|
||||
<version>3.2.4</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>shade</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
</plugins>
|
||||
<resources>
|
||||
<resource>
|
||||
<directory>src/main/resources</directory>
|
||||
<filtering>true</filtering>
|
||||
</resource>
|
||||
</resources>
|
||||
</build>
|
||||
|
||||
<repositories>
|
||||
<repository>
|
||||
<id>spigotmc-repo</id>
|
||||
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
|
||||
</repository>
|
||||
<repository>
|
||||
<id>sonatype</id>
|
||||
<url>https://oss.sonatype.org/content/groups/public/</url>
|
||||
</repository>
|
||||
<repository>
|
||||
<id>papermc</id>
|
||||
<url>https://repo.papermc.io/repository/maven-public/</url>
|
||||
</repository>
|
||||
<repository>
|
||||
<id>jitpack.io</id>
|
||||
<url>https://jitpack.io</url>
|
||||
</repository>
|
||||
<repository>
|
||||
<id>lunadeer-repo</id>
|
||||
<url>https://ssl.lunadeer.cn:14454/repository/maven-snapshots/</url>
|
||||
</repository>
|
||||
</repositories>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>dev.folia</groupId>
|
||||
<artifactId>folia-api</artifactId>
|
||||
<version>1.20.1-R0.1-SNAPSHOT</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>cn.lunadeer</groupId>
|
||||
<artifactId>MinecraftPluginUtils</artifactId>
|
||||
<version>1.3.4-SNAPSHOT</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.github.BlueMap-Minecraft</groupId>
|
||||
<artifactId>BlueMapAPI</artifactId>
|
||||
<version>v2.6.2</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.yaml</groupId>
|
||||
<artifactId>snakeyaml</artifactId>
|
||||
<version>2.0</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
7
settings.gradle.kts
Normal file
7
settings.gradle.kts
Normal file
@ -0,0 +1,7 @@
|
||||
rootProject.name = "Dominion"
|
||||
|
||||
include(
|
||||
"core",
|
||||
"v1_20_1",
|
||||
"v1_21"
|
||||
)
|
@ -1,454 +0,0 @@
|
||||
package cn.lunadeer.dominion;
|
||||
|
||||
import cn.lunadeer.dominion.dtos.*;
|
||||
import cn.lunadeer.dominion.utils.ResMigration;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.ParticleRender;
|
||||
import cn.lunadeer.minecraftpluginutils.Scheduler;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.GameMode;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
import java.time.LocalDateTime;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
import java.util.concurrent.atomic.AtomicBoolean;
|
||||
import java.util.concurrent.atomic.AtomicLong;
|
||||
|
||||
import static cn.lunadeer.dominion.DominionNode.getLocInDominionDTO;
|
||||
|
||||
public class Cache {
|
||||
|
||||
public Cache() {
|
||||
player_current_dominion_id = new HashMap<>();
|
||||
loadDominions();
|
||||
loadPlayerPrivileges();
|
||||
loadGroup();
|
||||
}
|
||||
|
||||
/**
|
||||
* 从数据库加载所有领地
|
||||
* 如果idToLoad为null,则加载所有领地
|
||||
*
|
||||
* @param idToLoad 领地ID
|
||||
*/
|
||||
public void loadDominions(Integer idToLoad) {
|
||||
if (_last_update_dominion.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadDominionsExecution directly");
|
||||
loadDominionsExecution(idToLoad);
|
||||
} else {
|
||||
if (_update_dominion_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadDominionsExecution");
|
||||
_update_dominion_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_dominion.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadDominionsExecution scheduled");
|
||||
loadDominionsExecution(idToLoad);
|
||||
_update_dominion_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
public void loadDominions() {
|
||||
loadDominions(null);
|
||||
}
|
||||
|
||||
private void loadDominionsExecution(Integer idToLoad) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
int count = 0;
|
||||
if (idToLoad == null) {
|
||||
id_dominions = new ConcurrentHashMap<>();
|
||||
world_dominion_tree = new ConcurrentHashMap<>();
|
||||
dominion_children = new ConcurrentHashMap<>();
|
||||
List<DominionDTO> dominions = DominionDTO.selectAll();
|
||||
count = dominions.size();
|
||||
Map<String, List<DominionDTO>> world_dominions = new HashMap<>();
|
||||
for (DominionDTO d : dominions) {
|
||||
if (!world_dominions.containsKey(d.getWorld())) {
|
||||
world_dominions.put(d.getWorld(), new ArrayList<>());
|
||||
}
|
||||
world_dominions.get(d.getWorld()).add(d);
|
||||
id_dominions.put(d.getId(), d);
|
||||
if (!dominion_children.containsKey(d.getParentDomId())) {
|
||||
dominion_children.put(d.getParentDomId(), new ArrayList<>());
|
||||
}
|
||||
dominion_children.get(d.getParentDomId()).add(d.getId());
|
||||
}
|
||||
for (Map.Entry<String, List<DominionDTO>> entry : world_dominions.entrySet()) {
|
||||
world_dominion_tree.put(entry.getKey(), DominionNode.BuildNodeTree(-1, entry.getValue()));
|
||||
}
|
||||
} else {
|
||||
DominionDTO dominion = DominionDTO.select(idToLoad);
|
||||
if (dominion == null && id_dominions.containsKey(idToLoad)) {
|
||||
id_dominions.remove(idToLoad);
|
||||
} else if (dominion != null) {
|
||||
id_dominions.put(idToLoad, dominion);
|
||||
count = 1;
|
||||
}
|
||||
}
|
||||
BlueMapConnect.render();
|
||||
recheckPlayerState = true;
|
||||
_last_update_dominion.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadDominionsExecution cost: %d ms for %d dominions"
|
||||
, System.currentTimeMillis() - start, count);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 从数据库加载所有玩家特权
|
||||
* 如果player_uuid为null,则加载所有玩家的特权
|
||||
*
|
||||
* @param player_uuid 玩家UUID
|
||||
*/
|
||||
public void loadPlayerPrivileges(UUID player_uuid) {
|
||||
if (_last_update_privilege.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadPlayerPrivilegesExecution directly");
|
||||
loadPlayerPrivilegesExecution(player_uuid);
|
||||
} else {
|
||||
if (_update_privilege_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadPlayerPrivilegesExecution");
|
||||
_update_privilege_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_privilege.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadPlayerPrivilegesExecution scheduled");
|
||||
loadPlayerPrivilegesExecution(player_uuid);
|
||||
_update_privilege_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
public void loadPlayerPrivileges() {
|
||||
loadPlayerPrivileges(null);
|
||||
}
|
||||
|
||||
private void loadPlayerPrivilegesExecution(UUID player_to_update) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
List<PlayerPrivilegeDTO> all_privileges;
|
||||
if (player_to_update == null) {
|
||||
all_privileges = PlayerPrivilegeDTO.selectAll();
|
||||
player_uuid_to_privilege = new ConcurrentHashMap<>();
|
||||
} else {
|
||||
all_privileges = PlayerPrivilegeDTO.selectAll(player_to_update);
|
||||
if (!player_uuid_to_privilege.containsKey(player_to_update)) {
|
||||
player_uuid_to_privilege.put(player_to_update, new ConcurrentHashMap<>());
|
||||
}
|
||||
player_uuid_to_privilege.get(player_to_update).clear();
|
||||
}
|
||||
for (PlayerPrivilegeDTO privilege : all_privileges) {
|
||||
UUID player_uuid = privilege.getPlayerUUID();
|
||||
if (!player_uuid_to_privilege.containsKey(player_uuid)) {
|
||||
player_uuid_to_privilege.put(player_uuid, new ConcurrentHashMap<>());
|
||||
}
|
||||
player_uuid_to_privilege.get(player_uuid).put(privilege.getDomID(), privilege);
|
||||
}
|
||||
recheckPlayerState = true;
|
||||
_last_update_privilege.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadPlayerPrivilegesExecution cost: %d ms for %d privileges"
|
||||
, System.currentTimeMillis() - start, all_privileges.size());
|
||||
});
|
||||
}
|
||||
|
||||
public void loadGroup() {
|
||||
loadGroup(null);
|
||||
}
|
||||
|
||||
public void loadGroup(Integer groupId) {
|
||||
if (_last_update_group.get() + UPDATE_INTERVAL < System.currentTimeMillis()) {
|
||||
XLogger.debug("run loadGroupExecution directly");
|
||||
loadGroupExecution(groupId);
|
||||
} else {
|
||||
if (_update_group_is_scheduled.get()) return;
|
||||
XLogger.debug("schedule loadGroupExecution");
|
||||
_update_group_is_scheduled.set(true);
|
||||
long delay_tick = (UPDATE_INTERVAL - (System.currentTimeMillis() - _last_update_group.get())) / 1000 * 20L;
|
||||
Scheduler.runTaskLaterAsync(() -> {
|
||||
XLogger.debug("run loadGroupExecution scheduled");
|
||||
loadGroupExecution(groupId);
|
||||
_update_group_is_scheduled.set(false);
|
||||
},
|
||||
delay_tick);
|
||||
}
|
||||
}
|
||||
|
||||
private void loadGroupExecution(Integer groupId) {
|
||||
Scheduler.runTaskAsync(() -> {
|
||||
long start = System.currentTimeMillis();
|
||||
if (groupId == null) {
|
||||
id_groups = new ConcurrentHashMap<>();
|
||||
List<GroupDTO> groups = GroupDTO.selectAll();
|
||||
for (GroupDTO group : groups) {
|
||||
id_groups.put(group.getId(), group);
|
||||
}
|
||||
} else {
|
||||
GroupDTO group = GroupDTO.select(groupId);
|
||||
if (group == null && id_groups.containsKey(groupId)) {
|
||||
id_groups.remove(groupId);
|
||||
} else if (group != null) {
|
||||
id_groups.put(groupId, group);
|
||||
}
|
||||
}
|
||||
recheckPlayerState = true;
|
||||
_last_update_group.set(System.currentTimeMillis());
|
||||
XLogger.debug("loadGroupExecution cost: %d ms", System.currentTimeMillis() - start);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取玩家当前所在领地
|
||||
* 此方法会先判断缓存中是否有玩家当前所在领地,如果没有则遍历所有领地判断玩家所在位置
|
||||
* 如果玩家不在任何领地内,则返回null
|
||||
* 如果玩家在领地内,则返回领地信息
|
||||
*
|
||||
* @param player 玩家
|
||||
* @return 玩家当前所在领地
|
||||
*/
|
||||
public DominionDTO getPlayerCurrentDominion(Player player) {
|
||||
Integer last_in_dom_id = player_current_dominion_id.get(player.getUniqueId());
|
||||
DominionDTO last_dominion = null;
|
||||
if (last_in_dom_id != null) {
|
||||
last_dominion = id_dominions.get(last_in_dom_id);
|
||||
}
|
||||
if (isInDominion(last_dominion, player)) {
|
||||
if (dominion_children.get(last_in_dom_id) == null || dominion_children.get(last_in_dom_id).size() == 0) {
|
||||
// 如果玩家仍在领地内,且领地没有子领地,则直接返回
|
||||
if (recheckPlayerState) {
|
||||
lightOrNot(player, last_dominion);
|
||||
flyOrNot(player, last_dominion);
|
||||
recheckPlayerState = false;
|
||||
}
|
||||
return last_dominion;
|
||||
}
|
||||
}
|
||||
DominionDTO current_dominion = getLocInDominionDTO(world_dominion_tree.get(player.getWorld().getName()), player.getLocation());
|
||||
int last_dom_id = last_dominion == null ? -1 : last_dominion.getId();
|
||||
int current_dom_id = current_dominion == null ? -1 : current_dominion.getId();
|
||||
if (last_dom_id == current_dom_id) {
|
||||
return last_dominion;
|
||||
}
|
||||
if (last_dom_id != -1) {
|
||||
String msg = last_dominion.getLeaveMessage();
|
||||
msg = msg.replace("${DOM_NAME}", last_dominion.getName());
|
||||
Notification.actionBar(player, msg);
|
||||
}
|
||||
if (current_dom_id != -1) {
|
||||
String msg = current_dominion.getJoinMessage();
|
||||
msg = msg.replace("${DOM_NAME}", current_dominion.getName());
|
||||
Notification.actionBar(player, msg);
|
||||
}
|
||||
|
||||
lightOrNot(player, current_dominion); // 发光检查
|
||||
flyOrNot(player, current_dominion); // 飞行检查
|
||||
if (current_dominion == null) {
|
||||
player_current_dominion_id.put(player.getUniqueId(), null);
|
||||
return null;
|
||||
}
|
||||
player_current_dominion_id.put(player.getUniqueId(), current_dominion.getId());
|
||||
// show border
|
||||
if (current_dominion.getFlagValue(Flag.SHOW_BORDER)) {
|
||||
ParticleRender.showBoxFace(Dominion.instance, player,
|
||||
current_dominion.getLocation1(),
|
||||
current_dominion.getLocation2());
|
||||
}
|
||||
return current_dominion;
|
||||
}
|
||||
|
||||
/**
|
||||
* 玩家退出时调用 用于清除玩家当前所在领地
|
||||
* 会将玩家当前所在领地设置为null
|
||||
* 这样当玩家下次进入领地时,会重新检查玩家所在位置
|
||||
*
|
||||
* @param player 玩家
|
||||
*/
|
||||
public void onPlayerQuit(Player player) {
|
||||
player_current_dominion_id.put(player.getUniqueId(), null);
|
||||
}
|
||||
|
||||
/**
|
||||
* 检查玩家是否需要设置为发光
|
||||
*
|
||||
* @param player 玩家
|
||||
* @param dominion 领地
|
||||
*/
|
||||
private void lightOrNot(Player player, DominionDTO dominion) {
|
||||
if (!Flag.GLOW.getEnable()) {
|
||||
return;
|
||||
}
|
||||
if (dominion == null) {
|
||||
player.setGlowing(false);
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = getPlayerPrivilege(player, dominion);
|
||||
if (privilege != null) {
|
||||
if (privilege.getGroupId() == -1) {
|
||||
player.setGlowing(privilege.getFlagValue(Flag.GLOW));
|
||||
} else {
|
||||
GroupDTO group = getGroup(privilege.getGroupId());
|
||||
if (group != null) {
|
||||
player.setGlowing(group.getFlagValue(Flag.GLOW));
|
||||
} else {
|
||||
player.setGlowing(dominion.getFlagValue(Flag.GLOW));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
player.setGlowing(dominion.getFlagValue(Flag.GLOW));
|
||||
}
|
||||
}
|
||||
|
||||
private void flyOrNot(Player player, DominionDTO dominion) {
|
||||
for (String flyPN : Dominion.config.getFlyPermissionNodes()) {
|
||||
if (player.hasPermission(flyPN)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (player.getGameMode() == GameMode.CREATIVE || player.getGameMode() == GameMode.SPECTATOR) {
|
||||
return;
|
||||
}
|
||||
if (player.isOp() && Dominion.config.getLimitOpBypass()) {
|
||||
return;
|
||||
}
|
||||
if (!Flag.FLY.getEnable()) {
|
||||
player.setAllowFlight(false);
|
||||
return;
|
||||
}
|
||||
if (dominion == null) {
|
||||
player.setAllowFlight(false);
|
||||
return;
|
||||
}
|
||||
PlayerPrivilegeDTO privilege = getPlayerPrivilege(player, dominion);
|
||||
if (privilege != null) {
|
||||
if (privilege.getGroupId() == -1) {
|
||||
player.setAllowFlight(privilege.getFlagValue(Flag.FLY));
|
||||
} else {
|
||||
GroupDTO group = getGroup(privilege.getGroupId());
|
||||
if (group != null) {
|
||||
player.setAllowFlight(group.getFlagValue(Flag.FLY));
|
||||
} else {
|
||||
player.setAllowFlight(dominion.getFlagValue(Flag.FLY));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
player.setAllowFlight(dominion.getFlagValue(Flag.FLY));
|
||||
}
|
||||
}
|
||||
|
||||
public DominionDTO getDominion(Location loc) {
|
||||
return getLocInDominionDTO(world_dominion_tree.get(loc.getWorld().getName()), loc);
|
||||
}
|
||||
|
||||
public List<DominionNode> getDominionTreeByPlayer(String player_name) {
|
||||
List<DominionNode> dominionTree = new ArrayList<>();
|
||||
PlayerDTO player = PlayerDTO.select(player_name);
|
||||
if (player == null) return dominionTree;
|
||||
for (List<DominionNode> tree : world_dominion_tree.values()) {
|
||||
for (DominionNode node : tree) {
|
||||
if (node.getDominion().getOwner().equals(player.getUuid())) {
|
||||
dominionTree.add(node);
|
||||
}
|
||||
}
|
||||
}
|
||||
return dominionTree;
|
||||
}
|
||||
|
||||
public List<DominionNode> getAllDominionTree() {
|
||||
List<DominionNode> dominionTree = new ArrayList<>();
|
||||
for (List<DominionNode> tree : world_dominion_tree.values()) {
|
||||
dominionTree.addAll(tree);
|
||||
}
|
||||
return dominionTree;
|
||||
}
|
||||
|
||||
public GroupDTO getGroup(Integer id) {
|
||||
return id_groups.get(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取玩家在指定领地的特权
|
||||
* 如果玩家不存在特权,则返回null
|
||||
*
|
||||
* @param player 玩家
|
||||
* @param dominion 领地
|
||||
* @return 特权表
|
||||
*/
|
||||
public PlayerPrivilegeDTO getPlayerPrivilege(Player player, DominionDTO dominion) {
|
||||
if (!player_uuid_to_privilege.containsKey(player.getUniqueId())) return null;
|
||||
return player_uuid_to_privilege.get(player.getUniqueId()).get(dominion.getId());
|
||||
}
|
||||
|
||||
public PlayerPrivilegeDTO getPlayerPrivilege(UUID player_uuid, DominionDTO dominion) {
|
||||
if (!player_uuid_to_privilege.containsKey(player_uuid)) return null;
|
||||
return player_uuid_to_privilege.get(player_uuid).get(dominion.getId());
|
||||
}
|
||||
|
||||
private static boolean isInDominion(@Nullable DominionDTO dominion, Player player) {
|
||||
if (dominion == null) return false;
|
||||
if (!Objects.equals(dominion.getWorld(), player.getWorld().getName())) return false;
|
||||
double x = player.getLocation().getX();
|
||||
double y = player.getLocation().getY();
|
||||
double z = player.getLocation().getZ();
|
||||
return x >= dominion.getX1() && x <= dominion.getX2() &&
|
||||
y >= dominion.getY1() && y <= dominion.getY2() &&
|
||||
z >= dominion.getZ1() && z <= dominion.getZ2();
|
||||
}
|
||||
|
||||
public DominionDTO getDominion(Integer id) {
|
||||
return id_dominions.get(id);
|
||||
}
|
||||
|
||||
public int getPlayerDominionCount(UUID player_uuid) {
|
||||
int count = 0;
|
||||
for (DominionDTO dominion : id_dominions.values()) {
|
||||
if (dominion.getOwner().equals(player_uuid)) {
|
||||
count++;
|
||||
}
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
public List<ResMigration.ResidenceNode> getResidenceData(UUID player_uuid) {
|
||||
if (residence_data == null) {
|
||||
residence_data = new HashMap<>();
|
||||
List<ResMigration.ResidenceNode> residences = ResMigration.extractFromResidence(Dominion.instance);
|
||||
for (ResMigration.ResidenceNode node : residences) {
|
||||
if (node == null) {
|
||||
continue;
|
||||
}
|
||||
if (!residence_data.containsKey(node.owner)) {
|
||||
XLogger.debug("residence_data put %s", node.owner);
|
||||
residence_data.put(node.owner, new ArrayList<>());
|
||||
}
|
||||
residence_data.get(node.owner).add(node);
|
||||
}
|
||||
XLogger.debug("residence_data: %d", residence_data.size());
|
||||
}
|
||||
return residence_data.get(player_uuid);
|
||||
}
|
||||
|
||||
public List<DominionDTO> getDominions() {
|
||||
return new ArrayList<>(id_dominions.values());
|
||||
}
|
||||
|
||||
public static Cache instance;
|
||||
private ConcurrentHashMap<Integer, DominionDTO> id_dominions;
|
||||
private ConcurrentHashMap<String, List<DominionNode>> world_dominion_tree;
|
||||
private ConcurrentHashMap<Integer, GroupDTO> id_groups;
|
||||
private ConcurrentHashMap<UUID, ConcurrentHashMap<Integer, PlayerPrivilegeDTO>> player_uuid_to_privilege; // 玩家所有的特权
|
||||
private final Map<UUID, Integer> player_current_dominion_id; // 玩家当前所在领地
|
||||
private ConcurrentHashMap<Integer, List<Integer>> dominion_children;
|
||||
private final AtomicLong _last_update_dominion = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_dominion_is_scheduled = new AtomicBoolean(false);
|
||||
private final AtomicLong _last_update_privilege = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_privilege_is_scheduled = new AtomicBoolean(false);
|
||||
private final AtomicLong _last_update_group = new AtomicLong(0);
|
||||
private final AtomicBoolean _update_group_is_scheduled = new AtomicBoolean(false);
|
||||
private static final long UPDATE_INTERVAL = 1000 * 4;
|
||||
private boolean recheckPlayerState = false; // 是否需要重新检查玩家状态(发光、飞行)
|
||||
public final Map<UUID, LocalDateTime> NextTimeAllowTeleport = new java.util.HashMap<>();
|
||||
|
||||
private Map<UUID, List<ResMigration.ResidenceNode>> residence_data = null;
|
||||
}
|
@ -1,69 +0,0 @@
|
||||
package cn.lunadeer.dominion.commands;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
public class Apis {
|
||||
public static Player playerOnly(CommandSender sender) {
|
||||
if (!(sender instanceof Player)) {
|
||||
Notification.error(sender, "该命令只能由玩家执行");
|
||||
return null;
|
||||
}
|
||||
return (Player) sender;
|
||||
}
|
||||
|
||||
public static void sizeInfo(CommandSender sender, DominionDTO dominionDTO) {
|
||||
Integer x1 = dominionDTO.getX1();
|
||||
Integer y1 = dominionDTO.getY1();
|
||||
Integer z1 = dominionDTO.getZ1();
|
||||
Integer x2 = dominionDTO.getX2();
|
||||
Integer y2 = dominionDTO.getY2();
|
||||
Integer z2 = dominionDTO.getZ2();
|
||||
Notification.info(sender, "领地 %s 的尺寸信息:", dominionDTO.getName());
|
||||
Notification.info(sender, " 大小: %d x %d x %d", x2 - x1, y2 - y1, z2 - z1);
|
||||
Notification.info(sender, " 中心坐标: %d %d %d", x1 + (x2 - x1) / 2, y1 + (y2 - y1) / 2, z1 + (z2 - z1) / 2);
|
||||
Notification.info(sender, " 高度: %d", y2 - y1);
|
||||
Notification.info(sender, " Y坐标范围: %d ~ %d", y1, y2);
|
||||
Notification.info(sender, " 体积: %d", (x2 - x1) * (y2 - y1) * (z2 - z1));
|
||||
Notification.info(sender, " 领地所在世界: %s", dominionDTO.getWorld());
|
||||
Notification.info(sender, " 领地的对角点坐标: x1=%d y1=%d z1=%d, x2=%d y2=%d z2=%d", x1, y1, z1, x2, y2, z2);
|
||||
}
|
||||
|
||||
public static void autoPoints(Player player) {
|
||||
Integer size = Dominion.config.getAutoCreateRadius();
|
||||
Location location = player.getLocation();
|
||||
Location location1 = new Location(location.getWorld(), location.getX() - size, location.getY() - size, location.getZ() - size);
|
||||
Location location2 = new Location(location.getWorld(), location.getX() + size, location.getY() + size, location.getZ() + size);
|
||||
if (Dominion.config.getLimitVert()) {
|
||||
location1.setY(Dominion.config.getLimitMinY());
|
||||
location2.setY(Dominion.config.getLimitMaxY());
|
||||
}
|
||||
Map<Integer, Location> points = new HashMap<>();
|
||||
points.put(0, location1);
|
||||
points.put(1, location2);
|
||||
Dominion.pointsSelect.put(player.getUniqueId(), points);
|
||||
}
|
||||
|
||||
public static boolean notOpOrConsole(CommandSender sender) {
|
||||
if (sender instanceof Player) {
|
||||
Player player = (Player) sender;
|
||||
if (!player.isOp()) {
|
||||
Notification.warn(player, "你没有权限使用此命令");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public static String CommandParser(String command, Object... args) {
|
||||
return String.format(command, args);
|
||||
}
|
||||
|
||||
}
|
@ -1,173 +0,0 @@
|
||||
package cn.lunadeer.dominion.events;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.entity.*;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.EventPriority;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.block.Action;
|
||||
import org.bukkit.event.block.BlockFromToEvent;
|
||||
import org.bukkit.event.block.BlockIgniteEvent;
|
||||
import org.bukkit.event.entity.CreatureSpawnEvent;
|
||||
import org.bukkit.event.entity.EntityDeathEvent;
|
||||
import org.bukkit.event.entity.EntityExplodeEvent;
|
||||
import org.bukkit.event.entity.EntityTeleportEvent;
|
||||
import org.bukkit.event.player.PlayerInteractEvent;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.events.Apis.checkFlag;
|
||||
import static org.bukkit.Material.FARMLAND;
|
||||
|
||||
public class EnvironmentEvents implements Listener {
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // creeper_explode
|
||||
public void onEntityExplode(EntityExplodeEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.CREEPER
|
||||
&& entity.getType() != EntityType.WITHER_SKULL
|
||||
&& entity.getType() != EntityType.FIREBALL
|
||||
&& entity.getType() != EntityType.ENDER_CRYSTAL
|
||||
) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getLocation());
|
||||
checkFlag(dom, Flag.CREEPER_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // fire_spread
|
||||
public void onFireSpread(BlockIgniteEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
if (player != null) {
|
||||
// 如果点燃事件没有玩家触发,那么就是火焰蔓延
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getBlock().getLocation());
|
||||
checkFlag(dom, Flag.FIRE_SPREAD, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // flow_in_protection
|
||||
public void onLiquidFlowIn(BlockFromToEvent event) {
|
||||
Location from = event.getBlock().getLocation();
|
||||
Location to = event.getToBlock().getLocation();
|
||||
DominionDTO dom_to = Cache.instance.getDominion(to);
|
||||
if (dom_to == null) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom_from = Cache.instance.getDominion(from);
|
||||
if (dom_from != null) {
|
||||
if (Objects.equals(dom_from.getId(), dom_to.getId())) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
checkFlag(dom_to, Flag.FLOW_IN_PROTECTION, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // mob_drop_item
|
||||
public void onMobDropItem(EntityDeathEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity instanceof Player) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
if (dom == null) {
|
||||
return;
|
||||
}
|
||||
if (!Flag.MOB_DROP_ITEM.getEnable()) {
|
||||
return;
|
||||
}
|
||||
if (dom.getFlagValue(Flag.MOB_DROP_ITEM)) {
|
||||
return;
|
||||
}
|
||||
event.getDrops().clear();
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // tnt_explode
|
||||
public void onTntExplode(EntityExplodeEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.MINECART_TNT && entity.getType() != EntityType.PRIMED_TNT) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getLocation());
|
||||
checkFlag(dom, Flag.TNT_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // trample
|
||||
public void onFarmlandTrample(PlayerInteractEvent event) {
|
||||
if (event.getAction() != Action.PHYSICAL) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
if (block.getType() != FARMLAND) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
checkFlag(dom, Flag.TRAMPLE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // wither_spawn
|
||||
public void onWitherSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.WITHER) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.WITHER_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // ender_man spawn
|
||||
public void onEnderManSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ENDERMAN) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.ENDER_MAN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // ender_man escape
|
||||
public void onEnderManEscape(EntityTeleportEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ENDERMAN) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.ENDER_MAN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // monster_spawn
|
||||
public void onMonsterSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof Monster)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.MONSTER_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // animal_spawn
|
||||
public void onAnimalSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof Animals)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.ANIMAL_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // villager_spawn
|
||||
public void onVillagerSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.VILLAGER) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
checkFlag(dom, Flag.VILLAGER_SPAWN, event);
|
||||
}
|
||||
}
|
@ -1,13 +0,0 @@
|
||||
name: Dominion
|
||||
version: '${project.version}'
|
||||
main: cn.lunadeer.dominion.Dominion
|
||||
api-version: '1.20'
|
||||
load: STARTUP
|
||||
folia-supported: true
|
||||
loadbefore:
|
||||
- Vault
|
||||
commands:
|
||||
Dominion:
|
||||
description: 领地插件命令
|
||||
usage: /dominion <cmd>
|
||||
aliases: [dominion, dom]
|
17
v1_20_1/build.gradle.kts
Normal file
17
v1_20_1/build.gradle.kts
Normal file
@ -0,0 +1,17 @@
|
||||
plugins {
|
||||
id("java")
|
||||
}
|
||||
|
||||
java {
|
||||
toolchain.languageVersion.set(JavaLanguageVersion.of(21))
|
||||
}
|
||||
|
||||
// utf-8
|
||||
tasks.withType<JavaCompile> {
|
||||
options.encoding = "UTF-8"
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compileOnly(project(":core"))
|
||||
compileOnly("io.papermc.paper:paper-api:1.20.1-R0.1-SNAPSHOT")
|
||||
}
|
@ -0,0 +1,350 @@
|
||||
package cn.lunadeer.dominion.events_v1_20_1;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.minecraftpluginutils.XLogger;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.Tag;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.block.BlockFace;
|
||||
import org.bukkit.entity.*;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.EventPriority;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.block.Action;
|
||||
import org.bukkit.event.block.BlockFromToEvent;
|
||||
import org.bukkit.event.block.BlockIgniteEvent;
|
||||
import org.bukkit.event.block.BlockPistonExtendEvent;
|
||||
import org.bukkit.event.entity.*;
|
||||
import org.bukkit.event.hanging.HangingBreakByEntityEvent;
|
||||
import org.bukkit.event.hanging.HangingBreakEvent;
|
||||
import org.bukkit.event.inventory.InventoryMoveItemEvent;
|
||||
import org.bukkit.event.player.PlayerInteractEvent;
|
||||
import org.bukkit.inventory.Inventory;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
import static cn.lunadeer.dominion.utils.EventUtils.checkFlag;
|
||||
import static org.bukkit.Material.FARMLAND;
|
||||
|
||||
public class EnvironmentEvents implements Listener {
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // creeper_explode
|
||||
public void onEntityExplode(EntityExplodeEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
XLogger.debug("EntityExplodeEvent: " + entity.getType());
|
||||
if (isNotExplodeEntity(entity)) {
|
||||
return;
|
||||
}
|
||||
XLogger.debug("blockList" + event.blockList().size());
|
||||
event.blockList().removeIf(block -> {
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
return !checkFlag(dom, Flag.CREEPER_EXPLODE, null);
|
||||
});
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // creeper_explode - item frame
|
||||
public void onItemFrameExploded(HangingBreakByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (event.getCause() != HangingBreakEvent.RemoveCause.EXPLOSION) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.CREEPER_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // creeper_explode - item frame
|
||||
public void onItemFrameShot(ProjectileHitEvent event) {
|
||||
Entity hit = event.getHitEntity();
|
||||
if (hit == null) {
|
||||
return;
|
||||
}
|
||||
if (event.getEntity().getShooter() instanceof Player) {
|
||||
return;
|
||||
}
|
||||
if (!(hit instanceof Hanging)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(hit.getLocation());
|
||||
checkFlag(dom, Flag.CREEPER_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // creeper_explode - armor stand
|
||||
public void onArmorStandExploded(EntityDamageByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ARMOR_STAND) {
|
||||
return;
|
||||
}
|
||||
if (isNotExplodeEntity(event.getDamager())) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.CREEPER_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // item_frame_proj_damage
|
||||
public void removeSomeOnItemFrameByArrow(HangingBreakByEntityEvent event) {
|
||||
if (event.getCause() != HangingBreakEvent.RemoveCause.ENTITY) {
|
||||
return;
|
||||
}
|
||||
Entity remover = event.getRemover();
|
||||
if (!(remover instanceof Projectile projectile)) {
|
||||
return;
|
||||
}
|
||||
if (!(projectile.getShooter() instanceof Player)) {
|
||||
// 玩家破坏由 玩家 break 权限控制
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getEntity().getLocation());
|
||||
checkFlag(dom, Flag.ITEM_FRAME_PROJ_DAMAGE, event);
|
||||
}
|
||||
|
||||
private static boolean isNotExplodeEntity(Entity damager) {
|
||||
return damager.getType() != EntityType.CREEPER
|
||||
&& damager.getType() != EntityType.WITHER_SKULL
|
||||
&& damager.getType() != EntityType.FIREBALL
|
||||
&& damager.getType() != EntityType.ENDER_CRYSTAL
|
||||
&& damager.getType() != EntityType.SMALL_FIREBALL
|
||||
&& damager.getType() != EntityType.DRAGON_FIREBALL;
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // dragon_break_block
|
||||
public void onDragonBreakBlock(EntityExplodeEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ENDER_DRAGON) {
|
||||
return;
|
||||
}
|
||||
event.blockList().removeIf(block -> {
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
return !checkFlag(dom, Flag.DRAGON_BREAK_BLOCK, null);
|
||||
});
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // fire_spread
|
||||
public void onFireSpread(BlockIgniteEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
if (player != null) {
|
||||
// 如果点燃事件没有玩家触发,那么就是火焰蔓延
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getBlock().getLocation());
|
||||
checkFlag(dom, Flag.FIRE_SPREAD, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // flow_in_protection
|
||||
public void onLiquidFlowIn(BlockFromToEvent event) {
|
||||
Location from = event.getBlock().getLocation();
|
||||
Location to = event.getToBlock().getLocation();
|
||||
DominionDTO dom_to = Cache.instance.getDominionByLoc(to);
|
||||
if (dom_to == null) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom_from = Cache.instance.getDominionByLoc(from);
|
||||
if (dom_from != null) {
|
||||
if (Objects.equals(dom_from.getId(), dom_to.getId())) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
checkFlag(dom_to, Flag.FLOW_IN_PROTECTION, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // mob_drop_item
|
||||
public void onMobDropItem(EntityDeathEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity instanceof Player) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
if (dom == null) {
|
||||
return;
|
||||
}
|
||||
if (!Flag.MOB_DROP_ITEM.getEnable()) {
|
||||
return;
|
||||
}
|
||||
if (dom.getFlagValue(Flag.MOB_DROP_ITEM)) {
|
||||
return;
|
||||
}
|
||||
event.getDrops().clear();
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // tnt_explode
|
||||
public void onTntExplode(EntityExplodeEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.MINECART_TNT && entity.getType() != EntityType.PRIMED_TNT) {
|
||||
return;
|
||||
}
|
||||
event.blockList().removeIf(block -> {
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
return !checkFlag(dom, Flag.TNT_EXPLODE, null);
|
||||
});
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // tnt_explode - entity
|
||||
public void onArmorStandExplodedByTnt(EntityDamageByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
Entity harmer = event.getDamager();
|
||||
if (harmer.getType() != EntityType.MINECART_TNT && harmer.getType() != EntityType.PRIMED_TNT) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.TNT_EXPLODE, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // trample
|
||||
public void onFarmlandTrample(PlayerInteractEvent event) {
|
||||
if (event.getAction() != Action.PHYSICAL) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
if (block.getType() != FARMLAND) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.TRAMPLE, event);
|
||||
}
|
||||
|
||||
/*
|
||||
TRIG_PRESSURE_PROJ("trig_pressure_proj", "投掷物触发压力板", "投掷物(箭/风弹/雪球)是否可以触发压力板", false, true, true),
|
||||
TRIG_PRESSURE_MOB("trig_pressure_mob", "生物触发压力板", "生物(不包含玩家)是否可以触发压力板", false, true, true),
|
||||
TRIG_PRESSURE_DROP("trig_pressure_drop", "掉落物触发压力板", "掉落物是否可以触发压力板", false, true, true),
|
||||
*/
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // trig_pressure_proj
|
||||
public void onPressurePlateTriggeredByProjectile(EntityInteractEvent event) {
|
||||
if (!(event.getEntity() instanceof Projectile)) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getBlock();
|
||||
if (!Tag.PRESSURE_PLATES.isTagged(block.getType())) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.TRIG_PRESSURE_PROJ, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // trig_pressure_mob
|
||||
public void onPressurePlateTriggeredByMob(EntityInteractEvent event) {
|
||||
if (!(event.getEntity() instanceof Mob)) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getBlock();
|
||||
if (!Tag.PRESSURE_PLATES.isTagged(block.getType())) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.TRIG_PRESSURE_MOB, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // trig_pressure_drop
|
||||
public void onPressurePlateTriggeredByDrop(EntityInteractEvent event) {
|
||||
if (!(event.getEntity() instanceof Item)) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getBlock();
|
||||
if (!Tag.PRESSURE_PLATES.isTagged(block.getType())) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.TRIG_PRESSURE_DROP, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // wither_spawn
|
||||
public void onWitherSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.WITHER) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.WITHER_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // ender_man spawn
|
||||
public void onEnderManSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ENDERMAN) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.ENDER_MAN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // ender_man escape
|
||||
public void onEnderManEscape(EntityTeleportEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ENDERMAN) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.ENDER_MAN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // monster_spawn
|
||||
public void onMonsterSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof Monster)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.MONSTER_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // animal_spawn
|
||||
public void onAnimalSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof Animals)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.ANIMAL_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // villager_spawn
|
||||
public void onVillagerSpawn(CreatureSpawnEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.VILLAGER) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.VILLAGER_SPAWN, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST)
|
||||
public void onHopper(InventoryMoveItemEvent event) {
|
||||
Inventory hopper = event.getDestination();
|
||||
Inventory inventory = event.getSource();
|
||||
DominionDTO hopperDom = Cache.instance.getDominionByLoc(hopper.getLocation());
|
||||
DominionDTO inventoryDom = Cache.instance.getDominionByLoc(inventory.getLocation());
|
||||
if (hopperDom == null && inventoryDom != null) {
|
||||
checkFlag(inventoryDom, Flag.HOPPER_OUTSIDE, event);
|
||||
}
|
||||
if (hopperDom != null && inventoryDom != null) {
|
||||
if (!hopperDom.getId().equals(inventoryDom.getId())) {
|
||||
checkFlag(inventoryDom, Flag.HOPPER_OUTSIDE, event);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST)
|
||||
public void onBlockPushedByPiston(BlockPistonExtendEvent event) {
|
||||
Block piston = event.getBlock();
|
||||
DominionDTO pistonDom = Cache.instance.getDominionByLoc(piston.getLocation());
|
||||
BlockFace direction = event.getDirection();
|
||||
Block endBlockAfterPush = piston.getRelative(direction, event.getBlocks().size() + 1);
|
||||
DominionDTO endBlockDom = Cache.instance.getDominionByLoc(endBlockAfterPush.getLocation());
|
||||
if (pistonDom != null && endBlockDom == null) {
|
||||
checkFlag(pistonDom, Flag.PISTON_OUTSIDE, event);
|
||||
}
|
||||
if (pistonDom == null && endBlockDom != null) {
|
||||
checkFlag(endBlockDom, Flag.PISTON_OUTSIDE, event);
|
||||
}
|
||||
if (pistonDom != null && endBlockDom != null) {
|
||||
if (!pistonDom.getId().equals(endBlockDom.getId())) {
|
||||
if (!endBlockDom.getFlagValue(Flag.PISTON_OUTSIDE) || !pistonDom.getFlagValue(Flag.PISTON_OUTSIDE)) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -1,9 +1,10 @@
|
||||
package cn.lunadeer.dominion.events;
|
||||
package cn.lunadeer.dominion.events_v1_20_1;
|
||||
|
||||
import cn.lunadeer.dominion.Cache;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.dtos.Flag;
|
||||
import cn.lunadeer.dominion.dtos.PlayerDTO;
|
||||
import cn.lunadeer.minecraftpluginutils.Common;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.Teleport;
|
||||
import org.bukkit.Location;
|
||||
@ -17,8 +18,10 @@ import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.block.*;
|
||||
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
||||
import org.bukkit.event.entity.EntityPlaceEvent;
|
||||
import org.bukkit.event.entity.ProjectileHitEvent;
|
||||
import org.bukkit.event.entity.ProjectileLaunchEvent;
|
||||
import org.bukkit.event.hanging.HangingBreakByEntityEvent;
|
||||
import org.bukkit.event.hanging.HangingBreakEvent;
|
||||
import org.bukkit.event.hanging.HangingPlaceEvent;
|
||||
import org.bukkit.event.inventory.InventoryOpenEvent;
|
||||
import org.bukkit.event.inventory.InventoryType;
|
||||
@ -28,8 +31,8 @@ import org.bukkit.inventory.Inventory;
|
||||
import org.bukkit.material.Colorable;
|
||||
import org.spigotmc.event.entity.EntityMountEvent;
|
||||
|
||||
import static cn.lunadeer.dominion.events.Apis.checkFlag;
|
||||
import static cn.lunadeer.dominion.events.Apis.getInvDominion;
|
||||
import static cn.lunadeer.dominion.utils.EventUtils.checkFlag;
|
||||
import static cn.lunadeer.dominion.utils.EventUtils.getInvDominion;
|
||||
|
||||
public class PlayerEvents implements Listener {
|
||||
@EventHandler
|
||||
@ -63,15 +66,14 @@ public class PlayerEvents implements Listener {
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // animal_killing
|
||||
public void onAnimalKilling(EntityDamageByEntityEvent event) {
|
||||
if (!(event.getDamager() instanceof Player)) {
|
||||
if (!(event.getDamager() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
// 如果不是动物 则不处理
|
||||
if (!(event.getEntity() instanceof Animals)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getDamager();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getEntity().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getEntity().getLocation());
|
||||
checkFlag(dom, Flag.ANIMAL_KILLING, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@ -80,10 +82,9 @@ public class PlayerEvents implements Listener {
|
||||
if (event.getInventory().getType() != InventoryType.ANVIL) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(bukkitPlayer);
|
||||
checkFlag(dom, Flag.ANVIL, bukkitPlayer, event);
|
||||
}
|
||||
@ -93,17 +94,16 @@ public class PlayerEvents implements Listener {
|
||||
if (event.getInventory().getType() != InventoryType.BEACON) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(bukkitPlayer);
|
||||
checkFlag(dom, Flag.BEACON, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // bed
|
||||
public void onBedUse(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = event.getPlayer();
|
||||
@ -114,7 +114,7 @@ public class PlayerEvents implements Listener {
|
||||
if (!(Tag.BEDS.isTagged(block.getType()))) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.BED, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@ -123,10 +123,9 @@ public class PlayerEvents implements Listener {
|
||||
if (event.getInventory().getType() != InventoryType.BREWING) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(bukkitPlayer);
|
||||
checkFlag(dom, Flag.BREW, bukkitPlayer, event);
|
||||
}
|
||||
@ -143,29 +142,46 @@ public class PlayerEvents implements Listener {
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // break - item frame
|
||||
public void onItemFrameBreak(HangingBreakByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof ItemFrame)) {
|
||||
if (event.getCause() != HangingBreakEvent.RemoveCause.ENTITY) {
|
||||
return;
|
||||
}
|
||||
ItemFrame itemFrame = (ItemFrame) entity;
|
||||
Entity remover = event.getRemover();
|
||||
if (!(remover instanceof Player)) {
|
||||
if (entity instanceof ItemFrame) {
|
||||
if (((ItemFrame) entity).getItem().getType() != Material.AIR) {
|
||||
if (!hasContainerPermission((Player) event.getRemover(), entity.getLocation())) {
|
||||
event.setCancelled(true);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (onBreak((Player) event.getRemover(), entity.getLocation())) {
|
||||
return;
|
||||
}
|
||||
if (onBreak((Player) event.getRemover(), itemFrame.getLocation())) {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // break - armor stand
|
||||
public void onArmorStandBreak(EntityDamageByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof ArmorStand)) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getDamager() instanceof Player)) {
|
||||
return;
|
||||
}
|
||||
if (onBreak((Player) event.getDamager(), entity.getLocation())) {
|
||||
return;
|
||||
}
|
||||
itemFrame.remove();
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
public static boolean onBreak(Player player, Location location) {
|
||||
DominionDTO dom = Cache.instance.getDominion(location);
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(location);
|
||||
return checkFlag(dom, Flag.BREAK_BLOCK, player, null);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // button
|
||||
public void onButton(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
@ -176,13 +192,13 @@ public class PlayerEvents implements Listener {
|
||||
if (!Tag.BUTTONS.isTagged(block.getType())) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.BUTTON, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // cake
|
||||
public void eatCake(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
@ -194,7 +210,7 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.CAKE, player, event);
|
||||
}
|
||||
|
||||
@ -204,7 +220,7 @@ public class PlayerEvents implements Listener {
|
||||
if (loc == null) {
|
||||
dom = null;
|
||||
} else {
|
||||
dom = Cache.instance.getDominion(loc);
|
||||
dom = Cache.instance.getDominionByLoc(loc);
|
||||
}
|
||||
return checkFlag(dom, Flag.CONTAINER, player, null);
|
||||
}
|
||||
@ -216,10 +232,9 @@ public class PlayerEvents implements Listener {
|
||||
event.getInventory().getType() != InventoryType.SHULKER_BOX) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
if (hasContainerPermission(bukkitPlayer, event.getInventory().getLocation())) {
|
||||
return;
|
||||
}
|
||||
@ -235,30 +250,56 @@ public class PlayerEvents implements Listener {
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // container (item frame)
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // container (item frame put)
|
||||
public void putSomeOnItemFrame(PlayerInteractEntityEvent event) {
|
||||
Entity entity = event.getRightClicked();
|
||||
if (!(entity instanceof ItemFrame)) {
|
||||
if (!(entity instanceof ItemFrame itemFrame)) {
|
||||
return;
|
||||
}
|
||||
if (itemFrame.getItem().getType() != Material.AIR) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = event.getPlayer();
|
||||
if (hasContainerPermission(bukkitPlayer, event.getRightClicked().getLocation())) {
|
||||
if (hasContainerPermission(bukkitPlayer, entity.getLocation())) {
|
||||
return;
|
||||
}
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // container (item frame)
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // container (item frame get)
|
||||
public void removeSomeOnItemFrame(EntityDamageByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof ItemFrame)) {
|
||||
if (!(entity instanceof ItemFrame itemFrame)) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getDamager() instanceof Player)) {
|
||||
if (itemFrame.getItem().getType() == Material.AIR) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getDamager();
|
||||
if (hasContainerPermission(bukkitPlayer, event.getEntity().getLocation())) {
|
||||
if (!(event.getDamager() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
if (hasContainerPermission(bukkitPlayer, entity.getLocation())) {
|
||||
return;
|
||||
}
|
||||
event.setCancelled(true);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // container (item frame get)
|
||||
public void removeSomeOnItemFrameByArrow(EntityDamageByEntityEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (!(entity instanceof ItemFrame itemFrame)) {
|
||||
return;
|
||||
}
|
||||
if (itemFrame.getItem().getType() == Material.AIR) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getDamager() instanceof Arrow arrow)) {
|
||||
return;
|
||||
}
|
||||
if (!(arrow.getShooter() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
if (hasContainerPermission(bukkitPlayer, itemFrame.getLocation())) {
|
||||
return;
|
||||
}
|
||||
event.setCancelled(true);
|
||||
@ -270,17 +311,30 @@ public class PlayerEvents implements Listener {
|
||||
if (inv.getType() != InventoryType.WORKBENCH) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = getInvDominion(bukkitPlayer, inv);
|
||||
checkFlag(dom, Flag.CRAFT, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // crafter
|
||||
public void onCrafterOpen(InventoryOpenEvent event) {
|
||||
Inventory inv = event.getInventory();
|
||||
// InventoryType.CRAFTER;
|
||||
if (!inv.getType().name().contains("CRAFTER")) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = getInvDominion(bukkitPlayer, inv);
|
||||
checkFlag(dom, Flag.CRAFTER, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // comparer
|
||||
public void comparerChange(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
@ -292,27 +346,41 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getClickedBlock().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getClickedBlock().getLocation());
|
||||
checkFlag(dom, Flag.COMPARER, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // door
|
||||
public void doorUse(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
if (!Tag.DOORS.isTagged(block.getType())) {
|
||||
if (!Tag.DOORS.isTagged(block.getType()) && !Tag.TRAPDOORS.isTagged(block.getType())) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getClickedBlock().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getClickedBlock().getLocation());
|
||||
checkFlag(dom, Flag.DOOR, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // dragon_egg
|
||||
public void touchDragonEdd(PlayerInteractEvent event) {
|
||||
Block block = event.getClickedBlock();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
if (block.getType() != Material.DRAGON_EGG) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.DRAGON_EGG, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // dye
|
||||
public void dyeEvent(PlayerInteractEntityEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
@ -320,13 +388,13 @@ public class PlayerEvents implements Listener {
|
||||
if (!(entity instanceof Colorable)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.DYE, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // edit sign
|
||||
public void onSignOpen(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
@ -337,7 +405,7 @@ public class PlayerEvents implements Listener {
|
||||
if (!(Tag.SIGNS.isTagged(block.getType()))) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.EDIT_SIGN, player, event);
|
||||
}
|
||||
|
||||
@ -345,19 +413,18 @@ public class PlayerEvents implements Listener {
|
||||
public void onSignEdit(SignChangeEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
Block block = event.getBlock();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.EDIT_SIGN, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // egg
|
||||
public void onThrowingEgg(ProjectileLaunchEvent event) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player)) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
if (event.getEntity().getType() != EntityType.EGG) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getEntity().getShooter();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(player);
|
||||
checkFlag(dom, Flag.EGG, player, event);
|
||||
}
|
||||
@ -367,23 +434,21 @@ public class PlayerEvents implements Listener {
|
||||
if (event.getInventory().getType() != InventoryType.ENCHANTING) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = getInvDominion(bukkitPlayer, event.getInventory());
|
||||
checkFlag(dom, Flag.ENCHANT, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // ender_pearl
|
||||
public void onThrowingEndPearl(ProjectileLaunchEvent event) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player)) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
if (event.getEntity().getType() != EntityType.ENDER_PEARL) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getEntity().getShooter();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(player);
|
||||
checkFlag(dom, Flag.ENDER_PEARL, player, event);
|
||||
}
|
||||
@ -398,7 +463,7 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getRightClicked().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getRightClicked().getLocation());
|
||||
checkFlag(dom, Flag.FEED, player, event);
|
||||
}
|
||||
|
||||
@ -424,13 +489,13 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.HARVEST, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // honey
|
||||
public void honeyInteractive(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
@ -442,7 +507,7 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.HONEY, player, event);
|
||||
}
|
||||
|
||||
@ -453,7 +518,7 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(caught.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(caught.getLocation());
|
||||
checkFlag(dom, Flag.HOOK, player, event);
|
||||
}
|
||||
|
||||
@ -468,10 +533,9 @@ public class PlayerEvents implements Listener {
|
||||
) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = getInvDominion(bukkitPlayer, event.getInventory());
|
||||
checkFlag(dom, Flag.HOPPER, bukkitPlayer, event);
|
||||
}
|
||||
@ -482,13 +546,28 @@ public class PlayerEvents implements Listener {
|
||||
if (player == null) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getBlock().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getBlock().getLocation());
|
||||
checkFlag(dom, Flag.IGNITE, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // item_frame_interactive
|
||||
public void onItemFrameInteractive(PlayerInteractEntityEvent event) {
|
||||
Entity entity = event.getRightClicked();
|
||||
if (!(entity instanceof ItemFrame itemFrame)) {
|
||||
return;
|
||||
}
|
||||
if (itemFrame.getItem().getType() == Material.AIR) {
|
||||
// 为空则当作容器处理见 putSomeOnItemFrame
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.ITEM_FRAME_INTERACTIVE, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // lever
|
||||
public void onLever(PlayerInteractEvent event) {
|
||||
if (!event.getAction().isRightClick()) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
@ -500,13 +579,13 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.LEVER, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // monster_killing
|
||||
public void onMonsterKilling(EntityDamageByEntityEvent event) {
|
||||
if (!(event.getDamager() instanceof Player)) {
|
||||
if (!(event.getDamager() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
// 如果不是怪物 则不处理
|
||||
@ -514,8 +593,7 @@ public class PlayerEvents implements Listener {
|
||||
if (!(entity instanceof Monster)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getDamager();
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.MONSTER_KILLING, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@ -543,15 +621,39 @@ public class PlayerEvents implements Listener {
|
||||
Teleport.doTeleportSafely(player, to).thenAccept((success) -> {
|
||||
if (!success) {
|
||||
Notification.warn(player, "传送失败,你将被传送到复活点");
|
||||
player.teleportAsync(player.getBedSpawnLocation() == null ?
|
||||
player.getWorld().getSpawnLocation() :
|
||||
player.getBedSpawnLocation()
|
||||
, PlayerTeleportEvent.TeleportCause.PLUGIN);
|
||||
Location bed = player.getBedSpawnLocation();
|
||||
if (bed == null) {
|
||||
bed = player.getWorld().getSpawnLocation();
|
||||
}
|
||||
if (Common.isPaper()) {
|
||||
player.teleportAsync(bed, PlayerTeleportEvent.TeleportCause.PLUGIN);
|
||||
} else {
|
||||
player.teleport(bed, PlayerTeleportEvent.TeleportCause.PLUGIN);
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // note_block
|
||||
public void onNoteBlockClicked(PlayerInteractEvent event) {
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
Material clicked = block.getType();
|
||||
if (clicked != Material.NOTE_BLOCK) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.NOTE_BLOCK, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // place
|
||||
public void onPlaceBlock(BlockPlaceEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
@ -573,9 +675,6 @@ public class PlayerEvents implements Listener {
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // place - item frame
|
||||
public void placeItemFrame(HangingPlaceEvent event) {
|
||||
Entity entity = event.getEntity();
|
||||
if (entity.getType() != EntityType.ITEM_FRAME && entity.getType() != EntityType.GLOW_ITEM_FRAME) {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
if (player == null) {
|
||||
return;
|
||||
@ -587,7 +686,7 @@ public class PlayerEvents implements Listener {
|
||||
}
|
||||
|
||||
public static boolean onPlace(Player player, Location location) {
|
||||
DominionDTO dom = Cache.instance.getDominion(location);
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(location);
|
||||
return checkFlag(dom, Flag.PLACE, player, null);
|
||||
}
|
||||
|
||||
@ -604,17 +703,16 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.PRESSURE, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // riding
|
||||
public void onRiding(EntityMountEvent event) {
|
||||
if (!(event.getEntity() instanceof Player)) {
|
||||
if (!(event.getEntity() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getEntity();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getMount().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getMount().getLocation());
|
||||
checkFlag(dom, Flag.RIDING, player, event);
|
||||
}
|
||||
|
||||
@ -629,28 +727,22 @@ public class PlayerEvents implements Listener {
|
||||
return;
|
||||
}
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(block.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(block.getLocation());
|
||||
checkFlag(dom, Flag.REPEATER, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // shear
|
||||
public void onShear(PlayerShearEntityEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getEntity().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getEntity().getLocation());
|
||||
checkFlag(dom, Flag.SHEAR, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // shoot
|
||||
public void onShootArrowSnowball(ProjectileLaunchEvent event) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player)) {
|
||||
public void onShootArrowSnowball(ProjectileHitEvent event) {
|
||||
if (!(event.getEntity().getShooter() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
if (event.getEntity().getType() != EntityType.ARROW &&
|
||||
event.getEntity().getType() != EntityType.SNOWBALL &&
|
||||
event.getEntity().getType() != EntityType.TRIDENT) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getEntity().getShooter();
|
||||
DominionDTO dom = Cache.instance.getPlayerCurrentDominion(player);
|
||||
checkFlag(dom, Flag.SHOOT, player, event);
|
||||
}
|
||||
@ -660,21 +752,19 @@ public class PlayerEvents implements Listener {
|
||||
if (event.getInventory().getType() != InventoryType.MERCHANT) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
if (!(event.getPlayer() instanceof Player bukkitPlayer)) {
|
||||
return;
|
||||
}
|
||||
Player bukkitPlayer = (Player) event.getPlayer();
|
||||
DominionDTO dom = getInvDominion(bukkitPlayer, event.getInventory());
|
||||
checkFlag(dom, Flag.TRADE, bukkitPlayer, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // vehicle_destroy
|
||||
public void onVehicleDestroy(VehicleDestroyEvent event) {
|
||||
if (!(event.getAttacker() instanceof Player)) {
|
||||
if (!(event.getAttacker() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getAttacker();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getVehicle().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getVehicle().getLocation());
|
||||
checkFlag(dom, Flag.VEHICLE_DESTROY, player, event);
|
||||
}
|
||||
|
||||
@ -688,20 +778,19 @@ public class PlayerEvents implements Listener {
|
||||
if (!(entity instanceof Vehicle)) {
|
||||
return;
|
||||
}
|
||||
DominionDTO dom = Cache.instance.getDominion(entity.getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(entity.getLocation());
|
||||
checkFlag(dom, Flag.VEHICLE_SPAWN, player, event);
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.HIGHEST) // villager_killing
|
||||
public void onVillagerKilling(EntityDamageByEntityEvent event) {
|
||||
if (!(event.getDamager() instanceof Player)) {
|
||||
if (!(event.getDamager() instanceof Player player)) {
|
||||
return;
|
||||
}
|
||||
if (!(event.getEntity() instanceof Villager)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getDamager();
|
||||
DominionDTO dom = Cache.instance.getDominion(event.getEntity().getLocation());
|
||||
DominionDTO dom = Cache.instance.getDominionByLoc(event.getEntity().getLocation());
|
||||
checkFlag(dom, Flag.VILLAGER_KILLING, player, event);
|
||||
}
|
||||
}
|
@ -0,0 +1,104 @@
|
||||
package cn.lunadeer.dominion.events_v1_20_1;
|
||||
|
||||
import cn.lunadeer.dominion.Dominion;
|
||||
import cn.lunadeer.dominion.dtos.DominionDTO;
|
||||
import cn.lunadeer.dominion.utils.Particle;
|
||||
import cn.lunadeer.minecraftpluginutils.Notification;
|
||||
import cn.lunadeer.minecraftpluginutils.VaultConnect.VaultConnect;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.EventPriority;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.block.Action;
|
||||
import org.bukkit.event.player.PlayerInteractEvent;
|
||||
import org.bukkit.inventory.ItemStack;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
public class SelectPointEvents implements Listener {
|
||||
@EventHandler(priority = EventPriority.HIGHEST)
|
||||
public void selectPoint(PlayerInteractEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
ItemStack item = player.getInventory().getItemInMainHand();
|
||||
|
||||
if (item.getType() != Dominion.config.getTool()) {
|
||||
return;
|
||||
}
|
||||
Block block = event.getClickedBlock();
|
||||
Action action = event.getAction();
|
||||
if (block == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
Map<Integer, Location> points = Dominion.pointsSelect.get(player.getUniqueId());
|
||||
if (points == null) {
|
||||
points = new HashMap<>();
|
||||
}
|
||||
|
||||
if (action == Action.LEFT_CLICK_BLOCK) {
|
||||
event.setCancelled(true);
|
||||
Notification.info(player, "已选择第一个点: %d %d %d", block.getX(), block.getY(), block.getZ());
|
||||
Location loc = block.getLocation();
|
||||
if (Dominion.config.getLimitVert(player)) {
|
||||
loc.setY(Dominion.config.getLimitMinY(player));
|
||||
}
|
||||
points.put(0, loc);
|
||||
} else if (action == Action.RIGHT_CLICK_BLOCK) {
|
||||
event.setCancelled(true);
|
||||
Notification.info(player, "已选择第二个点: %d %d %d", block.getX(), block.getY(), block.getZ());
|
||||
Location loc = block.getLocation();
|
||||
if (Dominion.config.getLimitVert(player)) {
|
||||
loc.setY(Dominion.config.getLimitMaxY(player) - 1);
|
||||
}
|
||||
points.put(1, loc);
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
Dominion.pointsSelect.put(player.getUniqueId(), points);
|
||||
|
||||
if (points.size() == 2) {
|
||||
World world = points.get(0).getWorld();
|
||||
if (world == null) {
|
||||
return;
|
||||
}
|
||||
if (!points.get(0).getWorld().equals(points.get(1).getWorld())) {
|
||||
Notification.warn(player, "两个点不在同一个世界");
|
||||
return;
|
||||
}
|
||||
Notification.info(player, "已选择两个点,可以使用 /dominion create <领地名称> 创建领地");
|
||||
Location loc1 = points.get(0);
|
||||
Location loc2 = points.get(1);
|
||||
int minX = Math.min(loc1.getBlockX(), loc2.getBlockX());
|
||||
int minY = Math.min(loc1.getBlockY(), loc2.getBlockY());
|
||||
int minZ = Math.min(loc1.getBlockZ(), loc2.getBlockZ());
|
||||
int maxX = Math.max(loc1.getBlockX(), loc2.getBlockX()) + 1;
|
||||
int maxY = Math.max(loc1.getBlockY(), loc2.getBlockY()) + 1;
|
||||
int maxZ = Math.max(loc1.getBlockZ(), loc2.getBlockZ()) + 1;
|
||||
DominionDTO dominion = new DominionDTO(player.getUniqueId(), "", loc1.getWorld(),
|
||||
minX, minY, minZ, maxX, maxY, maxZ);
|
||||
if (Dominion.config.getEconomyEnable()) {
|
||||
if (!VaultConnect.instance.economyAvailable()) {
|
||||
Notification.error(player, "计算价格失败,没有可用的经济插件系统,请联系服主。");
|
||||
return;
|
||||
}
|
||||
int count;
|
||||
if (Dominion.config.getEconomyOnlyXZ(player)) {
|
||||
count = dominion.getSquare();
|
||||
} else {
|
||||
count = dominion.getVolume();
|
||||
}
|
||||
float price = count * Dominion.config.getEconomyPrice(player);
|
||||
Notification.info(player, "预计领地创建价格为 %.2f %s", price, VaultConnect.instance.currencyNamePlural());
|
||||
}
|
||||
Particle.showBorder(player, dominion);
|
||||
Notification.info(player, "尺寸: %d x %d x %d", dominion.getWidthX(), dominion.getHeight(), dominion.getWidthZ());
|
||||
Notification.info(player, "面积: %d", dominion.getSquare());
|
||||
Notification.info(player, "高度: %d", dominion.getHeight());
|
||||
Notification.info(player, "体积: %d", dominion.getVolume());
|
||||
}
|
||||
}
|
||||
}
|
17
v1_21/build.gradle.kts
Normal file
17
v1_21/build.gradle.kts
Normal file
@ -0,0 +1,17 @@
|
||||
plugins {
|
||||
id("java")
|
||||
}
|
||||
|
||||
java {
|
||||
toolchain.languageVersion.set(JavaLanguageVersion.of(21))
|
||||
}
|
||||
|
||||
// utf-8
|
||||
tasks.withType<JavaCompile> {
|
||||
options.encoding = "UTF-8"
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compileOnly(project(":core"))
|
||||
compileOnly("io.papermc.paper:paper-api:1.21-R0.1-SNAPSHOT")
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user