Browse Source

Updated the crawler to be more smart about error codes and not crash on a http error 500 or 401.

pull/8/head
jrtechs 6 years ago
parent
commit
ae25cc020b
6 changed files with 138 additions and 13 deletions
  1. +10
    -0
      pom.xml
  2. +10
    -0
      runCrawler.sh
  3. +64
    -10
      src/main/java/net/jrtechs/www/SteamAPI/APIConnection.java
  4. +11
    -0
      src/main/java/net/jrtechs/www/SteamAPI/ConnectionErrors.java
  5. +20
    -0
      src/main/java/net/jrtechs/www/SteamAPI/SteamConnectionException.java
  6. +23
    -3
      src/main/java/net/jrtechs/www/utils/WebScraper.java

+ 10
- 0
pom.xml View File

@ -16,6 +16,9 @@
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target> <maven.compiler.target>1.8</maven.compiler.target>
<gson.version>2.8.5</gson.version>
</properties> </properties>
<dependencies> <dependencies>
@ -61,6 +64,13 @@
<version>1.3.0</version> <version>1.3.0</version>
</dependency> </dependency>
<!-- JSON utils -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>${gson.version}</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.janusgraph/janusgraph-core --> <!-- https://mvnrepository.com/artifact/org.janusgraph/janusgraph-core -->
<!--<dependency>--> <!--<dependency>-->
<!--<groupId>org.janusgraph</groupId>--> <!--<groupId>org.janusgraph</groupId>-->

+ 10
- 0
runCrawler.sh View File

@ -0,0 +1,10 @@
#!/bin/bash
# run - this script enters a infinite loop to ensure that
# the socket server does not go down
#
# 7/14/18 Jeffery Russell
while true
do java -cp SteamFriendsGraph-0.1-jar-with-dependencies.jar net.jrtechs.www.webCrawler.SteamWebCrawler
done

+ 64
- 10
src/main/java/net/jrtechs/www/SteamAPI/APIConnection.java View File

@ -4,6 +4,7 @@ import net.jrtechs.www.server.Player;
import net.jrtechs.www.utils.ConfigLoader; import net.jrtechs.www.utils.ConfigLoader;
import net.jrtechs.www.utils.WebScraper; import net.jrtechs.www.utils.WebScraper;
import net.jrtechs.www.webCrawler.APIThrottler;
import org.json.JSONArray; import org.json.JSONArray;
import org.json.JSONObject; import org.json.JSONObject;
@ -58,9 +59,43 @@ public class APIConnection
try try
{ {
new JSONObject(WebScraper
.getWebsite(this.baseURL + this.friendListURL +
this.apiKey + "&steamid=" + steamid))
String apiData = "";
try
{
apiData = WebScraper
.getWebsite(this.baseURL + this.friendListURL +
this.apiKey + "&steamid=" + steamid);
}
catch (SteamConnectionException e)
{
switch (e.getError())
{
case RESTRICTED:
{
//This is fine
System.out.println("Private profile: " + steamid);
return friendsId;
}
case CONNECTION:
{
//spooky 500 error :(
new APIThrottler().wait(120);
try
{
apiData = WebScraper
.getWebsite(this.baseURL + this.friendListURL +
this.apiKey + "&steamid=" + steamid);
}
catch (SteamConnectionException exception2)
{
throw new Exception("Everything is dead");
}
}
}
}
new JSONObject(apiData)
.getJSONObject("friendslist") .getJSONObject("friendslist")
.getJSONArray("friends").toList() .getJSONArray("friends").toList()
.forEach(f-> .forEach(f->
@ -69,8 +104,8 @@ public class APIConnection
} }
catch (Exception ex) catch (Exception ex)
{ {
System.out.println("Friends not public :(");
//ex.printStackTrace();
ex.printStackTrace();
System.exit(-1);
} }
return friendsId; return friendsId;
@ -103,8 +138,17 @@ public class APIConnection
} }
System.out.println(queryUrl); System.out.println(queryUrl);
JSONArray names = new JSONObject(WebScraper.getWebsite(queryUrl))
.getJSONObject("response").getJSONArray("players");
JSONArray names;
try
{
names = new JSONObject(WebScraper.getWebsite(queryUrl))
.getJSONObject("response").getJSONArray("players");
}
catch (SteamConnectionException ex)
{
//meh
return map;
}
for(int i = 0; i < names.length(); i++) for(int i = 0; i < names.length(); i++)
{ {
@ -143,6 +187,7 @@ public class APIConnection
} }
/** /**
* Returns the name of the player with a specific steam id * Returns the name of the player with a specific steam id
* *
@ -151,9 +196,18 @@ public class APIConnection
*/ */
public String getPlayerName(String steamid) public String getPlayerName(String steamid)
{ {
JSONObject response = new JSONObject(WebScraper
.getWebsite(this.baseURL + this.playerInfoURL +
this.apiKey + "&steamids=" + steamid));
JSONObject response;
try
{
response = new JSONObject(WebScraper
.getWebsite(this.baseURL + this.playerInfoURL +
this.apiKey + "&steamids=" + steamid));
}
catch (SteamConnectionException ex)
{
return "";
}
if(response.has("response")) if(response.has("response"))
{ {

+ 11
- 0
src/main/java/net/jrtechs/www/SteamAPI/ConnectionErrors.java View File

@ -0,0 +1,11 @@
package net.jrtechs.www.SteamAPI;
/**
* @author Jeffery Russell 11-19-18
*/
public enum ConnectionErrors
{
VALID,
CONNECTION,
RESTRICTED
}

+ 20
- 0
src/main/java/net/jrtechs/www/SteamAPI/SteamConnectionException.java View File

@ -0,0 +1,20 @@
package net.jrtechs.www.SteamAPI;
/**
* @author Jeffery Russell 11-19-18
*/
public class SteamConnectionException extends Exception
{
private ConnectionErrors error;
public SteamConnectionException(ConnectionErrors error)
{
this.error = error;
}
public ConnectionErrors getError() {
return error;
}
}

+ 23
- 3
src/main/java/net/jrtechs/www/utils/WebScraper.java View File

@ -1,5 +1,8 @@
package net.jrtechs.www.utils; package net.jrtechs.www.utils;
import net.jrtechs.www.SteamAPI.ConnectionErrors;
import net.jrtechs.www.SteamAPI.SteamConnectionException;
import java.io.*; import java.io.*;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.URL; import java.net.URL;
@ -17,22 +20,39 @@ public class WebScraper
* @param link to open * @param link to open
* @return source code of website as a single string * @return source code of website as a single string
*/ */
public static String getWebsite(String link)
public static String getWebsite(String link) throws SteamConnectionException
{ {
try try
{ {
URL url = new URL(link); URL url = new URL(link);
HttpURLConnection connection = (HttpURLConnection)url.openConnection();
connection.setRequestMethod("GET");
connection.connect();
int code = connection.getResponseCode();
switch (code)
{
case 401:
throw new SteamConnectionException(ConnectionErrors.RESTRICTED);
case 500:
throw new SteamConnectionException(ConnectionErrors.CONNECTION);
default:
}
BufferedReader br = new BufferedReader( BufferedReader br = new BufferedReader(
new InputStreamReader(url.openStream()) new InputStreamReader(url.openStream())
); );
return WebScraper.getBufferedReaderData(br); return WebScraper.getBufferedReaderData(br);
} }
catch (SteamConnectionException e)
{
throw e;
}
catch (Exception e) catch (Exception e)
{ {
e.printStackTrace();
throw new SteamConnectionException(ConnectionErrors.CONNECTION);
} }
return "";
} }

Loading…
Cancel
Save