feat: add cooldown tag that is stored

This commit is contained in:
Sekwah 2024-02-05 02:17:44 +00:00
parent 687ec8c9c9
commit 2064c3f8ab
13 changed files with 189 additions and 27 deletions

View File

@ -15,6 +15,7 @@ import com.sekwah.advancedportals.core.repository.ConfigRepository;
import com.sekwah.advancedportals.core.services.DestinationServices; import com.sekwah.advancedportals.core.services.DestinationServices;
import com.sekwah.advancedportals.core.services.PortalServices; import com.sekwah.advancedportals.core.services.PortalServices;
import com.sekwah.advancedportals.core.services.PlayerDataServices; import com.sekwah.advancedportals.core.services.PlayerDataServices;
import com.sekwah.advancedportals.core.tags.activation.CooldownTag;
import com.sekwah.advancedportals.core.tags.activation.DestiTag; import com.sekwah.advancedportals.core.tags.activation.DestiTag;
import com.sekwah.advancedportals.core.tags.activation.NameTag; import com.sekwah.advancedportals.core.tags.activation.NameTag;
import com.sekwah.advancedportals.core.tags.activation.TriggerBlockTag; import com.sekwah.advancedportals.core.tags.activation.TriggerBlockTag;
@ -118,6 +119,7 @@ public class AdvancedPortalsCore {
private void registerTags() { private void registerTags() {
this.tagRegistry.registerTag(new NameTag()); this.tagRegistry.registerTag(new NameTag());
this.tagRegistry.registerTag(new DestiTag()); this.tagRegistry.registerTag(new DestiTag());
this.tagRegistry.registerTag(new CooldownTag());
this.tagRegistry.registerTag(new TriggerBlockTag()); this.tagRegistry.registerTag(new TriggerBlockTag());
} }

View File

@ -32,11 +32,11 @@ public class CoreListeners {
private GameScheduler gameScheduler; private GameScheduler gameScheduler;
public void playerJoin(PlayerContainer player) { public void playerJoin(PlayerContainer player) {
this.playerDataServices.activateCooldown(player); this.playerDataServices.setJoinCooldown(player);
} }
public void teleportEvent(PlayerContainer player) { public void teleportEvent(PlayerContainer player) {
this.playerDataServices.activateCooldown(player); this.playerDataServices.setJoinCooldown(player);
} }
public void playerLeave(PlayerContainer player) { public void playerLeave(PlayerContainer player) {
@ -157,7 +157,7 @@ public class CoreListeners {
} }
public void worldChange(PlayerContainer player) { public void worldChange(PlayerContainer player) {
this.playerDataServices.activateCooldown(player); this.playerDataServices.setJoinCooldown(player);
} }
public boolean preventEntityCombust(EntityContainer entity) { public boolean preventEntityCombust(EntityContainer entity) {

View File

@ -65,7 +65,7 @@ public class Destination implements TagTarget {
} }
public boolean activate(PlayerContainer player) { public boolean activate(PlayerContainer player) {
ActivationData data = new ActivationData(); ActivationData data = new ActivationData(false);
this.portalActivate(player, data); this.portalActivate(player, data);
this.postActivate(player, data); this.postActivate(player, data);
return true; return true;

View File

@ -11,6 +11,8 @@ import com.sekwah.advancedportals.core.registry.TagRegistry;
import com.sekwah.advancedportals.core.serializeddata.PlayerLocation; import com.sekwah.advancedportals.core.serializeddata.PlayerLocation;
import com.sekwah.advancedportals.core.services.PlayerDataServices; import com.sekwah.advancedportals.core.services.PlayerDataServices;
import com.sekwah.advancedportals.core.tags.activation.TriggerBlockTag; import com.sekwah.advancedportals.core.tags.activation.TriggerBlockTag;
import com.sekwah.advancedportals.core.util.Lang;
import com.sekwah.advancedportals.core.util.PlayerUtils;
import com.sekwah.advancedportals.core.warphandler.ActivationData; import com.sekwah.advancedportals.core.warphandler.ActivationData;
import com.sekwah.advancedportals.core.warphandler.Tag; import com.sekwah.advancedportals.core.warphandler.Tag;
@ -107,15 +109,19 @@ public class AdvancedPortal implements TagTarget {
*/ */
public boolean activate(PlayerContainer player, boolean moveActivated) { public boolean activate(PlayerContainer player, boolean moveActivated) {
var playerData = playerDataServices.getPlayerData(player); var playerData = playerDataServices.getPlayerData(player);
if(playerData.isGlobalCooldown()) { if(playerData.isInPortal()) return false;
playerData.setInPortal(true);
if(playerData.hasJoinCooldown()) {
var cooldown = (int) Math.ceil(playerData.getJoinCooldownLeft() / 1000D);
player.sendMessage(Lang.translateInsertVariables("portal.cooldown.join", cooldown,
Lang.translate(cooldown == 1 ? "time.second" : "time.seconds")));
if(configRepository.playFailSound()) { if(configRepository.playFailSound()) {
player.playSound("block.portal.travel", 0.05f, new Random().nextFloat() * 0.4F + 0.8F); player.playSound("block.portal.travel", 0.05f, new Random().nextFloat() * 0.4F + 0.8F);
} }
if(moveActivated) throwPlayerBack(player);
return false; return false;
} }
ActivationData data = new ActivationData(); ActivationData data = new ActivationData(moveActivated);
DataTag[] portalTags = new DataTag[args.size()]; DataTag[] portalTags = new DataTag[args.size()];
int i = 0; int i = 0;
for(Map.Entry<String, String[]> entry : args.entrySet()) { for(Map.Entry<String, String[]> entry : args.entrySet()) {
@ -146,18 +152,11 @@ public class AdvancedPortal implements TagTarget {
} }
if(data.hasActivated()) { if(data.hasActivated()) {
playerData.setNetherPortalCooldown(1000); playerData.setNetherPortalCooldown(1000);
playerData.setGlobalCooldown(configRepository.getPortalCooldown() * 1000);
return true; return true;
} }
return false; return false;
} }
private void throwPlayerBack(PlayerContainer player) {
var strength = configRepository.getThrowbackStrength();
var playerLoc = player.getLoc().getDirection();
player.setVelocity(playerLoc.setY(0).normalize().multiply(-1).setY(0.5).multiply(strength));
}
public boolean isLocationInPortal(BlockLocation loc) { public boolean isLocationInPortal(BlockLocation loc) {
return this.isLocationInPortal(loc, 0); return this.isLocationInPortal(loc, 0);
@ -209,4 +208,8 @@ public class AdvancedPortal implements TagTarget {
} }
return false; return false;
} }
public String getName() {
return getArgValues("name")[0];
}
} }

View File

@ -79,7 +79,7 @@ public class ConfigRepositoryImpl implements ConfigRepository {
@Override @Override
public long getPortalCooldown() { public long getPortalCooldown() {
return this.config.portalCooldown; return this.config.joinCooldown;
} }
@Override @Override

View File

@ -39,11 +39,11 @@ public class PlayerData {
/** /**
* The next time System.currentTimeMillis() a player can use a portal. * The next time System.currentTimeMillis() a player can use a portal.
*/ */
private transient long globalCooldown; private transient long joinCooldown;
private transient long netherPortalCooldown; private transient long netherPortalCooldown;
private HashMap<String, String> perPortalCooldowns = new HashMap<>(); private HashMap<String, Long> perPortalCooldowns = new HashMap<>();
private String selectedPortal; private String selectedPortal;
@ -63,12 +63,12 @@ public class PlayerData {
this.pos2 = pos2; this.pos2 = pos2;
} }
public long getGlobalCooldown() { public long getJoinCooldownLeft() {
return globalCooldown; return joinCooldown - System.currentTimeMillis();
} }
public void setGlobalCooldown(long globalCooldown) { public void setJoinCooldown(long joinCooldown) {
this.globalCooldown = System.currentTimeMillis() + globalCooldown; this.joinCooldown = System.currentTimeMillis() + joinCooldown;
} }
public String getSelectedPortal() { public String getSelectedPortal() {
@ -107,11 +107,23 @@ public class PlayerData {
this.netherPortalCooldown = System.currentTimeMillis() + netherPortalCooldown; this.netherPortalCooldown = System.currentTimeMillis() + netherPortalCooldown;
} }
public boolean isGlobalCooldown() { public boolean hasJoinCooldown() {
return System.currentTimeMillis() < globalCooldown; return System.currentTimeMillis() < joinCooldown;
} }
public boolean isNetherPortalCooldown() { public boolean isNetherPortalCooldown() {
return System.currentTimeMillis() < netherPortalCooldown; return System.currentTimeMillis() < netherPortalCooldown;
} }
public void setPortalCooldown(String portalName, long cooldown) {
perPortalCooldowns.put(portalName, System.currentTimeMillis() + cooldown);
}
public boolean hasPortalCooldown(String portalName) {
return perPortalCooldowns.containsKey(portalName) && System.currentTimeMillis() < perPortalCooldowns.get(portalName);
}
public double getPortalCooldownLeft(String portalName) {
return perPortalCooldowns.get(portalName) - System.currentTimeMillis();
}
} }

View File

@ -17,7 +17,7 @@ public class Config {
public boolean stopWaterFlow = true; public boolean stopWaterFlow = true;
public int portalCooldown = 5; public int joinCooldown = 5;
public String warpParticles = "ENDER"; public String warpParticles = "ENDER";
@ -31,7 +31,7 @@ public class Config {
public int maxTriggerVisualisationSize = 1000; public int maxTriggerVisualisationSize = 1000;
public double throwbackStrength = 1; public double throwbackStrength = 0.7;
public boolean playFailSound = true; public boolean playFailSound = true;
} }

View File

@ -39,9 +39,9 @@ public final class PlayerDataServices {
}); });
} }
public void activateCooldown(PlayerContainer player) { public void setJoinCooldown(PlayerContainer player) {
var tempData = getPlayerData(player); var tempData = getPlayerData(player);
tempData.setGlobalCooldown(configRepository.getPortalCooldown() * 1000); tempData.setJoinCooldown(configRepository.getPortalCooldown() * 1000);
} }
public void playerLeave(PlayerContainer player) { public void playerLeave(PlayerContainer player) {

View File

@ -12,6 +12,7 @@ import com.sekwah.advancedportals.core.portal.AdvancedPortal;
import com.sekwah.advancedportals.core.serializeddata.PlayerData; import com.sekwah.advancedportals.core.serializeddata.PlayerData;
import com.sekwah.advancedportals.core.tags.activation.NameTag; import com.sekwah.advancedportals.core.tags.activation.NameTag;
import com.sekwah.advancedportals.core.util.Lang; import com.sekwah.advancedportals.core.util.Lang;
import com.sekwah.advancedportals.core.util.PlayerUtils;
import com.sekwah.advancedportals.core.warphandler.Tag; import com.sekwah.advancedportals.core.warphandler.Tag;
import javax.inject.Singleton; import javax.inject.Singleton;
@ -80,16 +81,26 @@ public class PortalServices {
var blockMaterial = world.getBlock(blockLoc); var blockMaterial = world.getBlock(blockLoc);
var blockEntityTopMaterial = world.getBlock(blockEntityTopLoc); var blockEntityTopMaterial = world.getBlock(blockEntityTopLoc);
var notInPortal = true;
for (AdvancedPortal portal : portalCache.values()) { for (AdvancedPortal portal : portalCache.values()) {
if ((portal.isLocationInPortal(toLoc) if ((portal.isLocationInPortal(toLoc)
&& portal.isTriggerBlock(blockMaterial)) && portal.isTriggerBlock(blockMaterial))
|| (portal.isLocationInPortal(blockEntityTopLoc) || (portal.isLocationInPortal(blockEntityTopLoc)
&& portal.isTriggerBlock(blockEntityTopMaterial))) { && portal.isTriggerBlock(blockEntityTopMaterial))) {
notInPortal = false;
if(portal.activate(player, true)) { if(portal.activate(player, true)) {
return; return;
} }
} }
} }
var playerData = playerDataServices.getPlayerData(player);
if(!notInPortal) {
var strength = configRepository.getThrowbackStrength();
PlayerUtils.throwPlayerBack(player, strength);
}
if(playerData.isInPortal() && notInPortal) {
playerData.setInPortal(false);
}
} }
public List<String> getPortalNames() { public List<String> getPortalNames() {

View File

@ -0,0 +1,111 @@
package com.sekwah.advancedportals.core.tags.activation;
import com.google.inject.Inject;
import com.sekwah.advancedportals.core.connector.containers.PlayerContainer;
import com.sekwah.advancedportals.core.destination.Destination;
import com.sekwah.advancedportals.core.effect.WarpEffect;
import com.sekwah.advancedportals.core.portal.AdvancedPortal;
import com.sekwah.advancedportals.core.registry.TagTarget;
import com.sekwah.advancedportals.core.repository.ConfigRepository;
import com.sekwah.advancedportals.core.services.PlayerDataServices;
import com.sekwah.advancedportals.core.util.InfoLogger;
import com.sekwah.advancedportals.core.util.Lang;
import com.sekwah.advancedportals.core.util.PlayerUtils;
import com.sekwah.advancedportals.core.warphandler.ActivationData;
import com.sekwah.advancedportals.core.warphandler.Tag;
import javax.annotation.Nullable;
import java.util.List;
import java.util.Random;
public class CooldownTag implements Tag.Activation, Tag.Creation {
@Inject
transient PlayerDataServices playerDataServices;
@Inject
transient ConfigRepository configRepository;
@Inject
private InfoLogger infoLogger;
public static String TAG_NAME = "cooldown";
private final TagType[] tagTypes = new TagType[]{ TagType.PORTAL };
@Override
public TagType[] getTagTypes() {
return tagTypes;
}
@Override
public String getName() {
return TAG_NAME;
}
@Nullable
@Override
public String[] getAliases() {
return null;
}
@Override
public String description() {
return Lang.translate("tag.cooldown.description");
}
@Override
public boolean preActivated(TagTarget target, PlayerContainer player, ActivationData activationData, String[] argData) {
var playerData = playerDataServices.getPlayerData(player);
if(target instanceof AdvancedPortal portal) {
var portalName = portal.getName();
if(playerData.hasPortalCooldown(portalName)) {
var cooldown = (int) Math.ceil(playerData.getPortalCooldownLeft(portalName) / 1000D);
player.sendMessage(Lang.translateInsertVariables("portal.cooldown.individual", cooldown,
Lang.translate(cooldown == 1 ? "time.second" : "time.seconds")));
if(configRepository.playFailSound()) {
player.playSound("block.portal.travel", 0.05f, new Random().nextFloat() * 0.4F + 0.8F);
}
return false;
}
return true;
}
return false;
}
@Override
public void postActivated(TagTarget target, PlayerContainer player, ActivationData activationData, String[] argData) {
if(activationData.hasActivated()) {
if(target instanceof AdvancedPortal portal) {
var playerData = playerDataServices.getPlayerData(player);
try {
playerData.setPortalCooldown(portal.getName(), Integer.parseInt(argData[0]) * 1000);
} catch (NumberFormatException e) {
infoLogger.warning("Cooldown tag failed to set cooldown for portal: " + portal.getName() + " with value: " + argData[0]);
}
}
}
}
@Override
public boolean activated(TagTarget target, PlayerContainer player, ActivationData activationData, String[] argData) {
return true;
}
@Override
public boolean created(TagTarget target, PlayerContainer player, String[] argData) {
try {
Integer.parseInt(argData[0]);
} catch (NumberFormatException e) {
player.sendMessage(Lang.translate("messageprefix.negative") + Lang.translate("tag.cooldown.fail"));
return false;
}
return true;
}
@Override
public void destroyed(TagTarget target, PlayerContainer player, String[] argData) {
}
}

View File

@ -0,0 +1,11 @@
package com.sekwah.advancedportals.core.util;
import com.sekwah.advancedportals.core.connector.containers.PlayerContainer;
public class PlayerUtils {
public static void throwPlayerBack(PlayerContainer player, double strength) {
var playerLoc = player.getLoc().getDirection();
player.setVelocity(playerLoc.setY(0).normalize().multiply(-1).setY(0.5).multiply(strength));
}
}

View File

@ -12,6 +12,8 @@ public class ActivationData {
private boolean warpAllowed = true; private boolean warpAllowed = true;
public final boolean moveActivated;
private WarpedStatus warpStatus = WarpedStatus.NOTACTIVATED; private WarpedStatus warpStatus = WarpedStatus.NOTACTIVATED;
private PlayerLocation wantedLocation; private PlayerLocation wantedLocation;
@ -20,6 +22,10 @@ public class ActivationData {
return this.warpStatus; return this.warpStatus;
} }
public ActivationData(boolean moveActivated) {
this.moveActivated = moveActivated;
}
public void setWarpStatus(WarpedStatus warped) { public void setWarpStatus(WarpedStatus warped) {
if (this.warpStatus == WarpedStatus.WARPED) { if (this.warpStatus == WarpedStatus.WARPED) {
return; return;

View File

@ -141,6 +141,11 @@ error.notplayer=Only players can do that.
portal.selector.poschange=&aYou have selected &epos%1$s &aX&7:&e%2$s &aY&7:&e%3$s &aZ&7:&e%4$s portal.selector.poschange=&aYou have selected &epos%1$s &aX&7:&e%2$s &aY&7:&e%3$s &aZ&7:&e%4$s
time.second=second
time.seconds=seconds
portal.cooldown.join=&cThere is &e%1$s &c%2$s join cooldown protection left.
portal.cooldown.individual=&cPlease wait &e%1$s &c%2$s until attempting to enter this portal again.
command.lang.help=Update the translation file command.lang.help=Update the translation file
command.version.help=Returns the current version of the plugin command.version.help=Returns the current version of the plugin
@ -156,4 +161,5 @@ tag.desti.description=Sets the destination of the portal
tag.name.error.nospaces= The name cannot contain spaces. tag.name.error.nospaces= The name cannot contain spaces.
tag.triggerblock.description=Sets the trigger block/s of the portal. Comma seperated or multi tag. tag.triggerblock.description=Sets the trigger block/s of the portal. Comma seperated or multi tag.
tag.cooldown.fail= The cooldown must be a number.