Skip to content

Commit

Permalink
project: Add xtea base, Fix session base
Browse files Browse the repository at this point in the history
  • Loading branch information
Therealnull committed Jan 17, 2020
1 parent 89bbf84 commit cd43ef6
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 81 deletions.
19 changes: 0 additions & 19 deletions cache/src/main/java/net/runelite/cache/util/XteaKeyManager.java
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,8 @@
*/
package net.runelite.cache.util;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import net.runelite.http.api.xtea.XteaClient;
import net.runelite.http.api.xtea.XteaKey;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

Expand All @@ -40,23 +37,7 @@ public class XteaKeyManager

public void loadKeys()
{
XteaClient xteaClient = new XteaClient();

try
{
for (XteaKey key : xteaClient.get())
{
keys.put(key.getRegion(), key.getKeys());
}
}
catch (IOException ex)
{
// happens on release when it is not deployed yet
logger.debug("unable to load xtea keys", ex);
return;
}

logger.info("Loaded {} keys", keys.size());
}

public int[] getKeys(int region)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,8 @@ public class RuneLiteAPI
private static final String STATICBASE = "https://static.runelite.net";

private static final String OPENOSRS_BASE = /*"https://api.openosrs.com*/ "https://api.runelitepl.us";
private static final String OPENOSRS_SESSION = "http://www.openosrs.dev/session";
private static final String OPENOSRS_SESSION = "http://session.openosrs.dev";
private static final String OPENOSRS_XTEA = "http://xtea.openosrs.dev";
private static final String MAVEN_METADATA = "http://repo.runelite.net/net/runelite/runelite-parent/maven-metadata.xml";

private static final Properties properties = new Properties();
Expand Down Expand Up @@ -121,6 +122,11 @@ public static HttpUrl getSessionBase()
return HttpUrl.parse(OPENOSRS_SESSION);
}

public static HttpUrl getXteaBase()
{
return HttpUrl.parse(OPENOSRS_XTEA);
}

public static HttpUrl getApiBase()
{
final String prop = System.getProperty("runelite.http-service.url");
Expand Down
50 changes: 13 additions & 37 deletions http-api/src/main/java/net/runelite/http/api/xtea/XteaClient.java
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,12 @@
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.List;
import java.util.HashMap;
import net.runelite.http.api.RuneLiteAPI;
import static net.runelite.http.api.RuneLiteAPI.JSON;
import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.HttpUrl;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
Expand All @@ -45,19 +43,19 @@ public class XteaClient
{
private static final Logger logger = LoggerFactory.getLogger(XteaClient.class);

public void submit(XteaRequest xteaRequest)
public void submit(int region, int[] keys)
{
String json = RuneLiteAPI.GSON.toJson(xteaRequest);

HttpUrl url = RuneLiteAPI.getOpenOSRSApiBase().newBuilder()
.addPathSegment("xtea")
HttpUrl url = RuneLiteAPI.getXteaBase().newBuilder()
.addPathSegment("submit")
.addQueryParameter("region", String.valueOf(region))
.addQueryParameter("key1", String.valueOf(keys[0]))
.addQueryParameter("key2", String.valueOf(keys[1]))
.addQueryParameter("key3", String.valueOf(keys[2]))
.addQueryParameter("key4", String.valueOf(keys[3]))
.build();

logger.debug("Built URI: {}", url);

RequestBody body = RequestBody.Companion.create(json, JSON);
Request request = new Request.Builder()
.post(body)
.url(url)
.build();

Expand Down Expand Up @@ -87,10 +85,10 @@ public void onResponse(Call call, Response response)
});
}

public List<XteaKey> get() throws IOException
public HashMap<Integer, int[]> get() throws IOException
{
HttpUrl url = RuneLiteAPI.getOpenOSRSApiBase().newBuilder()
.addPathSegment("xtea")
HttpUrl url = RuneLiteAPI.getXteaBase().newBuilder()
.addPathSegment("get")
.build();

Request request = new Request.Builder()
Expand All @@ -101,34 +99,12 @@ public List<XteaKey> get() throws IOException
{
InputStream in = response.body().byteStream();
// CHECKSTYLE:OFF
return RuneLiteAPI.GSON.fromJson(new InputStreamReader(in), new TypeToken<List<XteaKey>>() {}.getType());
return RuneLiteAPI.GSON.fromJson(new InputStreamReader(in), new TypeToken<HashMap<Integer, Integer[]>>() {}.getType());
// CHECKSTYLE:ON
}
catch (JsonParseException ex)
{
throw new IOException(ex);
}
}

public XteaKey get(int region) throws IOException
{
HttpUrl url = RuneLiteAPI.getOpenOSRSApiBase().newBuilder()
.addPathSegment("xtea")
.addPathSegment(Integer.toString(region))
.build();

Request request = new Request.Builder()
.url(url)
.build();

try (Response response = RuneLiteAPI.CLIENT.newCall(request).execute())
{
InputStream in = response.body().byteStream();
return RuneLiteAPI.GSON.fromJson(new InputStreamReader(in), XteaKey.class);
}
catch (JsonParseException ex)
{
throw new IOException(ex);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,18 +24,17 @@
*/
package net.runelite.client.plugins.xtea;

import java.util.HashSet;
import java.util.Set;
import java.io.IOException;
import java.util.HashMap;
import javax.inject.Inject;
import lombok.extern.slf4j.Slf4j;
import net.runelite.api.Client;
import net.runelite.api.GameState;
import net.runelite.api.events.GameStateChanged;
import net.runelite.client.eventbus.Subscribe;
import net.runelite.client.plugins.Plugin;
import net.runelite.client.plugins.PluginDescriptor;
import net.runelite.http.api.xtea.XteaClient;
import net.runelite.http.api.xtea.XteaKey;
import net.runelite.http.api.xtea.XteaRequest;

@PluginDescriptor(
name = "Xtea",
Expand All @@ -46,38 +45,43 @@ public class XteaPlugin extends Plugin
{
private final XteaClient xteaClient = new XteaClient();

private final Set<Integer> sentRegions = new HashSet<>();
private HashMap<Integer, int[]> xteas;
{
try
{
xteas = xteaClient.get();
}
catch (IOException e)
{
e.printStackTrace();
}
}

@Inject
private Client client;

// todo re-enable when we have our server back up.
// @Subscribe
@Subscribe
private void onGameStateChanged(GameStateChanged gameStateChanged)
{
if (gameStateChanged.getGameState() != GameState.LOGGED_IN)
{
return;
}

int revision = client.getRevision();
int[] regions = client.getMapRegions();
int[][] xteaKeys = client.getXteaKeys();

XteaRequest xteaRequest = new XteaRequest();
xteaRequest.setRevision(revision);

for (int idx = 0; idx < regions.length; ++idx)
{
int region = regions[idx];
int[] keys = xteaKeys[idx];

if (sentRegions.contains(region))
if (xteas.get(region) != null)
{
continue;
}

sentRegions.add(region);
xteas.put(region, keys);

log.debug("Region {} keys {}, {}, {}, {}", region, keys[0], keys[1], keys[2], keys[3]);

Expand All @@ -87,17 +91,7 @@ private void onGameStateChanged(GameStateChanged gameStateChanged)
continue;
}

XteaKey xteaKey = new XteaKey();
xteaKey.setRegion(region);
xteaKey.setKeys(keys);
xteaRequest.addKey(xteaKey);
}

if (xteaRequest.getKeys().isEmpty())
{
return;
xteaClient.submit(region, keys);
}

xteaClient.submit(xteaRequest);
}
}

0 comments on commit cd43ef6

Please sign in to comment.