remember cached locations & stuff

This commit is contained in:
sirjonasxx 2018-10-13 17:17:03 +02:00
parent 7724dbea14
commit 0733de713a
2 changed files with 13 additions and 4 deletions

Binary file not shown.

View File

@ -31,6 +31,10 @@ public class WindowsHabboClient extends HabboClient {
private static final int PRODUCTIONID = 4000; private static final int PRODUCTIONID = 4000;
private String production = ""; private String production = "";
private String getOffsetsCacheKey() {
return production + "-RC4Offsets";
}
@Override @Override
public List<byte[]> getRC4cached() { public List<byte[]> getRC4cached() {
List<byte[]> result = new ArrayList<>(); List<byte[]> result = new ArrayList<>();
@ -50,7 +54,7 @@ public class WindowsHabboClient extends HabboClient {
private ArrayList<String> readPossibleBytes(boolean useCache) throws IOException, URISyntaxException { private ArrayList<String> readPossibleBytes(boolean useCache) throws IOException, URISyntaxException {
ProcessBuilder pb = null; ProcessBuilder pb = null;
List<String> cachedOffsets = (List<String>) Cacher.get("RC4Offsets"); List<String> cachedOffsets = (List<String>) Cacher.get(getOffsetsCacheKey());
StringJoiner joiner = new StringJoiner(" "); StringJoiner joiner = new StringJoiner(" ");
if (useCache) { if (useCache) {
@ -75,19 +79,24 @@ public class WindowsHabboClient extends HabboClient {
String line; String line;
ArrayList<String> possibleData = new ArrayList<>(); ArrayList<String> possibleData = new ArrayList<>();
if (cachedOffsets == null) {
cachedOffsets = new ArrayList<>(); cachedOffsets = new ArrayList<>();
}
int count = 0; int count = 0;
while((line = reader.readLine()) != null) { while((line = reader.readLine()) != null) {
if (line.length() > 1) { if (line.length() > 1) {
if (!useCache && (count++ % 2 == 0)) { if (!useCache && (count++ % 2 == 0)) {
if (!cachedOffsets.contains(line)) {
cachedOffsets.add(line); cachedOffsets.add(line);
} }
}
else else
possibleData.add(line); possibleData.add(line);
} }
} }
Cacher.put("RC4Offsets", cachedOffsets); Cacher.put(getOffsetsCacheKey(), cachedOffsets);
p.destroy(); p.destroy();
return possibleData; return possibleData;
} }