Merge pull request #633 from devLotto/improve-remember-username

Improve Remember Username plugin
This commit is contained in:
Adam
2018-02-21 19:25:30 -05:00
committed by GitHub
6 changed files with 99 additions and 27 deletions

View File

@@ -284,4 +284,6 @@ public interface Client extends GameEngine
ClanMember[] getClanMembers(); ClanMember[] getClanMembers();
boolean isClanMember(String name); boolean isClanMember(String name);
Preferences getPreferences();
} }

View File

@@ -0,0 +1,32 @@
/*
* Copyright (c) 2018, Lotto <https://github.com/devLotto>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.api;
public interface Preferences
{
String getRememberedUsername();
void setRememberedUsername(String username);
}

View File

@@ -22,7 +22,7 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.runelite.client.plugins.rememberusername; package net.runelite.client.plugins.usernamesyncer;
import net.runelite.client.config.Config; import net.runelite.client.config.Config;
import net.runelite.client.config.ConfigGroup; import net.runelite.client.config.ConfigGroup;
@@ -30,10 +30,10 @@ import net.runelite.client.config.ConfigItem;
@ConfigGroup( @ConfigGroup(
keyName = "rememberusername", keyName = "rememberusername",
name = "Remember Username", name = "Username Syncer",
description = "Configuration for the remember username plugin" description = "Syncs the username that is currently remembered between computers"
) )
public interface RememberUsernameConfig extends Config public interface UsernameSyncerConfig extends Config
{ {
@ConfigItem( @ConfigItem(
keyName = "username", keyName = "username",

View File

@@ -22,12 +22,11 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.runelite.client.plugins.rememberusername; package net.runelite.client.plugins.usernamesyncer;
import com.google.common.base.Strings; import com.google.common.base.Strings;
import com.google.common.eventbus.Subscribe; import com.google.common.eventbus.Subscribe;
import com.google.inject.Provides; import com.google.inject.Provides;
import java.util.Objects;
import javax.inject.Inject; import javax.inject.Inject;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import net.runelite.api.Client; import net.runelite.api.Client;
@@ -39,16 +38,16 @@ import net.runelite.client.plugins.Plugin;
import net.runelite.client.plugins.PluginDescriptor; import net.runelite.client.plugins.PluginDescriptor;
@PluginDescriptor( @PluginDescriptor(
name = "Remember username" name = "Username Syncer"
) )
@Slf4j @Slf4j
public class RememberUsernamePlugin extends Plugin public class UsernameSyncerPlugin extends Plugin
{ {
@Inject @Inject
private Client client; private Client client;
@Inject @Inject
private RememberUsernameConfig config; private UsernameSyncerConfig config;
@Override @Override
protected void startUp() throws Exception protected void startUp() throws Exception
@@ -56,22 +55,10 @@ public class RememberUsernamePlugin extends Plugin
applyUsername(); applyUsername();
} }
protected void shutDown() throws Exception
{
GameState gameState = client.getGameState();
if (gameState == GameState.LOGIN_SCREEN)
{
if (Objects.equals(config.username(), client.getUsername()))
{
client.setUsername("");
}
}
}
@Provides @Provides
RememberUsernameConfig getConfig(ConfigManager configManager) UsernameSyncerConfig getConfig(ConfigManager configManager)
{ {
return configManager.getConfig(RememberUsernameConfig.class); return configManager.getConfig(UsernameSyncerConfig.class);
} }
@Subscribe @Subscribe
@@ -83,13 +70,20 @@ public class RememberUsernamePlugin extends Plugin
} }
else if (event.getGameState() == GameState.LOGGED_IN) else if (event.getGameState() == GameState.LOGGED_IN)
{ {
if (config.username().equals(client.getUsername())) String username = "";
if (client.getPreferences().getRememberedUsername() != null)
{
username = client.getUsername();
}
if (config.username().equals(username))
{ {
return; return;
} }
log.debug("Saving username: {}", client.getUsername()); log.debug("Saving username: {}", username);
config.username(client.getUsername()); config.username(username);
} }
} }
@@ -106,12 +100,13 @@ public class RememberUsernamePlugin extends Plugin
if (gameState == GameState.LOGIN_SCREEN) if (gameState == GameState.LOGIN_SCREEN)
{ {
String username = config.username(); String username = config.username();
if (Strings.isNullOrEmpty(username)) if (Strings.isNullOrEmpty(username))
{ {
return; return;
} }
client.setUsername(username); client.getPreferences().setRememberedUsername(username);
} }
} }
} }

View File

@@ -468,4 +468,8 @@ public interface RSClient extends RSGameEngine, Client
@Import("varbits") @Import("varbits")
RSNodeCache getVarbitCache(); RSNodeCache getVarbitCache();
@Import("preferences")
@Override
RSPreferences getPreferences();
} }

View File

@@ -0,0 +1,39 @@
/*
* Copyright (c) 2018, Lotto <https://github.com/devLotto>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.rs.api;
import net.runelite.api.Preferences;
import net.runelite.mapping.Import;
public interface RSPreferences extends Preferences
{
@Import("rememberedUsername")
@Override
String getRememberedUsername();
@Import("rememberedUsername")
@Override
void setRememberedUsername(String username);
}