mirror of
https://github.com/SpigotMC/BungeeCord.git
synced 2025-01-27 18:11:37 +01:00
Fix async/login event
This commit is contained in:
parent
c08764990d
commit
6bf9df31f5
@ -15,14 +15,16 @@ import net.md_5.bungee.api.plugin.Plugin;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents an event which depends on the result of asynchronous operations.
|
* Represents an event which depends on the result of asynchronous operations.
|
||||||
|
*
|
||||||
|
* @param <T> Type of this event
|
||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@ToString(callSuper = true)
|
@ToString(callSuper = true)
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
public class AsyncEvent extends Event
|
public class AsyncEvent<T> extends Event
|
||||||
{
|
{
|
||||||
|
|
||||||
private final Callback done;
|
private final Callback<T> done;
|
||||||
private final Set<Plugin> intents = Collections.newSetFromMap( new ConcurrentHashMap<Plugin, Boolean>() );
|
private final Set<Plugin> intents = Collections.newSetFromMap( new ConcurrentHashMap<Plugin, Boolean>() );
|
||||||
private final AtomicBoolean fired = new AtomicBoolean();
|
private final AtomicBoolean fired = new AtomicBoolean();
|
||||||
private final AtomicInteger latch = new AtomicInteger();
|
private final AtomicInteger latch = new AtomicInteger();
|
||||||
@ -34,7 +36,7 @@ public class AsyncEvent extends Event
|
|||||||
fired.set( true );
|
fired.set( true );
|
||||||
if ( latch.get() == 0 )
|
if ( latch.get() == 0 )
|
||||||
{
|
{
|
||||||
done.done( this, null );
|
done.done( (T) this, null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,7 +68,7 @@ public class AsyncEvent extends Event
|
|||||||
intents.remove( plugin );
|
intents.remove( plugin );
|
||||||
if ( latch.decrementAndGet() == 0 )
|
if ( latch.decrementAndGet() == 0 )
|
||||||
{
|
{
|
||||||
done.done( this, null );
|
done.done( (T) this, null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,9 +3,9 @@ package net.md_5.bungee.api.event;
|
|||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.ToString;
|
import lombok.ToString;
|
||||||
|
import net.md_5.bungee.api.Callback;
|
||||||
import net.md_5.bungee.api.connection.PendingConnection;
|
import net.md_5.bungee.api.connection.PendingConnection;
|
||||||
import net.md_5.bungee.api.plugin.Cancellable;
|
import net.md_5.bungee.api.plugin.Cancellable;
|
||||||
import net.md_5.bungee.api.plugin.Event;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Event called to represent a player logging in.
|
* Event called to represent a player logging in.
|
||||||
@ -13,7 +13,7 @@ import net.md_5.bungee.api.plugin.Event;
|
|||||||
@Data
|
@Data
|
||||||
@ToString(callSuper = false)
|
@ToString(callSuper = false)
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
public class LoginEvent extends Event implements Cancellable
|
public class LoginEvent extends AsyncEvent<LoginEvent> implements Cancellable
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -28,4 +28,10 @@ public class LoginEvent extends Event implements Cancellable
|
|||||||
* Connection attempting to login.
|
* Connection attempting to login.
|
||||||
*/
|
*/
|
||||||
private final PendingConnection connection;
|
private final PendingConnection connection;
|
||||||
|
|
||||||
|
public LoginEvent(PendingConnection connection, Callback<LoginEvent> done)
|
||||||
|
{
|
||||||
|
super( done );
|
||||||
|
this.connection = connection;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,7 @@ import net.md_5.bungee.BungeeCord;
|
|||||||
import net.md_5.bungee.EncryptionUtil;
|
import net.md_5.bungee.EncryptionUtil;
|
||||||
import net.md_5.bungee.UserConnection;
|
import net.md_5.bungee.UserConnection;
|
||||||
import net.md_5.bungee.Util;
|
import net.md_5.bungee.Util;
|
||||||
|
import net.md_5.bungee.api.Callback;
|
||||||
import net.md_5.bungee.api.ChatColor;
|
import net.md_5.bungee.api.ChatColor;
|
||||||
import net.md_5.bungee.api.ProxyServer;
|
import net.md_5.bungee.api.ProxyServer;
|
||||||
import net.md_5.bungee.api.ServerPing;
|
import net.md_5.bungee.api.ServerPing;
|
||||||
@ -185,23 +186,36 @@ public class InitialHandler extends PacketHandler implements PendingConnection
|
|||||||
old.disconnect( "You are already connected to the server" );
|
old.disconnect( "You are already connected to the server" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Callback<LoginEvent> complete = new Callback<LoginEvent>()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void done(LoginEvent result, Throwable error)
|
||||||
|
{
|
||||||
|
if ( result.isCancelled() )
|
||||||
|
{
|
||||||
|
disconnect( result.getCancelReason() );
|
||||||
|
}
|
||||||
|
if ( disconnected )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Cipher encrypt = EncryptionUtil.getCipher( Cipher.ENCRYPT_MODE, sharedKey );
|
||||||
|
Cipher decrypt = EncryptionUtil.getCipher( Cipher.DECRYPT_MODE, sharedKey );
|
||||||
|
ch.write( new PacketFCEncryptionResponse() );
|
||||||
|
ch.pipeline().addBefore( "decoder", "cipher", new CipherCodec( encrypt, decrypt ) );
|
||||||
|
thisState = InitialHandler.State.LOGIN;
|
||||||
|
} catch ( GeneralSecurityException ex )
|
||||||
|
{
|
||||||
|
disconnect( "Cipher error: " + Util.exception( ex ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// fire login event
|
// fire login event
|
||||||
LoginEvent event = new LoginEvent( InitialHandler.this );
|
bungee.getPluginManager().callEvent( new LoginEvent( InitialHandler.this, complete ) );
|
||||||
if ( bungee.getPluginManager().callEvent( event ).isCancelled() )
|
|
||||||
{
|
|
||||||
disconnect( event.getCancelReason() );
|
|
||||||
}
|
|
||||||
if ( disconnected )
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Cipher encrypt = EncryptionUtil.getCipher( Cipher.ENCRYPT_MODE, sharedKey );
|
|
||||||
Cipher decrypt = EncryptionUtil.getCipher( Cipher.DECRYPT_MODE, sharedKey );
|
|
||||||
ch.write( new PacketFCEncryptionResponse() );
|
|
||||||
ch.pipeline().addBefore( "decoder", "cipher", new CipherCodec( encrypt, decrypt ) );
|
|
||||||
|
|
||||||
thisState = InitialHandler.State.LOGIN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user