2021-01-03 07:21:15 +00:00
package dev.plex.listener.impl ;
2020-10-27 20:12:38 +00:00
2020-10-28 03:49:56 +00:00
import java.util.Arrays ;
2020-11-05 21:17:14 +00:00
import java.util.UUID ;
2021-01-03 07:21:15 +00:00
import dev.plex.admin.Admin ;
import dev.plex.cache.DataUtils ;
import dev.plex.cache.MongoPlayerData ;
import dev.plex.cache.PlayerCache ;
import dev.plex.cache.SQLPlayerData ;
import dev.plex.command.impl.FionnCMD ;
import dev.plex.listener.PlexListener ;
import dev.plex.player.PlexPlayer ;
import dev.plex.player.PunishedPlayer ;
import dev.plex.util.PlexLog ;
2020-10-28 19:07:02 +00:00
import org.bukkit.ChatColor ;
2020-11-02 00:06:08 +00:00
import org.bukkit.Location ;
2020-10-27 20:12:38 +00:00
import org.bukkit.entity.Player ;
import org.bukkit.event.EventHandler ;
2020-10-28 19:07:02 +00:00
import org.bukkit.event.EventPriority ;
2020-10-27 20:12:38 +00:00
import org.bukkit.event.player.PlayerJoinEvent ;
import org.bukkit.event.player.PlayerQuitEvent ;
2020-10-31 08:55:27 +00:00
public class PlayerListener extends PlexListener
2020-10-27 20:12:38 +00:00
{
2020-10-31 08:55:27 +00:00
private final MongoPlayerData mongoPlayerData = plugin . getMongoPlayerData ( ) ! = null ? plugin . getMongoPlayerData ( ) : null ;
private final SQLPlayerData sqlPlayerData = plugin . getSqlPlayerData ( ) ! = null ? plugin . getSqlPlayerData ( ) : null ;
2020-10-27 20:12:38 +00:00
2020-11-02 00:06:08 +00:00
// setting up a player's data
2020-11-06 01:29:38 +00:00
@EventHandler ( priority = EventPriority . HIGHEST )
2020-10-28 19:07:02 +00:00
public void onPlayerSetup ( PlayerJoinEvent event )
2020-10-27 20:12:38 +00:00
{
Player player = event . getPlayer ( ) ;
2020-10-27 21:04:05 +00:00
2020-11-06 18:19:38 +00:00
PlexPlayer plexPlayer ;
2020-10-27 21:04:05 +00:00
2020-11-06 18:19:38 +00:00
if ( ! DataUtils . hasPlayedBefore ( player . getUniqueId ( ) ) )
{
PlexLog . log ( " AYO THIS MAN DONT EXIST " ) ; // funi msg
plexPlayer = new PlexPlayer ( player . getUniqueId ( ) ) ; //it doesn't! okay so now create the object
plexPlayer . setName ( player . getName ( ) ) ; //set the name of the player
plexPlayer . setIps ( Arrays . asList ( player . getAddress ( ) . getAddress ( ) . getHostAddress ( ) . trim ( ) ) ) ; //set the arraylist of ips
DataUtils . insert ( plexPlayer ) ; // insert data in some wack db
} else {
plexPlayer = DataUtils . getPlayer ( player . getUniqueId ( ) ) ;
}
/ * if ( mongoPlayerData ! = null ) // Alright, check if we're saving with Mongo first
2020-10-27 20:12:38 +00:00
{
if ( ! mongoPlayerData . exists ( player . getUniqueId ( ) ) ) //okay, we're saving with mongo! now check if the player's document exists
{
PlexLog . log ( " AYO THIS MAN DONT EXIST " ) ; // funi msg
2020-10-27 21:04:05 +00:00
plexPlayer = new PlexPlayer ( player . getUniqueId ( ) ) ; //it doesn't! okay so now create the object
2020-10-27 20:12:38 +00:00
plexPlayer . setName ( player . getName ( ) ) ; //set the name of the player
plexPlayer . setIps ( Arrays . asList ( player . getAddress ( ) . getAddress ( ) . getHostAddress ( ) . trim ( ) ) ) ; //set the arraylist of ips
2020-10-28 04:11:23 +00:00
mongoPlayerData . save ( plexPlayer ) ; //and put their document in mongo collection
2020-10-28 03:49:56 +00:00
}
else
{
2020-10-27 21:04:05 +00:00
plexPlayer = mongoPlayerData . getByUUID ( player . getUniqueId ( ) ) ; //oh they do exist!
plexPlayer . setName ( plexPlayer . getName ( ) ) ; //set the name!
}
2020-10-28 03:49:56 +00:00
}
else if ( sqlPlayerData ! = null )
2020-10-27 21:04:05 +00:00
{
2020-10-31 08:55:27 +00:00
if ( ! sqlPlayerData . exists ( player . getUniqueId ( ) ) ) //okay, we're saving with sql! now check if the player's document exists
2020-10-27 21:04:05 +00:00
{
PlexLog . log ( " AYO THIS MAN DONT EXIST " ) ; // funi msg
plexPlayer = new PlexPlayer ( player . getUniqueId ( ) ) ; //it doesn't! okay so now create the object
plexPlayer . setName ( player . getName ( ) ) ; //set the name of the player
plexPlayer . setIps ( Arrays . asList ( player . getAddress ( ) . getAddress ( ) . getHostAddress ( ) . trim ( ) ) ) ; //set the arraylist of ips
2020-10-31 08:55:27 +00:00
sqlPlayerData . insert ( plexPlayer ) ; //and put their row into the sql table
2020-10-28 03:49:56 +00:00
}
else
{
2020-10-27 21:04:05 +00:00
plexPlayer = sqlPlayerData . getByUUID ( player . getUniqueId ( ) ) ; //oh they do exist!
2020-10-27 20:12:38 +00:00
plexPlayer . setName ( plexPlayer . getName ( ) ) ; //set the name!
}
2020-11-06 18:19:38 +00:00
} * /
2020-10-27 21:04:05 +00:00
PlayerCache . getPlexPlayerMap ( ) . put ( player . getUniqueId ( ) , plexPlayer ) ; //put them into the cache
PlayerCache . getPunishedPlayerMap ( ) . put ( player . getUniqueId ( ) , new PunishedPlayer ( player . getUniqueId ( ) ) ) ;
2020-10-28 19:07:02 +00:00
assert plexPlayer ! = null ;
2020-10-31 08:55:27 +00:00
if ( plugin . getRankManager ( ) . isAdmin ( plexPlayer ) )
2020-10-28 19:07:02 +00:00
{
2020-11-05 21:17:14 +00:00
Admin admin = new Admin ( UUID . fromString ( plexPlayer . getUuid ( ) ) ) ;
admin . setRank ( plexPlayer . getRankFromString ( ) ) ;
plugin . getAdminList ( ) . addToCache ( admin ) ;
2020-10-28 19:07:02 +00:00
if ( ! plexPlayer . getLoginMSG ( ) . isEmpty ( ) )
{
event . setJoinMessage ( ChatColor . AQUA + player . getName ( ) + " is " + plexPlayer . getLoginMSG ( ) ) ;
2020-11-06 01:29:38 +00:00
}
else
{
2020-10-28 19:07:02 +00:00
event . setJoinMessage ( ChatColor . AQUA + player . getName ( ) + " is " + plexPlayer . getRankFromString ( ) . getLoginMSG ( ) ) ;
}
}
2020-11-06 18:51:47 +00:00
/ * Punishment test = new Punishment ( player . getUniqueId ( ) , player . getUniqueId ( ) ) ;
test . setPunishedUsername ( player . getName ( ) ) ;
test . setReason ( " hii " ) ;
2020-11-10 02:47:03 +00:00
test . setType ( PunishmentType . BAN ) ;
test . setEndDate ( new Date ( Instant . now ( ) . plusSeconds ( 10 ) . getEpochSecond ( ) ) ) ;
plugin . getPunishmentManager ( ) . doPunishment ( PlayerCache . getPunishedPlayer ( player . getUniqueId ( ) ) , test ) ; * /
2020-11-06 18:51:47 +00:00
2020-10-27 20:12:38 +00:00
}
2020-11-02 00:06:08 +00:00
// saving the player's data
2020-11-03 02:24:25 +00:00
@EventHandler ( priority = EventPriority . HIGHEST )
2020-10-28 19:07:02 +00:00
public void onPlayerSave ( PlayerQuitEvent event )
2020-10-27 20:12:38 +00:00
{
2020-10-27 21:04:05 +00:00
PlexPlayer plexPlayer = PlayerCache . getPlexPlayerMap ( ) . get ( event . getPlayer ( ) . getUniqueId ( ) ) ; //get the player because it's literally impossible for them to not have an object
2020-11-05 21:17:14 +00:00
if ( plugin . getRankManager ( ) . isAdmin ( plexPlayer ) )
{
plugin . getAdminList ( ) . removeFromCache ( UUID . fromString ( plexPlayer . getUuid ( ) ) ) ;
}
2020-10-27 20:12:38 +00:00
if ( mongoPlayerData ! = null ) //back to mongo checking
{
2020-10-27 21:04:05 +00:00
mongoPlayerData . update ( plexPlayer ) ; //update the player's document
2020-10-28 03:49:56 +00:00
}
2020-10-31 08:55:27 +00:00
else if ( sqlPlayerData ! = null ) //sql checking
2020-10-27 21:04:05 +00:00
{
sqlPlayerData . update ( plexPlayer ) ;
2020-10-27 20:12:38 +00:00
}
2020-11-03 02:24:25 +00:00
if ( FionnCMD . ENABLED )
2020-11-06 01:29:38 +00:00
{
2020-11-03 02:24:25 +00:00
PlayerCache . getPunishedPlayer ( event . getPlayer ( ) . getUniqueId ( ) ) . setFrozen ( false ) ;
2020-11-06 01:29:38 +00:00
}
2020-11-03 02:24:25 +00:00
2020-10-27 21:04:05 +00:00
PlayerCache . getPlexPlayerMap ( ) . remove ( event . getPlayer ( ) . getUniqueId ( ) ) ; //remove them from cache
PlayerCache . getPunishedPlayerMap ( ) . remove ( event . getPlayer ( ) . getUniqueId ( ) ) ;
2020-11-05 21:17:14 +00:00
2020-10-27 20:12:38 +00:00
}
2020-10-28 19:07:02 +00:00
2020-11-02 00:06:08 +00:00
// unrelated player quitting
@EventHandler
public void onPlayerQuit ( PlayerQuitEvent e )
{
Player player = e . getPlayer ( ) ;
if ( FionnCMD . ENABLED )
{
player . setInvisible ( false ) ;
Location location = FionnCMD . LOCATION_CACHE . get ( player ) ;
if ( location ! = null )
2020-11-06 01:29:38 +00:00
{
2020-11-02 00:06:08 +00:00
player . teleport ( location ) ;
2020-11-06 01:29:38 +00:00
}
2020-11-02 00:06:08 +00:00
}
}
2020-10-27 20:12:38 +00:00
}