Skip to content

Commit

Permalink
Updated BloodcatServer to use the new API. (fixes #139, 140)
Browse files Browse the repository at this point in the history
Signed-off-by: Jeffrey Han <[email protected]>
  • Loading branch information
itdelatrisu committed Sep 30, 2015
1 parent ab81717 commit 9c7dbce
Showing 1 changed file with 24 additions and 16 deletions.
40 changes: 24 additions & 16 deletions src/itdelatrisu/opsu/downloads/servers/BloodcatServer.java
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,10 @@ public class BloodcatServer extends DownloadServer {
private static final String DOWNLOAD_URL = "http://bloodcat.com/osu/s/%d";

/** Formatted search URL: {@code query,rankedOnly,page} */
private static final String SEARCH_URL = "http://bloodcat.com/osu/?q=%s&m=b&c=%s&g=&d=0&s=date&o=0&p=%d&mod=json";
private static final String SEARCH_URL = "http://bloodcat.com/osu/?q=%s&c=b&s=%s&m=0&p=%d&mod=json";//"?q=%s&m=b&c=%s&g=&d=0&s=date&o=0&p=%d&mod=json";

/** Maximum beatmaps displayed per page. */
private static final int PAGE_LIMIT = 40;

/** Total result count from the last query. */
private int totalResults = -1;
Expand All @@ -67,28 +70,32 @@ public DownloadNode[] resultList(String query, int page, boolean rankedOnly) thr
DownloadNode[] nodes = null;
try {
// read JSON
String search = String.format(SEARCH_URL, URLEncoder.encode(query, "UTF-8"), rankedOnly ? "0" : "", page);
JSONObject json = Utils.readJsonObjectFromUrl(new URL(search));
if (json == null) {
String search = String.format(SEARCH_URL, URLEncoder.encode(query, "UTF-8"), rankedOnly ? "1" : "", page);
JSONArray arr = Utils.readJsonArrayFromUrl(new URL(search));
if (arr == null) {
this.totalResults = -1;
return null;
}

// parse result list
JSONArray arr = json.getJSONArray("results");
//JSONArray arr = json.getJSONArray("results");
nodes = new DownloadNode[arr.length()];
for (int i = 0; i < nodes.length; i++) {
JSONObject item = arr.getJSONObject(i);
nodes[i] = new DownloadNode(
item.getInt("id"), formatDate(item.getString("date")),
item.getString("title"), item.isNull("titleUnicode") ? null : item.getString("titleUnicode"),
item.getString("artist"), item.isNull("artistUnicode") ? null : item.getString("artistUnicode"),
item.getInt("id"), formatDate(item.getString("synced")), //"date"
item.getString("title"), item.isNull("titleU") ? null : item.getString("titleU"), //"titleUnicode"
item.getString("artist"), item.isNull("artistU") ? null : item.getString("artistU"), //"artistUnicode"
item.getString("creator")
);
}

// store total result count
this.totalResults = json.getInt("resultCount");
//this.totalResults = arr.getInt("resultCount");
int resultCount = nodes.length + (page - 1) * PAGE_LIMIT;
if (nodes.length == PAGE_LIMIT)
resultCount++;
this.totalResults = resultCount;
} catch (MalformedURLException | UnsupportedEncodingException e) {
ErrorHandler.error(String.format("Problem loading result list for query '%s'.", query), e, true);
}
Expand All @@ -103,19 +110,20 @@ public DownloadNode[] resultList(String query, int page, boolean rankedOnly) thr

/**
* Returns a formatted date string from a raw date.
* @param s the raw date string (e.g. "2015-05-14T23:38:47+09:00")
* @param s the raw date string (e.g. "2015-09-30 09:39:04.536")
* @return the formatted date, or the raw string if it could not be parsed
*/
private String formatDate(String s) {
try {
// old format: "2015-05-14T23:38:47+09:00"
// make string parseable by SimpleDateFormat
int index = s.lastIndexOf(':');
if (index == -1)
return s;
String str = new StringBuilder(s).deleteCharAt(index).toString();
// int index = s.lastIndexOf(':');
// if (index == -1)
// return s;
// s = new StringBuilder(s).deleteCharAt(index).toString();

DateFormat f = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ");
Date d = f.parse(str);
DateFormat f = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS"); //"yyyy-MM-dd'T'HH:mm:ssZ"
Date d = f.parse(s);
DateFormat fmt = new SimpleDateFormat("d MMM yyyy HH:mm:ss");
return fmt.format(d);
} catch (StringIndexOutOfBoundsException | ParseException e) {
Expand Down

0 comments on commit 9c7dbce

Please sign in to comment.