diff --git a/.github/ISSUE_TEMPLATE/bugs_report.md b/.github/ISSUE_TEMPLATE/bugs_report.md new file mode 100644 index 0000000..e163a00 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/bugs_report.md @@ -0,0 +1,30 @@ +--- +name: 问题提交 +about: 提交并描述问题,帮助我们对其进行检查与修复。 +title: '' +labels: bug +assignees: '' + +--- + +**问题简述** +用简短的话语描述一下大概问题。 + +**问题来源** +描述一下通过哪些操作才发现的问题,如: +1. 打开 '...' +2. 点击了 '....' +3. 出现了报错 '....' + +**预期结果**(可选) +如果问题不发生,应该是什么情况 + +**问题截图/问题报错** +如果有报错或输出,请提供截图。 + +**操作环境** +请在后台输入 `version` 并复制相关输出。 + + +**其他补充** +如有其他补充,可以在这里描述。 diff --git a/.github/ISSUE_TEMPLATE/feature_issues.md b/.github/ISSUE_TEMPLATE/feature_issues.md new file mode 100644 index 0000000..b7e7f40 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/feature_issues.md @@ -0,0 +1,20 @@ +--- +name: 功能需求 +about: 希望我们提供更多的功能。 +title: '' +labels: enhancement +assignees: '' + +--- + +**功能简述** +简单的描述一下你想要的功能 + +**需求来源** +简单的描述一下为什么需要这个功能。 + +**功能参考**(可选) +如果有相关功能的参考,如文本、截图,请提供给我们。 + +**附加内容** +如果有什么小细节需要重点注意,请在这里告诉我们。 diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml new file mode 100644 index 0000000..cef8356 --- /dev/null +++ b/.github/workflows/deploy.yml @@ -0,0 +1,33 @@ +# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time +# For more information see: https://help.github.com/actions/language-and-framework-guides/building-and-testing-java-with-maven + +name: Deploy + +on: + # 支持手动触发构建 + workflow_dispatch: + release: + # 创建release的时候触发 + types: [ published ] + +jobs: + build: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + - name: "Set up JDK" + uses: actions/setup-java@v2 + with: + java-version: '11' + distribution: 'adopt' + cache: maven + server-id: github + server-username: MAVEN_USERNAME + server-password: MAVEN_TOKEN + - name: "Deploy" + run: mvn -B deploy --file pom.xml + env: + MAVEN_USERNAME: ${{ github.repository_owner }} + MAVEN_TOKEN: ${{secrets.GITHUB_TOKEN}} \ No newline at end of file diff --git a/.github/workflows/maven.yml b/.github/workflows/maven.yml new file mode 100644 index 0000000..913b96f --- /dev/null +++ b/.github/workflows/maven.yml @@ -0,0 +1,38 @@ +# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time +# For more information see: https://help.github.com/actions/language-and-framework-guides/building-and-testing-java-with-maven + +name: Build + +on: + # 支持手动触发构建 + workflow_dispatch: + push: + +jobs: + build: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + - name: "Set up JDK" + uses: actions/setup-java@v2 + with: + java-version: '11' + distribution: 'adopt' + cache: maven + server-id: github + server-username: MAVEN_USERNAME + server-password: MAVEN_TOKEN + - name: "Package" + run: mvn -B package --file pom.xml + env: + MAVEN_USERNAME: ${{ github.repository_owner }} + MAVEN_TOKEN: ${{secrets.GITHUB_TOKEN}} + - name: "Target Stage" + run: mkdir staging && cp target/*.jar staging + - name: "Upload artifact" + uses: actions/upload-artifact@v2 + with: + name: artifact + path: staging \ No newline at end of file diff --git a/.gitignore b/.gitignore index 1493170..8a6e898 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ +/.idea/ +/*.iml +/*/*.iml /target/ -TimeForFlight.iml -.idea/ \ No newline at end of file +/*/taget/ \ No newline at end of file diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml deleted file mode 100644 index 81f6f64..0000000 --- a/.gitlab-ci.yml +++ /dev/null @@ -1,22 +0,0 @@ - -stages: - - check - - build -# 构建 Job -check: - stage: check - tags: - - maven - script: - - mvn -v -build: - stage: build - tags: - - maven - script: - - mvn install - - ls ./target/*.jar - artifacts: - expire_in: 1 week - paths: - - ./target/*.jar diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..819d9fe --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2021 Carm + +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. diff --git a/README.md b/README.md new file mode 100644 index 0000000..55afb4b --- /dev/null +++ b/README.md @@ -0,0 +1,90 @@ +# TimeForFlight 限时飞行! + +![CodeSize](https://img.shields.io/github/languages/code-size/CarmJos/TimeForFlight) +[![License](https://img.shields.io/github/license/CarmJos/TimeForFlight)](https://opensource.org/licenses/mit-license.php) +[![Build](https://github.com/CarmJos/TimeForFlight/actions/workflows/maven.yml/badge.svg?branch=master)](https://github.com/CarmJos/TimeForFlight/actions/workflows/maven.yml) +![Support](https://img.shields.io/badge/Minecraft-Java%201.12--Latest-yellow) +![](https://visitor-badge.glitch.me/badge?page_id=TimeForFlight.readme) + +## 简介 + +本插件支持玩家通过在线游玩积攒飞行时间,并在需要的时候开关飞行! + +玩家数据将存储为YAML。 + +本插件基于Spigot实现,功能简单,运行稳定,**理论上支持全版本**。 + +本插件由 [桦木原Harmoland](https://www.mcbbs.net/thread-1028923-1-1.html) 请求本人开发,经过授权后开源。 + +## 依赖 + +- **[必须]** 插件本体基于 [Spigot-API](https://hub.spigotmc.org/stash/projects/SPIGOT) 、[BukkitAPI](http://bukkit.org/) 实现。 + +详细依赖列表可见 [Dependencies](https://github.com/CarmJos/TimeForFlight/network/dependencies) 。 + +## 指令 + +### 玩家指令 + +```text +# /toggleFly +- 开关飞行模式 +```~~~~ + +### 管理员指令 + +```text +# /TimeForFlight set <玩家> <秒数> +- 设置玩家的飞行时间 +# /TimeForFlight add <玩家> <秒数> +- 添加玩家的飞行时间 +# /TimeForFlight remove <玩家> <秒数> +- 移除玩家的飞行时间 +# /TimeForFlight get <玩家> +- 查看玩家的飞行时间 +# /TimeForFlight clear <玩家> +- 清空玩家的飞行时间 +# /TimeForFlight help +- 查看此帮助 +``` + +## 权限 + +```yaml +permissions: + timeforflight.admin: + default: op + description: "管理员权限" + timeforflight.unlimited: + default: op + description: "无限制飞行,不计算飞行时间" + timeforflight.allowflight: + description: "拥有此权限的玩家允许飞行" + timeforflight.getflighttime: + description: "拥有次权限的玩家会获赠飞行时间" +``` + +## 支持与捐赠 + +若您觉得本插件做的不错,您可以捐赠支持我! + +感谢您成为开源项目的支持者! + + + +## 开源协议 + +本项目源码采用 [The MIT License](https://opensource.org/licenses/mit-license.php) 开源协议。 + +> ### 关于 MIT 协议 +> MIT 协议可能是几大开源协议中最宽松的一个,核心条款是: +> +> 该软件及其相关文档对所有人免费,可以任意处置,包括使用,复制,修改,合并,发表,分发,再授权,或者销售。唯一的限制是,软件中必须包含上述版 权和许可提示。 +> +> 这意味着: +> - 你可以自由使用,复制,修改,可以用于自己的项目。 +> - 可以免费分发或用来盈利。 +> - 唯一的限制是必须包含许可声明。 +> - MIT 协议是所有开源许可中最宽松的一个,除了必须包含许可声明外,再无任何限制。 +> +> *以上文字来自 [五种开源协议GPL,LGPL,BSD,MIT,Apache](https://www.oschina.net/question/54100_9455) 。* diff --git a/TimeForFlight.iml b/TimeForFlight.iml deleted file mode 100644 index 78b2cc5..0000000 --- a/TimeForFlight.iml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/_lib/EssentialsX-2.18.0.0.jar b/_lib/EssentialsX-2.18.0.0.jar deleted file mode 100644 index 1ffb825..0000000 Binary files a/_lib/EssentialsX-2.18.0.0.jar and /dev/null differ diff --git a/_lib/EssentialsXChat-2.18.0.0.jar b/_lib/EssentialsXChat-2.18.0.0.jar deleted file mode 100644 index 1f15645..0000000 Binary files a/_lib/EssentialsXChat-2.18.0.0.jar and /dev/null differ diff --git a/_lib/EssentialsXProtect-2.18.0.0.jar b/_lib/EssentialsXProtect-2.18.0.0.jar deleted file mode 100644 index d8a816f..0000000 Binary files a/_lib/EssentialsXProtect-2.18.0.0.jar and /dev/null differ diff --git a/_lib/spigot-1.16.1.jar b/_lib/spigot-1.16.1.jar deleted file mode 100644 index a4574b5..0000000 Binary files a/_lib/spigot-1.16.1.jar and /dev/null differ diff --git a/pom.xml b/pom.xml index 601e12f..bdc23ff 100644 --- a/pom.xml +++ b/pom.xml @@ -4,63 +4,199 @@ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0 - com.carmwork - TimeForFlight - 1.0-SNAPSHOT + cc.carm.plugin + timeforflight + 1.0.0 jar - - - org.spigotmc - Spigot - 1.16.1 - system - ${basedir}/_lib/spigot-1.16.1.jar - - - net.ess3 - EssentialX - 2.18.0.0 - system - ${basedir}/_lib/EssentialsX-2.18.0.0.jar - - - net.ess3 - EssentialX-Protect - 2.18.0.0 - system - ${basedir}/_lib/EssentialsXProtect-2.18.0.0.jar - - - net.ess3 - EssentialX-Chat - 2.18.0.0 - system - ${basedir}/_lib/EssentialsXChat-2.18.0.0.jar - - - - - - - org.apache.maven.plugins - maven-compiler-plugin - - 1.8 - 1.8 - - UTF-8 - - - - - UTF-8 - 1.8 1.8 + TimeForFlight + 玩家通过在线游玩积攒飞行时间,并在需要的时候开关飞行! + https://github.com/CarmJos/TimeForFlight + + + GitHub Issues + ${project.url}/issues + + + + GitHub Actions + ${project.url}/actions/workflows/maven.yml + + + + + CarmJos + Carm Jos + carm@carm.cc + + Main Developer + + https://work.carm.cc + + + + + + The MIT License + https://opensource.org/licenses/mit-license.php + + + + + + + spigot-repo + https://hub.spigotmc.org/nexus/content/repositories/snapshots/ + + + + placeholder-api-repo + https://repo.extendedclip.com/content/repositories/placeholderapi/ + + + + oss-repo + https://oss.sonatype.org/content/groups/public/ + + + + luck-repo + https://repo.lucko.me/ + + + + maven-central + https://repo1.maven.org/maven2/ + + + + github + GitHub Packages + https://maven.pkg.github.com/CarmJos/${project.artifactId} + + + + + + github + GitHub Packages + https://maven.pkg.github.com/CarmJos/${project.artifactId} + + + + + + + org.spigotmc + spigot-api + 1.12.2-R0.1-SNAPSHOT + provided + + + + com.github.azbh111 + craftbukkit-1.12.2 + R + provided + + + + me.clip + placeholderapi + 2.10.9 + provided + + + + junit + junit + 4.13 + test + + + + + + + + + org.apache.maven.plugins + maven-compiler-plugin + 3.8.1 + + 1.8 + 1.8 + UTF-8 + -parameters + + + + org.apache.maven.plugins + maven-jar-plugin + 3.2.0 + + + org.apache.maven.plugins + maven-source-plugin + 3.2.0 + + + package + + jar-no-fork + + + + + + org.apache.maven.plugins + maven-shade-plugin + 3.2.3 + + + package + + shade + + + false + + + + + + + *:* + + META-INF/MANIFEST.MF + META-INF/*.txt + + + + + + + org.apache.maven.plugins + maven-surefire-plugin + 2.22.1 + + false + + + + + + src/main/resources + true + + + + \ No newline at end of file diff --git a/src/main/java/cc/carm/plugin/timeforflight/Main.java b/src/main/java/cc/carm/plugin/timeforflight/Main.java new file mode 100644 index 0000000..0a15cf0 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/Main.java @@ -0,0 +1,43 @@ +package cc.carm.plugin.timeforflight; + +import cc.carm.plugin.timeforflight.commands.TimeForFlightCommand; +import cc.carm.plugin.timeforflight.commands.ToggleFlyCommand; +import cc.carm.plugin.timeforflight.managers.ConfigManager; +import cc.carm.plugin.timeforflight.managers.DataManager; +import cc.carm.plugin.timeforflight.listeners.PlayerListener; +import org.bukkit.Bukkit; +import org.bukkit.plugin.java.JavaPlugin; + +import java.util.logging.Level; + +public class Main extends JavaPlugin { + + private static Main instance; + + public static Main getInstance() { + return Main.instance; + } + + @Override + public void onEnable() { + instance = this; + + logInfo("加载配置文件中"); + ConfigManager.loadConfig(); + + logInfo("注册指令"); + Main.getInstance().getCommand("TimeForFlight").setExecutor(new TimeForFlightCommand()); + Main.getInstance().getCommand("ToggleFly").setExecutor(new ToggleFlyCommand()); + + logInfo("注册监听器"); + Bukkit.getPluginManager().registerEvents(new PlayerListener(),this); + + logInfo("初始化数据管理"); + DataManager.init(); + } + + public static void logInfo(String message) { + Main.getInstance().getLogger().log(Level.INFO, message); + } + +} \ No newline at end of file diff --git a/src/main/java/cc/carm/plugin/timeforflight/commands/TimeForFlightCommand.java b/src/main/java/cc/carm/plugin/timeforflight/commands/TimeForFlightCommand.java new file mode 100644 index 0000000..4f8cbfc --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/commands/TimeForFlightCommand.java @@ -0,0 +1,154 @@ +package cc.carm.plugin.timeforflight.commands; + +import cc.carm.plugin.timeforflight.models.UserData; +import cc.carm.plugin.timeforflight.utils.MessageParser; +import cc.carm.plugin.timeforflight.enums.Permissions; +import cc.carm.plugin.timeforflight.managers.DataManager; +import cc.carm.plugin.timeforflight.utils.TimeFormat; +import com.google.common.collect.ImmutableList; +import org.bukkit.Bukkit; +import org.bukkit.OfflinePlayer; +import org.bukkit.command.Command; +import org.bukkit.command.CommandExecutor; +import org.bukkit.command.CommandSender; +import org.bukkit.command.TabCompleter; +import org.bukkit.entity.Player; +import org.bukkit.util.StringUtil; + +import java.util.ArrayList; +import java.util.List; + +/** + * 管理员管理、查看玩家飞行时间的指令 + */ +public class TimeForFlightCommand implements CommandExecutor, TabCompleter { + + public static boolean help(CommandSender sender) { + sendMessage(sender, "&6&l限时飞行 &7管理指令帮助"); + sendMessage(sender, "&8- &fset <玩家> <秒数> &7设置玩家的飞行时间 "); + sendMessage(sender, "&8- &fadd <玩家> <秒数> &7添加玩家的飞行时间 "); + sendMessage(sender, "&8- &fremove <玩家> <秒数> &7移除玩家的飞行时间 "); + sendMessage(sender, "&8- &fget <玩家> &7查看玩家的飞行时间 "); + sendMessage(sender, "&8- &fclear <玩家> &7清空玩家的飞行时间 "); + sendMessage(sender, "&8- &fhelp &7查看此帮助 "); + return true; + } + + public static boolean noPerm(CommandSender sender) { + sender.sendMessage(MessageParser.parseColor("&c抱歉!&7但您没有这么做的权限。")); + return true; + } + + public static void sendMessage(CommandSender sender, String message) { + sender.sendMessage(MessageParser.parseColor(message)); + } + + public static void sendMessage(Player player, String message) { + player.sendMessage(MessageParser.parseColor(message)); + } + + @Override + public boolean onCommand(CommandSender sender, Command command, String s, String[] args) { + if (!sender.hasPermission(Permissions.ADMIN.toString())) return noPerm(sender); + if (args.length > 3 || args.length < 2) return help(sender); + String aim = args[0].toLowerCase(); + if (args.length == 2) { + if (aim.equalsIgnoreCase("clear")) { + OfflinePlayer target = Bukkit.getOfflinePlayer(args[1]); + UserData targetData = DataManager.getData(target.getUniqueId()); + if (targetData.isFileLoaded() && targetData.getRemainTime() > 0) { + targetData.setTime(0); + } + DataManager.unloadData(target.getUniqueId()); + sendMessage(sender, "&f已清空玩家 " + target.getName() + " 的飞行时间。"); + return true; + } else if (aim.equalsIgnoreCase("get")) { + OfflinePlayer target = Bukkit.getOfflinePlayer(args[1]); + UserData targetData = DataManager.getData(target.getUniqueId()); + if (targetData.isFileLoaded() && targetData.getRemainTime() > 0) { + sendMessage(sender, "&f玩家" + target.getName() + " 的剩余飞行时间为 " + TimeFormat.getTimeString(targetData.getRemainTime()) + "。"); + } else { + sendMessage(sender, "&f玩家" + target.getName() + " 的剩余飞行时间为 " + TimeFormat.getTimeString(0) + "。"); + } + DataManager.unloadData(target.getUniqueId()); + + return true; + } else { + return help(sender); + } + + } else if (args.length == 3) { + if (aim.equalsIgnoreCase("add") || aim.equalsIgnoreCase("remove") || aim.equalsIgnoreCase("set")) { + int value; + try { + value = Integer.parseInt(args[2]); + } catch (Exception ignore) { + sendMessage(sender, "请填写正确的数字。"); + return true; + } + + + OfflinePlayer target = Bukkit.getOfflinePlayer(args[1]); + UserData targetData = DataManager.getData(target.getUniqueId()); + + if (aim.equalsIgnoreCase("add")) { + targetData.addTime(value); + sendMessage(sender, "成功为玩家 " + target.getName() + " 添加飞行时间 " + TimeFormat.getTimeString(value) + "。"); + } else if (aim.equalsIgnoreCase("remove")) { + targetData.removeTime(value); + sendMessage(sender, "成功为玩家 " + target.getName() + " 移除飞行时间 " + TimeFormat.getTimeString(value) + "。"); + } else if (aim.equalsIgnoreCase("set")) { + targetData.setTime(value); + sendMessage(sender, "成功设置玩家 " + target.getName() + " 的飞行时间 " + TimeFormat.getTimeString(value) + "。"); + } + DataManager.unloadData(target.getUniqueId()); + return true; + } else { + return help(sender); + } + } + return true; + } + + @Override + public List onTabComplete(CommandSender sender, Command command, String alias, String[] args) { + if (!sender.hasPermission(Permissions.ADMIN.toString())) { + return ImmutableList.of(); + } + switch (args.length) { + case 1: { + List completions = new ArrayList<>(); + List strings = new ArrayList<>(); + strings.add("help"); + strings.add("set"); + strings.add("add"); + strings.add("remove"); + strings.add("clear"); + for (String s : strings) { + if (StringUtil.startsWithIgnoreCase(s, args[0].toLowerCase())) { + completions.add(s); + } + } + return completions; + } + case 2: { + String aim = args[1]; + if (aim.equalsIgnoreCase("add") + || aim.equalsIgnoreCase("remove") + || aim.equalsIgnoreCase("set") + || aim.equalsIgnoreCase("clear")) { + List completions = new ArrayList<>(); + for (Player pl : Bukkit.getOnlinePlayers()) { + if (StringUtil.startsWithIgnoreCase(pl.getName(), args[1].toLowerCase())) { + completions.add(pl.getName()); + } + } + return completions; + } + } + default: + return ImmutableList.of(); + } + } + +} diff --git a/src/main/java/cc/carm/plugin/timeforflight/commands/ToggleFlyCommand.java b/src/main/java/cc/carm/plugin/timeforflight/commands/ToggleFlyCommand.java new file mode 100644 index 0000000..8b61713 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/commands/ToggleFlyCommand.java @@ -0,0 +1,122 @@ +package cc.carm.plugin.timeforflight.commands; + +import cc.carm.plugin.timeforflight.models.UserData; +import cc.carm.plugin.timeforflight.utils.MessageParser; +import cc.carm.plugin.timeforflight.enums.Permissions; +import cc.carm.plugin.timeforflight.managers.DataManager; +import cc.carm.plugin.timeforflight.utils.TimeFormat; +import org.bukkit.Bukkit; +import org.bukkit.command.Command; +import org.bukkit.command.CommandExecutor; +import org.bukkit.command.CommandSender; +import org.bukkit.entity.Player; + +/** + * 开关飞行的指令 + */ +public class ToggleFlyCommand implements CommandExecutor { + + + @Override + public boolean onCommand(CommandSender sender, Command command, String s, String[] args) { + if (!(sender instanceof Player)) { + sender.sendMessage(MessageParser.parseColor("该指令只允许玩家使用。")); + sender.sendMessage(MessageParser.parseColor("您可以输入 /togglefly <玩家名> 设置某个玩家的飞行状态。")); + return true; + } + + Player player = (Player) sender; + + UserData userData = DataManager.getData(player.getUniqueId()); + + if (args.length == 0 || !sender.isOp()) { + if (player.getAllowFlight()) { + // 在玩家开启飞行的状态之下 + if (player.hasPermission(Permissions.ALLOW_FLIGHT.toString()) || player.hasPermission(Permissions.UNLIMITED.toString())) { + userData.stopFly(player); + player.sendMessage(MessageParser.parseColor("§f已为您关闭飞行状态,剩余飞行时长 " + userData.getRemainTimeString() + " 。")); + return true; + } else { + sender.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); + } + } else { + //在玩家没有开启飞行的状态下 + if (player.hasPermission(Permissions.UNLIMITED.toString())) { + player.setAllowFlight(true); + player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); + return true; + } else if (player.hasPermission(Permissions.ALLOW_FLIGHT.toString())) { + if (userData.canFly()) { + userData.startFlyTask(player); + player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); + player.sendMessage(MessageParser.parseColor("&f剩余飞行时长 &a" + TimeFormat.getTimeString(userData.getRemainTime()))); + return true; + } else { + player.sendMessage(MessageParser.parseColor("&c您的飞行时长不足,无法开启飞行。")); + return true; + } + } else { + player.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); + return true; + } + } + + + } else if (args.length == 1) { + if (!sender.isOp()) { + sender.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); + return true; + } + + + Player target = Bukkit.getPlayer(args[0]); + if (target == null) { + sender.sendMessage("玩家 " + args[0] + " 不在线。"); + return true; + } + UserData targetData = DataManager.getData(target.getUniqueId()); + + if (target.getAllowFlight()) { + //在目标玩家正在飞行的状态下。 + if (target.hasPermission(Permissions.ALLOW_FLIGHT.toString()) || target.hasPermission(Permissions.UNLIMITED.toString())) { + userData.stopFly(target); + target.sendMessage(MessageParser.parseColor("§f已为您关闭飞行状态,剩余飞行时长 " + userData.getRemainTimeString() + " 。")); + return true; + } else { + sender.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); + } + } else { + //在目标玩家没有飞行的状态下 + if (target.hasPermission(Permissions.UNLIMITED.toString())) { + + target.setAllowFlight(true); + target.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); + sender.sendMessage(MessageParser.parseColor("已为玩家 " + target.getName() + " 开启飞行。")); + return true; + } else if (target.hasPermission(Permissions.ALLOW_FLIGHT.toString())) { + if (targetData.canFly()) { + targetData.startFlyTask(target); + target.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); + target.sendMessage(MessageParser.parseColor("&f剩余飞行时长 &a" + TimeFormat.getTimeString(userData.getRemainTime()))); + sender.sendMessage(MessageParser.parseColor("已为玩家 " + target.getName() + " 开启飞行。")); + + return true; + } else { + target.sendMessage(MessageParser.parseColor("&c您的飞行时长不足,无法开启飞行。")); + sender.sendMessage(MessageParser.parseColor("玩家 " + target.getName() + " 飞行时间不足。")); + return true; + } + } else { + sender.sendMessage(MessageParser.parseColor("玩家 " + target.getName() + " 没有飞行权限。")); + return true; + } + } + + } + + + return true; + } + + +} diff --git a/src/main/java/cc/carm/plugin/timeforflight/enums/Permissions.java b/src/main/java/cc/carm/plugin/timeforflight/enums/Permissions.java new file mode 100644 index 0000000..1ad1376 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/enums/Permissions.java @@ -0,0 +1,20 @@ +package cc.carm.plugin.timeforflight.enums; + +public enum Permissions { + UNLIMITED("timeforflight.unlimited"), + ALLOW_FLIGHT("timeforflight.allowflight"), + GET_TIME("timeforflight.getflighttime"), + ADMIN("timeforflight.admin"); + + String permissionNode; + + Permissions(String permissionNode) { + this.permissionNode = permissionNode; + } + + + public String getPermission() { + return permissionNode; + } + +} diff --git a/src/main/java/cc/carm/plugin/timeforflight/listeners/PlayerListener.java b/src/main/java/cc/carm/plugin/timeforflight/listeners/PlayerListener.java new file mode 100644 index 0000000..8599333 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/listeners/PlayerListener.java @@ -0,0 +1,35 @@ +package cc.carm.plugin.timeforflight.listeners; + +import cc.carm.plugin.timeforflight.managers.DataManager; +import cc.carm.plugin.timeforflight.models.UserData; +import cc.carm.plugin.timeforflight.enums.Permissions; +import org.bukkit.entity.Player; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.player.PlayerJoinEvent; +import org.bukkit.event.player.PlayerQuitEvent; + +public class PlayerListener implements Listener { + + @EventHandler + public void onJoin(PlayerJoinEvent event) { + Player player = event.getPlayer(); + UserData playerCache = DataManager.loadData(player.getUniqueId()); + if (player.hasPermission(Permissions.GET_TIME.toString()) + && !player.hasPermission(Permissions.UNLIMITED.toString())) { + playerCache.startGivenTask(player); + } + } + + + @EventHandler + public void onQuit(PlayerQuitEvent event) { + Player player = event.getPlayer(); + UserData playerCache = DataManager.getData(player.getUniqueId()); + + player.setAllowFlight(false); + player.setFlying(false); + + DataManager.unloadData(player.getUniqueId()); + } +} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/managers/ConfigManager.java b/src/main/java/cc/carm/plugin/timeforflight/managers/ConfigManager.java similarity index 88% rename from src/main/java/com/carmwork/plugin/timeforflight/managers/ConfigManager.java rename to src/main/java/cc/carm/plugin/timeforflight/managers/ConfigManager.java index 7bf2c4c..9043cc2 100644 --- a/src/main/java/com/carmwork/plugin/timeforflight/managers/ConfigManager.java +++ b/src/main/java/cc/carm/plugin/timeforflight/managers/ConfigManager.java @@ -1,7 +1,7 @@ -package com.carmwork.plugin.timeforflight.managers; +package cc.carm.plugin.timeforflight.managers; -import com.carmwork.plugin.timeforflight.Main; -import com.carmwork.plugin.timeforflight.utils.MessageParser; +import cc.carm.plugin.timeforflight.utils.MessageParser; +import cc.carm.plugin.timeforflight.Main; import org.bukkit.configuration.file.FileConfiguration; import java.util.Objects; diff --git a/src/main/java/com/carmwork/plugin/timeforflight/managers/DataManager.java b/src/main/java/cc/carm/plugin/timeforflight/managers/DataManager.java similarity index 53% rename from src/main/java/com/carmwork/plugin/timeforflight/managers/DataManager.java rename to src/main/java/cc/carm/plugin/timeforflight/managers/DataManager.java index 47e2995..a236edc 100644 --- a/src/main/java/com/carmwork/plugin/timeforflight/managers/DataManager.java +++ b/src/main/java/cc/carm/plugin/timeforflight/managers/DataManager.java @@ -1,37 +1,37 @@ -package com.carmwork.plugin.timeforflight.managers; +package cc.carm.plugin.timeforflight.managers; -import com.carmwork.plugin.timeforflight.Main; -import com.carmwork.plugin.timeforflight.models.UserData; +import cc.carm.plugin.timeforflight.models.UserData; +import cc.carm.plugin.timeforflight.Main; import java.io.File; import java.util.*; public class DataManager { - private static File userdatasFolder; + private static File userdataFolder; /** * 通过这个Map缓存玩家的数据 */ - public static Map userDatas = new HashMap<>(); + public static Map userDataCaches = new HashMap<>(); public static void init() { - userdatasFolder = new File(Main.getInstance().getDataFolder() + File.separator + "userdatas"); - if (!userdatasFolder.isDirectory() || !userdatasFolder.exists()) { - userdatasFolder.mkdir(); + userdataFolder = new File(Main.getInstance().getDataFolder() + File.separator + "userdata"); + if (!userdataFolder.isDirectory() || !userdataFolder.exists()) { + userdataFolder.mkdir(); } } public static UserData loadData(UUID uuid) { UserData prefixCache = new UserData(uuid); - userDatas.put(uuid, prefixCache); + userDataCaches.put(uuid, prefixCache); return prefixCache; } public static UserData getData(UUID uuid) { - return userDatas.getOrDefault(uuid, loadData(uuid)); + return userDataCaches.getOrDefault(uuid, loadData(uuid)); } public static void unloadData(UUID uuid) { @@ -40,13 +40,13 @@ public class DataManager { data.stopTasks(); data.saveData(); - userDatas.remove(uuid); + userDataCaches.remove(uuid); } } public static boolean isDataLoaded(UUID uuid) { - return userDatas.containsKey(uuid); + return userDataCaches.containsKey(uuid); } /** @@ -56,7 +56,7 @@ public class DataManager { * @return 是否已有数据 */ public static boolean hasData(UUID uuid) { - return Arrays.stream(Objects.requireNonNull(userdatasFolder.listFiles())) + return Arrays.stream(Objects.requireNonNull(userdataFolder.listFiles())) .anyMatch(file -> file.getName().startsWith(uuid.toString())); } diff --git a/src/main/java/cc/carm/plugin/timeforflight/models/UserData.java b/src/main/java/cc/carm/plugin/timeforflight/models/UserData.java new file mode 100644 index 0000000..269c8f8 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/models/UserData.java @@ -0,0 +1,182 @@ +package cc.carm.plugin.timeforflight.models; + +import cc.carm.plugin.timeforflight.Main; +import cc.carm.plugin.timeforflight.enums.Permissions; +import cc.carm.plugin.timeforflight.managers.ConfigManager; +import cc.carm.plugin.timeforflight.utils.MessageParser; +import cc.carm.plugin.timeforflight.utils.TimeFormat; +import org.bukkit.Bukkit; +import org.bukkit.configuration.file.FileConfiguration; +import org.bukkit.configuration.file.YamlConfiguration; +import org.bukkit.entity.Player; +import org.bukkit.scheduler.BukkitRunnable; + +import java.io.File; +import java.io.IOException; +import java.util.UUID; + +public class UserData { + + + UUID uuid; + + private File dataFile; + private FileConfiguration data; + + boolean fileLoaded; + + private int remainTime; + + private BukkitRunnable giveTask; + private BukkitRunnable flyTask; + + + public UserData(UUID uuid) { + this.uuid = uuid; + File userdatasFolder = new File(Main.getInstance().getDataFolder() + "/userdata"); + if (!userdatasFolder.isDirectory() || !userdatasFolder.exists()) { + userdatasFolder.mkdir(); + } + this.dataFile = new File(userdatasFolder, this.uuid + ".yml"); + this.remainTime = 0; + + + this.fileLoaded = dataFile.exists(); + if (fileLoaded) { + this.data = YamlConfiguration.loadConfiguration(dataFile); + + readData(); + } + } + + public void startFlyTask(Player player) { + player.setAllowFlight(true); + flyTask = new BukkitRunnable() { + @Override + public void run() { + if (canFly()) { + removeTime(1); + if (getRemainTime() == 10) { + player.sendMessage(MessageParser.parseColor("§c注意!§7您的飞行剩余时间仅剩10秒,请您注意安全!")); + } + } else { + player.sendMessage(MessageParser.parseColor("&7您已经用尽剩余的飞行时长,已为您关闭飞行状态。")); + stopFly(player); + } + } + }; + flyTask.runTaskTimer(Main.getInstance(), 0L, 20L); + + } + + public void stopFly(Player player) { + if (this.flyTask != null) { + this.flyTask.cancel(); + } + player.setAllowFlight(false); + player.setFlying(false); + } + + public void readData() { + this.remainTime = getData().getInt("remainTime"); + } + + public void addTime(int remainTime) { + this.remainTime += remainTime; + } + + public void removeTime(int time) { + this.remainTime -= time; + } + public void setTime(int time){ + this.remainTime = time; + } + + public void addTimeInConfig() { + addTime(ConfigManager.getTimeGiven()); + } + + public boolean canFly() { + return getRemainTime() > 0; + } + + + public BukkitRunnable getGiveTask() { + return giveTask; + } + + public void startGivenTask(Player player) { + giveTask = new BukkitRunnable() { + @Override + public void run() { + if (!player.isOnline() + || !player.hasPermission(Permissions.GET_TIME.toString()) + || player.hasPermission(Permissions.UNLIMITED.toString())) { + cancel(); + } + addTimeInConfig(); + if (ConfigManager.isAlertEnabled()) { + player.sendMessage(ConfigManager.getAlertMessage()); + } + } + }; + + getGiveTask().runTaskTimerAsynchronously(Main.getInstance(), + ConfigManager.getTimeInterval() * 20L, + ConfigManager.getTimeInterval() * 20L); + } + + public void stopTasks() { + if (getGiveTask() != null) { + getGiveTask().cancel(); + } + if (this.flyTask != null) { + this.flyTask.cancel(); + } + } + + public boolean isFileLoaded() { + return fileLoaded; + } + + public File getDataFile() { + return dataFile; + } + + public FileConfiguration getData() { + return data; + } + + public int getRemainTime() { + return remainTime; + } + + private void checkFile() { + if (!dataFile.exists()) { + try { + dataFile.createNewFile(); + } catch (IOException ex) { + Bukkit.getLogger().info("Could not load file " + "/userdata/" + "yml" + ex); + } + } + if (!isFileLoaded()) { + this.data = YamlConfiguration.loadConfiguration(dataFile); + this.fileLoaded = true; + } + } + + public String getRemainTimeString() { + return TimeFormat.getTimeString(getRemainTime()); + } + + public void saveData() { + checkFile(); + getData().set("remainTime", getRemainTime()); + try { + getData().save(dataFile); + } catch (IOException e) { + e.printStackTrace(); + } + } + +} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/utils/MessageParser.java b/src/main/java/cc/carm/plugin/timeforflight/utils/MessageParser.java similarity index 61% rename from src/main/java/com/carmwork/plugin/timeforflight/utils/MessageParser.java rename to src/main/java/cc/carm/plugin/timeforflight/utils/MessageParser.java index e5c6887..101cc1a 100644 --- a/src/main/java/com/carmwork/plugin/timeforflight/utils/MessageParser.java +++ b/src/main/java/cc/carm/plugin/timeforflight/utils/MessageParser.java @@ -1,6 +1,4 @@ -package com.carmwork.plugin.timeforflight.utils; - -import net.md_5.bungee.api.chat.BaseComponent; +package cc.carm.plugin.timeforflight.utils; public class MessageParser { diff --git a/src/main/java/cc/carm/plugin/timeforflight/utils/TimeFormat.java b/src/main/java/cc/carm/plugin/timeforflight/utils/TimeFormat.java new file mode 100644 index 0000000..ff22a53 --- /dev/null +++ b/src/main/java/cc/carm/plugin/timeforflight/utils/TimeFormat.java @@ -0,0 +1,23 @@ +package cc.carm.plugin.timeforflight.utils; + +public class TimeFormat { + + + public static String getTimeString(int time) { + int temp; + StringBuilder sb = new StringBuilder(); + + temp = time / 60 / 60 % 60; + sb.append((temp < 10) ? "0" + temp + ":" : "" + temp + ":"); + + temp = time % 3600 / 60; + sb.append((temp < 10) ? "0" + temp + ":" : "" + temp + ":"); + + temp = time % 3600 % 60; + sb.append((temp < 10) ? "0" + temp : "" + temp); + + return sb.toString(); + } + + +} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/Main.java b/src/main/java/com/carmwork/plugin/timeforflight/Main.java deleted file mode 100644 index 7b50d98..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/Main.java +++ /dev/null @@ -1,33 +0,0 @@ -package com.carmwork.plugin.timeforflight; - -import com.carmwork.plugin.timeforflight.commands.ToggleFlyCommand; -import com.carmwork.plugin.timeforflight.managers.ConfigManager; -import org.bukkit.plugin.java.JavaPlugin; - -import java.util.logging.Level; - -public class Main extends JavaPlugin { - - private static Main instance; - - public static Main getInstance() { - return Main.instance; - } - - @Override - public void onEnable() { - instance = this; - - logInfo("加载配置文件中"); - ConfigManager.loadConfig(); - - logInfo("注册指令"); - Main.getInstance().getCommand("togglefly").setExecutor(new ToggleFlyCommand()); - - } - - public static void logInfo(String message) { - Main.getInstance().getLogger().log(Level.INFO, message); - } - -} \ No newline at end of file diff --git a/src/main/java/com/carmwork/plugin/timeforflight/commands/TimeForFlightCommand.java b/src/main/java/com/carmwork/plugin/timeforflight/commands/TimeForFlightCommand.java deleted file mode 100644 index ba10e41..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/commands/TimeForFlightCommand.java +++ /dev/null @@ -1,98 +0,0 @@ -package com.carmwork.plugin.timeforflight.commands; - -import com.carmwork.plugin.timeforflight.utils.MessageParser; -import com.google.common.collect.ImmutableList; -import org.bukkit.Bukkit; -import org.bukkit.command.Command; -import org.bukkit.command.CommandExecutor; -import org.bukkit.command.CommandSender; -import org.bukkit.command.TabCompleter; -import org.bukkit.entity.Player; -import org.bukkit.util.StringUtil; - -import java.util.ArrayList; -import java.util.List; - -/** - * 管理员管理、查看玩家飞行时间的指令 - */ -public class TimeForFlightCommand implements CommandExecutor, TabCompleter { - - /* - * - set 设置玩家剩余的飞行时间 - * - add 为玩家添加飞行时间 - * - remove 移除玩家的飞行时间 - * - clear 情况玩家的飞行时间 - * - * - help 查看此帮助 - */ - - public static boolean help(CommandSender sender) { - sendMessage(sender, "&6&l限时飞行 &7管理指令帮助"); - return true; - } - - public static boolean noPerm(CommandSender sender) { - sender.sendMessage(MessageParser.parseColor("&c抱歉!&7但您没有这么做的权限。")); - return true; - } - - public static void sendMessage(CommandSender sender, String message) { - sender.sendMessage(MessageParser.parseColor(message)); - } - - public static void sendMessage(Player player, String message) { - player.sendMessage(MessageParser.parseColor(message)); - } - - @Override - public boolean onCommand(CommandSender sender, Command command, String s, String[] args) { - if (!sender.hasPermission("timeforflight.admin")) return noPerm(sender); - if (args.length > 3 || args.length < 1) return help(sender); - - - return true; - } - - @Override - public List onTabComplete(CommandSender sender, Command command, String alias, String[] args) { - if (!sender.hasPermission("timeforflight.admin")) { - return ImmutableList.of(); - } - switch (args.length) { - case 1: { - List completions = new ArrayList<>(); - List strings = new ArrayList<>(); - strings.add("help"); - strings.add("set"); - strings.add("add"); - strings.add("remove"); - strings.add("clear"); - for (String s : strings) { - if (StringUtil.startsWithIgnoreCase(s, args[0].toLowerCase())) { - completions.add(s); - } - } - return completions; - } - case 2: { - String aim = args[1]; - if (aim.equalsIgnoreCase("add") - || aim.equalsIgnoreCase("remove") - || aim.equalsIgnoreCase("set") - || aim.equalsIgnoreCase("clear")) { - List completions = new ArrayList<>(); - for (Player pl : Bukkit.getOnlinePlayers()) { - if (StringUtil.startsWithIgnoreCase(pl.getName(), args[1].toLowerCase())) { - completions.add(pl.getName()); - } - } - return completions; - } - } - default: - return ImmutableList.of(); - } - } - -} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/commands/ToggleFlyCommand.java b/src/main/java/com/carmwork/plugin/timeforflight/commands/ToggleFlyCommand.java deleted file mode 100644 index 99a4896..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/commands/ToggleFlyCommand.java +++ /dev/null @@ -1,92 +0,0 @@ -package com.carmwork.plugin.timeforflight.commands; - -import com.carmwork.plugin.timeforflight.managers.DataManager; -import com.carmwork.plugin.timeforflight.models.UserData; -import com.carmwork.plugin.timeforflight.utils.MessageParser; -import com.carmwork.plugin.timeforflight.utils.TimeFormat; -import org.bukkit.Bukkit; -import org.bukkit.command.Command; -import org.bukkit.command.CommandExecutor; -import org.bukkit.command.CommandSender; -import org.bukkit.entity.Player; - -/** - * 开关飞行的指令 - */ -public class ToggleFlyCommand implements CommandExecutor { - - - @Override - public boolean onCommand(CommandSender sender, Command command, String s, String[] args) { - if (args.length == 0 || !sender.isOp()) { - if (!(sender instanceof Player)) { - sender.sendMessage(MessageParser.parseColor("该指令只允许玩家使用。")); - sender.sendMessage(MessageParser.parseColor("您可以输入 /togglefly <玩家名> 设置某个玩家的飞行状态。")); - return true; - } - - Player player = (Player) sender; - - UserData userData = DataManager.getData(player.getUniqueId()); - if (player.hasPermission("timeforflight.unlimited")) { - - player.setAllowFlight(true); - player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); - return true; - } else if (player.hasPermission("timeforflight.allowflight")) { - if (userData.canFly()) { - userData.startFlyTask(player); - player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); - player.sendMessage(MessageParser.parseColor("&f剩余飞行时长 &a" + TimeFormat.getTimeString(userData.getRemainTime()))); - return true; - } else { - player.sendMessage(MessageParser.parseColor("&c您的飞行时长不足,无法开启飞行。")); - return true; - } - } else { - player.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); - return true; - } - } else if (args.length == 1) { - if (!sender.isOp()) { - sender.sendMessage(MessageParser.parseColor("&c抱歉!&f但您没有使用该指令的权限。")); - return true; - } - Player player = Bukkit.getPlayer(args[0]); - if (player == null) { - sender.sendMessage("玩家 " + args[0] + " 不在线。"); - return true; - } - - UserData userData = DataManager.getData(player.getUniqueId()); - if (player.hasPermission("timeforflight.unlimited")) { - - player.setAllowFlight(true); - player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); - sender.sendMessage(MessageParser.parseColor("已为玩家 " + player.getName() + " 开启飞行。")); - return true; - } else if (player.hasPermission("timeforflight.allowflight")) { - if (userData.canFly()) { - userData.startFlyTask(player); - player.sendMessage(MessageParser.parseColor("&f您现在可以飞行了!")); - player.sendMessage(MessageParser.parseColor("&f剩余飞行时长 &a" + TimeFormat.getTimeString(userData.getRemainTime()))); - sender.sendMessage(MessageParser.parseColor("已为玩家 " + player.getName() + " 开启飞行。")); - - return true; - } else { - player.sendMessage(MessageParser.parseColor("&c您的飞行时长不足,无法开启飞行。")); - sender.sendMessage(MessageParser.parseColor("玩家 " + player.getName() + " 飞行时间不足。")); - return true; - } - } else { - sender.sendMessage(MessageParser.parseColor("玩家 " + player.getName() + " 没有飞行权限。")); - return true; - } - - - } - return true; - } - - -} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/listeners/PlayerListener.java b/src/main/java/com/carmwork/plugin/timeforflight/listeners/PlayerListener.java deleted file mode 100644 index bd3dfd0..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/listeners/PlayerListener.java +++ /dev/null @@ -1,35 +0,0 @@ -package com.carmwork.plugin.timeforflight.listeners; - -import com.carmwork.plugin.timeforflight.managers.DataManager; -import com.carmwork.plugin.timeforflight.models.UserData; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerJoinEvent; -import org.bukkit.event.player.PlayerQuitEvent; - -public class PlayerListener implements Listener { - - @EventHandler - public void onJoin(PlayerJoinEvent event) { - Player player = event.getPlayer(); - UserData playerCache = DataManager.loadData(player.getUniqueId()); - if (player.hasPermission("timeforflight.getflighttime") - && !player.hasPermission("timeforflight.unlimited")) { - playerCache.startGivenTask(player); - } - - } - - @EventHandler - public void onQuit(PlayerQuitEvent event) { - Player player = event.getPlayer(); - UserData playerCache = DataManager.getData(player.getUniqueId()); - - player.setAllowFlight(false); - player.setFlying(false); - - - DataManager.unloadData(player.getUniqueId()); - } -} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/models/UserData.java b/src/main/java/com/carmwork/plugin/timeforflight/models/UserData.java deleted file mode 100644 index 809cf08..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/models/UserData.java +++ /dev/null @@ -1,167 +0,0 @@ -package com.carmwork.plugin.timeforflight.models; - -import com.carmwork.plugin.timeforflight.Main; -import com.carmwork.plugin.timeforflight.managers.ConfigManager; -import org.bukkit.Bukkit; -import org.bukkit.configuration.file.FileConfiguration; -import org.bukkit.configuration.file.YamlConfiguration; -import org.bukkit.entity.Player; -import org.bukkit.scheduler.BukkitRunnable; - -import java.io.File; -import java.io.IOException; -import java.util.UUID; - -public class UserData { - - - UUID uuid; - - private File datafile; - private FileConfiguration data; - - boolean fileLoaded; - - private int remainTime; - - private BukkitRunnable giveTask; - private BukkitRunnable flyTask; - - - public UserData(UUID uuid) { - this.uuid = uuid; - File userdatasFolder = new File(Main.getInstance().getDataFolder() + "/userdatas"); - if (!userdatasFolder.isDirectory() || !userdatasFolder.exists()) { - userdatasFolder.mkdir(); - } - this.datafile = new File(userdatasFolder, this.uuid + ".yml"); - this.remainTime = 0; - - - this.fileLoaded = datafile.exists(); - if (fileLoaded) { - this.data = YamlConfiguration.loadConfiguration(datafile); - - readData(); - } - } - - public void startFlyTask(Player player) { - player.setAllowFlight(true); - flyTask = new BukkitRunnable() { - @Override - public void run() { - if (canFly()) { - removeTime(1); - } else { - player.setAllowFlight(false); - player.setFlying(false); - } - } - }; - flyTask.runTaskTimer(Main.getInstance(), 0L, 20L); - - } - - public void stopFly() { - if (this.flyTask != null) { - this.flyTask.cancel(); - } - } - - public void readData() { - this.remainTime = getData().getInt("remainTime"); - } - - public void addTime(int remainTime) { - this.remainTime += remainTime; - } - - public void removeTime(int time) { - this.remainTime -= time; - } - - public void addTimeInConfig() { - addTime(ConfigManager.getTimeGiven()); - } - - public boolean canFly() { - return getRemainTime() > 0; - } - - - public BukkitRunnable getGiveTask() { - return giveTask; - } - - public void startGivenTask(Player player) { - giveTask = new BukkitRunnable() { - @Override - public void run() { - if (!player.isOnline() - || !player.hasPermission("timeforflight.getflighttime") - || player.hasPermission("timeforflight.unlimited")) { - cancel(); - } - addTimeInConfig(); - if (ConfigManager.isAlertEnabled()) { - player.sendMessage(ConfigManager.getAlertMessage()); - } - } - }; - - getGiveTask().runTaskTimerAsynchronously(Main.getInstance(), - ConfigManager.getTimeInterval() * 20, - ConfigManager.getTimeInterval() * 20); - } - - public void stopTasks() { - if (getGiveTask() != null) { - getGiveTask().cancel(); - } - if (this.flyTask != null) { - this.flyTask.cancel(); - } - } - - public boolean isFileLoaded() { - return fileLoaded; - } - - public File getDatafile() { - return datafile; - } - - public FileConfiguration getData() { - return data; - } - - public int getRemainTime() { - return remainTime; - } - - private void checkFile() { - if (!datafile.exists()) { - try { - datafile.createNewFile(); - } catch (IOException ex) { - Bukkit.getLogger().info("Could not load file " + "/userdatas/" + "yml" + ex); - } - } - if (!isFileLoaded()) { - this.data = YamlConfiguration.loadConfiguration(datafile); - this.fileLoaded = true; - } - } - - public void saveData() { - checkFile(); - getData().set("remainTime", getRemainTime()); - try { - getData().save(datafile); - } catch (IOException e) { - e.printStackTrace(); - } - } - -} diff --git a/src/main/java/com/carmwork/plugin/timeforflight/utils/TimeFormat.java b/src/main/java/com/carmwork/plugin/timeforflight/utils/TimeFormat.java deleted file mode 100644 index 850a19e..0000000 --- a/src/main/java/com/carmwork/plugin/timeforflight/utils/TimeFormat.java +++ /dev/null @@ -1,23 +0,0 @@ -package com.carmwork.plugin.timeforflight.utils; - -public class TimeFormat { - - - public static String getTimeString(int time) { - int temp; - StringBuilder sb = new StringBuilder(); - - temp = time / 60 / 60 % 60; - sb.append((temp < 10) ? "0" + temp + ":" : "" + temp + ":"); - - temp = time % 3600 / 60; - sb.append((temp < 10) ? "0" + temp + ":" : "" + temp + ":"); - - temp = time % 3600 % 60; - sb.append((temp < 10) ? "0" + temp : "" + temp); - - return sb.toString(); - } - - -} diff --git a/src/main/resources/config.yml b/src/main/resources/config.yml index 00e90b8..662f553 100644 --- a/src/main/resources/config.yml +++ b/src/main/resources/config.yml @@ -1,6 +1,3 @@ -#权限节点 -# - settings: interval: 60 #赠送飞行时间的在线时长间隔(秒) diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml index 5df02b6..b879fdd 100644 --- a/src/main/resources/plugin.yml +++ b/src/main/resources/plugin.yml @@ -1,8 +1,12 @@ -name: TimeForFlight -main: com.carmwork.plugin.timeforflight.Main -version: 1.0.0 - SNAPSHOT + +main: cc.carm.plugin.timeforflight.Main + +name: ${project.name} +version: ${project.version} +description: ${project.description} author: CarmJos -depend: [ProtocolLib] +website: ${project.url} + commands: TimeForFlight: permission: timeforflight.admin @@ -13,7 +17,10 @@ commands: ToggleFly: aliases: - ToggleFlight + permissions: + timeforflight.admin: + default: op timeforflight.unlimited: default: op description: "无限制飞行,不计算飞行时间"