Search in sources :

Example 1 with SQLStorage

use of com.github.games647.fastlogin.core.storage.SQLStorage in project FastLogin by games647.

the class ForceLoginManagement method run.

@Override
public void run() {
    if (!isOnline(player)) {
        core.getPlugin().getLog().info("Player {} disconnected", player);
        return;
    }
    if (session == null) {
        core.getPlugin().getLog().info("No valid session found for {}", player);
        return;
    }
    SQLStorage storage = core.getStorage();
    StoredProfile playerProfile = session.getProfile();
    try {
        if (isOnlineMode()) {
            // premium player
            AuthPlugin<P> authPlugin = core.getAuthPluginHook();
            if (authPlugin == null) {
                // maybe only bungeecord plugin
                onForceActionSuccess(session);
            } else {
                boolean success = true;
                String playerName = getName(player);
                if (core.getConfig().get("autoLogin", true)) {
                    if (session.needsRegistration() || (core.getConfig().get("auto-register-unknown", false) && !authPlugin.isRegistered(playerName))) {
                        success = forceRegister(player);
                    } else if (!callFastLoginAutoLoginEvent(session, playerProfile).isCancelled()) {
                        success = forceLogin(player);
                    }
                }
                if (success) {
                    // update only on success to prevent corrupt data
                    if (playerProfile != null) {
                        playerProfile.setId(session.getUuid());
                        playerProfile.setPremium(true);
                        storage.save(playerProfile);
                    }
                    onForceActionSuccess(session);
                }
            }
        } else if (playerProfile != null) {
            // cracked player
            playerProfile.setId(null);
            playerProfile.setPremium(false);
            storage.save(playerProfile);
        }
    } catch (Exception ex) {
        core.getPlugin().getLog().warn("ERROR ON FORCE LOGIN of {}", getName(player), ex);
    }
}
Also used : StoredProfile(com.github.games647.fastlogin.core.StoredProfile) SQLStorage(com.github.games647.fastlogin.core.storage.SQLStorage)

Aggregations

StoredProfile (com.github.games647.fastlogin.core.StoredProfile)1 SQLStorage (com.github.games647.fastlogin.core.storage.SQLStorage)1