mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2024-11-21 18:25:12 +01:00
WIP
This commit is contained in:
parent
c994dbdd3d
commit
03888f811d
2
pom.xml
2
pom.xml
@ -73,7 +73,7 @@
|
|||||||
<postgresql.version>42.2.18</postgresql.version>
|
<postgresql.version>42.2.18</postgresql.version>
|
||||||
<hikaricp.version>5.0.1</hikaricp.version>
|
<hikaricp.version>5.0.1</hikaricp.version>
|
||||||
<!-- More visible way to change dependency versions -->
|
<!-- More visible way to change dependency versions -->
|
||||||
<spigot.version>1.20.5-R0.1-SNAPSHOT</spigot.version>
|
<spigot.version>1.21.2-R0.1-SNAPSHOT</spigot.version>
|
||||||
<!-- Might differ from the last Spigot release for short periods
|
<!-- Might differ from the last Spigot release for short periods
|
||||||
of time -->
|
of time -->
|
||||||
<paper.version>1.20.6-R0.1-SNAPSHOT</paper.version>
|
<paper.version>1.20.6-R0.1-SNAPSHOT</paper.version>
|
||||||
|
@ -10,6 +10,7 @@ import java.util.UUID;
|
|||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
|
|
||||||
import com.google.gson.annotations.Expose;
|
import com.google.gson.annotations.Expose;
|
||||||
|
|
||||||
@ -37,6 +38,8 @@ public class Players implements DataObject, MetaDataAble {
|
|||||||
private String locale = "";
|
private String locale = "";
|
||||||
@Expose
|
@Expose
|
||||||
private Map<String, Integer> deaths = new HashMap<>();
|
private Map<String, Integer> deaths = new HashMap<>();
|
||||||
|
@Expose
|
||||||
|
private Long lastLogin;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This variable stores set of worlds where user inventory must be cleared.
|
* This variable stores set of worlds where user inventory must be cleared.
|
||||||
@ -292,5 +295,20 @@ public class Players implements DataObject, MetaDataAble {
|
|||||||
this.metaData = metaData;
|
this.metaData = metaData;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the lastLogin, Unix timestamp, or null if never logged in since this was tracked
|
||||||
|
* @since 2.6.0
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
public Long getLastLogin() {
|
||||||
|
return lastLogin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param lastLogin the lastLogin to set
|
||||||
|
*/
|
||||||
|
public void setLastLogin(Long lastLogin) {
|
||||||
|
this.lastLogin = lastLogin;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -64,6 +64,9 @@ public class JoinLeaveListener implements Listener {
|
|||||||
// don't exist
|
// don't exist
|
||||||
players.getPlayer(playerUUID);
|
players.getPlayer(playerUUID);
|
||||||
|
|
||||||
|
// Set the login
|
||||||
|
players.setLoginTimeStamp(user);
|
||||||
|
|
||||||
// Reset island resets if required
|
// Reset island resets if required
|
||||||
plugin.getIWM().getOverWorlds().stream()
|
plugin.getIWM().getOverWorlds().stream()
|
||||||
.filter(w -> event.getPlayer().getLastPlayed() < plugin.getIWM().getResetEpoch(w))
|
.filter(w -> event.getPlayer().getLastPlayed() < plugin.getIWM().getResetEpoch(w))
|
||||||
|
@ -420,4 +420,32 @@ public class PlayersManager {
|
|||||||
return CompletableFuture.completedFuture(false);
|
return CompletableFuture.completedFuture(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Records when the user last logged in. Called by the joinleave listener
|
||||||
|
* @param user user
|
||||||
|
*/
|
||||||
|
public void setLoginTimeStamp(User user) {
|
||||||
|
if (user.isPlayer() && user.isOnline()) {
|
||||||
|
Players p = this.getPlayer(user.getUniqueId());
|
||||||
|
if (p != null) {
|
||||||
|
p.setLastLogin(System.currentTimeMillis());
|
||||||
|
this.savePlayer(user.getUniqueId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the last login time stamp for this player
|
||||||
|
* @param uuid player's UUID
|
||||||
|
* @return timestamp or null if unknown or not recorded yet
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
public Long getLastLoginTimestamp(UUID uuid) {
|
||||||
|
Players p = this.getPlayer(uuid);
|
||||||
|
if (p != null) {
|
||||||
|
return p.getLastLogin();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
package world.bentobox.bentobox.nms.v1_21_2_R0_1_SNAPSHOT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Same as 1.21
|
||||||
|
*/
|
||||||
|
public class PasteHandlerImpl extends world.bentobox.bentobox.nms.v1_21_R0_1_SNAPSHOT.PasteHandlerImpl {
|
||||||
|
// Do nothing special
|
||||||
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
package world.bentobox.bentobox.nms.v1_21_2_R0_1_SNAPSHOT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Same as 1.21
|
||||||
|
*/
|
||||||
|
public class WorldRegeneratorImpl extends world.bentobox.bentobox.nms.v1_21_R0_1_SNAPSHOT.WorldRegeneratorImpl {
|
||||||
|
// Do nothing special
|
||||||
|
}
|
@ -20,6 +20,8 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.Tag;
|
import org.bukkit.Tag;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
|
import org.bukkit.damage.DamageSource;
|
||||||
|
import org.bukkit.damage.DamageType;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.entity.Player.Spigot;
|
import org.bukkit.entity.Player.Spigot;
|
||||||
@ -298,13 +300,14 @@ public abstract class AbstractCommonSetup {
|
|||||||
*/
|
*/
|
||||||
public EntityExplodeEvent getExplodeEvent(Entity entity, Location l, List<Block> list) {
|
public EntityExplodeEvent getExplodeEvent(Entity entity, Location l, List<Block> list) {
|
||||||
//return new EntityExplodeEvent(entity, l, list, 0, null);
|
//return new EntityExplodeEvent(entity, l, list, 0, null);
|
||||||
return new EntityExplodeEvent(entity, l, list, 0);
|
return new EntityExplodeEvent(entity, l, list, 0, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PlayerDeathEvent getPlayerDeathEvent(Player player, List<ItemStack> drops, int droppedExp, int newExp,
|
public PlayerDeathEvent getPlayerDeathEvent(Player player, List<ItemStack> drops, int droppedExp, int newExp,
|
||||||
int newTotalExp, int newLevel, @Nullable String deathMessage) {
|
int newTotalExp, int newLevel, @Nullable String deathMessage) {
|
||||||
//return new PlayerDeathEvent(player, null, drops, droppedExp, newExp, newTotalExp, newLevel, deathMessage);
|
//return new PlayerDeathEvent(player, null, drops, droppedExp, newExp, newTotalExp, newLevel, deathMessage);
|
||||||
return new PlayerDeathEvent(player, drops, droppedExp, newExp, newTotalExp, newLevel, deathMessage);
|
return new PlayerDeathEvent(player, DamageSource.builder(DamageType.GENERIC).build(), drops, droppedExp, newExp,
|
||||||
|
newTotalExp, newLevel, deathMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,8 @@ import java.util.Map;
|
|||||||
|
|
||||||
import org.bukkit.DyeColor;
|
import org.bukkit.DyeColor;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.NamespacedKey;
|
||||||
|
import org.bukkit.Registry;
|
||||||
import org.bukkit.entity.ChestedHorse;
|
import org.bukkit.entity.ChestedHorse;
|
||||||
import org.bukkit.entity.Cow;
|
import org.bukkit.entity.Cow;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
@ -21,6 +23,7 @@ import org.bukkit.inventory.ItemStack;
|
|||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
@ -34,6 +37,7 @@ import world.bentobox.bentobox.blueprints.dataobjects.BlueprintEntity.MythicMobR
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@Ignore("Cannot mock Villager Professions anynore")
|
||||||
public class BlueprintEntityTest {
|
public class BlueprintEntityTest {
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
@ -55,7 +59,8 @@ public class BlueprintEntityTest {
|
|||||||
*/
|
*/
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
when(villager.getProfession()).thenReturn(Profession.LIBRARIAN);
|
when(villager.getProfession())
|
||||||
|
.thenReturn(Registry.VILLAGER_PROFESSION.get(NamespacedKey.minecraft("librarian")));
|
||||||
when(villager.getVillagerExperience()).thenReturn(100);
|
when(villager.getVillagerExperience()).thenReturn(100);
|
||||||
when(villager.getVillagerLevel()).thenReturn(2);
|
when(villager.getVillagerLevel()).thenReturn(2);
|
||||||
when(villager.getVillagerType()).thenReturn(Villager.Type.PLAINS);
|
when(villager.getVillagerType()).thenReturn(Villager.Type.PLAINS);
|
||||||
|
@ -126,7 +126,7 @@ public class PanelListenerManagerTest {
|
|||||||
PanelListenerManager.getOpenPanels().clear();
|
PanelListenerManager.getOpenPanels().clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
class MyView extends InventoryView {
|
class MyView implements InventoryView {
|
||||||
|
|
||||||
private final Inventory top;
|
private final Inventory top;
|
||||||
private final String name;
|
private final String name;
|
||||||
@ -195,6 +195,53 @@ public class PanelListenerManagerTest {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCursor(ItemStack item) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getCursor() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Inventory getInventory(int rawSlot) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int convertSlot(int rawSlot) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SlotType getSlotType(int slot) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int countSlots() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setProperty(Property prop, int value) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -338,7 +338,7 @@ public class BreakBlocksListenerTest extends AbstractCommonSetup {
|
|||||||
when(island.isAllowed(any(), any())).thenReturn(false);
|
when(island.isAllowed(any(), any())).thenReturn(false);
|
||||||
Vehicle vehicle = mock(Vehicle.class);
|
Vehicle vehicle = mock(Vehicle.class);
|
||||||
when(vehicle.getLocation()).thenReturn(location);
|
when(vehicle.getLocation()).thenReturn(location);
|
||||||
when(vehicle.getType()).thenReturn(EntityType.BOAT);
|
when(vehicle.getType()).thenReturn(EntityType.OAK_BOAT);
|
||||||
VehicleDamageEvent e = new VehicleDamageEvent(vehicle, mockPlayer, 10);
|
VehicleDamageEvent e = new VehicleDamageEvent(vehicle, mockPlayer, 10);
|
||||||
bbl.onVehicleDamageEvent(e);
|
bbl.onVehicleDamageEvent(e);
|
||||||
assertTrue(e.isCancelled());
|
assertTrue(e.isCancelled());
|
||||||
|
@ -65,7 +65,7 @@ public class CreeperListenerTest extends AbstractCommonSetup {
|
|||||||
Entity entity = mock(Entity.class);
|
Entity entity = mock(Entity.class);
|
||||||
when(entity.getType()).thenReturn(EntityType.TNT);
|
when(entity.getType()).thenReturn(EntityType.TNT);
|
||||||
when(iwm.inWorld(location)).thenReturn(true);
|
when(iwm.inWorld(location)).thenReturn(true);
|
||||||
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0);
|
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0, null);
|
||||||
cl.onExplosion(event);
|
cl.onExplosion(event);
|
||||||
assertFalse(event.isCancelled());
|
assertFalse(event.isCancelled());
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ public class CreeperListenerTest extends AbstractCommonSetup {
|
|||||||
when(entity.getLocation()).thenReturn(location);
|
when(entity.getLocation()).thenReturn(location);
|
||||||
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
||||||
when(iwm.inWorld(location)).thenReturn(false);
|
when(iwm.inWorld(location)).thenReturn(false);
|
||||||
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0);
|
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0, null);
|
||||||
cl.onExplosion(event);
|
cl.onExplosion(event);
|
||||||
assertFalse(event.isCancelled());
|
assertFalse(event.isCancelled());
|
||||||
}
|
}
|
||||||
@ -98,7 +98,7 @@ public class CreeperListenerTest extends AbstractCommonSetup {
|
|||||||
when(entity.getLocation()).thenReturn(location);
|
when(entity.getLocation()).thenReturn(location);
|
||||||
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
||||||
when(iwm.inWorld(location)).thenReturn(true);
|
when(iwm.inWorld(location)).thenReturn(true);
|
||||||
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0);
|
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0, null);
|
||||||
cl.onExplosion(event);
|
cl.onExplosion(event);
|
||||||
assertFalse(event.isCancelled());
|
assertFalse(event.isCancelled());
|
||||||
assertFalse(event.blockList().isEmpty()); // No clearing of block list
|
assertFalse(event.blockList().isEmpty()); // No clearing of block list
|
||||||
@ -119,7 +119,7 @@ public class CreeperListenerTest extends AbstractCommonSetup {
|
|||||||
when(entity.getLocation()).thenReturn(location);
|
when(entity.getLocation()).thenReturn(location);
|
||||||
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
when(entity.getType()).thenReturn(EntityType.CREEPER);
|
||||||
when(iwm.inWorld(location)).thenReturn(true);
|
when(iwm.inWorld(location)).thenReturn(true);
|
||||||
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0);
|
EntityExplodeEvent event = new EntityExplodeEvent(entity, location, list, 0, null);
|
||||||
cl.onExplosion(event);
|
cl.onExplosion(event);
|
||||||
assertFalse(event.isCancelled());
|
assertFalse(event.isCancelled());
|
||||||
assertTrue(event.blockList().isEmpty()); // No clearing of block list
|
assertTrue(event.blockList().isEmpty()); // No clearing of block list
|
||||||
|
@ -101,6 +101,12 @@ public class ItemParserTest {
|
|||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Keyed getOrThrow(NamespacedKey key) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
|
Loading…
Reference in New Issue
Block a user