1
0
mirror of https://github.com/RipMeApp/ripme.git synced 2025-01-19 05:28:03 +01:00

1.2.12 - 500px: Support 'galleries' and subgalleries

Closes #282
This commit is contained in:
4pr0n 2016-04-17 05:44:25 -07:00
parent 1105c9c170
commit 68c6697207
3 changed files with 77 additions and 3 deletions

View File

@ -4,7 +4,7 @@
<groupId>com.rarchives.ripme</groupId> <groupId>com.rarchives.ripme</groupId>
<artifactId>ripme</artifactId> <artifactId>ripme</artifactId>
<packaging>jar</packaging> <packaging>jar</packaging>
<version>1.2.11</version> <version>1.2.12</version>
<name>ripme</name> <name>ripme</name>
<url>http://rip.rarchives.com</url> <url>http://rip.rarchives.com</url>
<properties> <properties>

View File

@ -98,6 +98,40 @@ public class FivehundredpxRipper extends AbstractJSONRipper {
return username + "_faves"; return username + "_faves";
} }
// http://500px.com/tsyganov/galleries
p = Pattern.compile("^.*500px.com/([a-zA-Z0-9\\-_]+)/galleries/?$");
m = p.matcher(url.toExternalForm());
if (m.matches()) {
String username = m.group(1);
String userID;
try {
userID = getUserID(username);
} catch (IOException e) {
throw new MalformedURLException("Unable to get User ID from username (" + username + ")");
}
baseURL += "/users/" + userID + "/galleries"
+ "?rpp=100";
return username + "_galleries";
}
// https://500px.com/getesmart86/galleries/olga
p = Pattern.compile("^.*500px.com/([a-zA-Z0-9\\-_]+)/galleries/([a-zA-Z0-9\\-_]+)/?$");
m = p.matcher(url.toExternalForm());
if (m.matches()) {
String username = m.group(1);
String subgallery = m.group(2);
String userID;
try {
userID = getUserID(username);
} catch (IOException e) {
throw new MalformedURLException("Unable to get User ID from username (" + username + ")");
}
baseURL += "/users/" + userID + "/galleries/" + subgallery + "/items"
+ "?rpp=100"
+ "&image_size=5";
return username + "_galleries_" + subgallery;
}
// http://500px.com/tsyganov (photos) // http://500px.com/tsyganov (photos)
p = Pattern.compile("^.*500px.com/([a-zA-Z0-9\\-_]+)/?$"); p = Pattern.compile("^.*500px.com/([a-zA-Z0-9\\-_]+)/?$");
m = p.matcher(url.toExternalForm()); m = p.matcher(url.toExternalForm());
@ -117,12 +151,52 @@ public class FivehundredpxRipper extends AbstractJSONRipper {
+ " Got: " + url); + " Got: " + url);
} }
/** Convert username to UserID. */
private String getUserID(String username) throws IOException {
logger.info("Fetching user ID for " + username);
JSONObject json = new Http("https://api.500px.com/v1/" +
"users/show" +
"?username=" + username +
"&consumer_key=" + CONSUMER_KEY)
.getJSON();
return Long.toString(json.getJSONObject("user").getLong("id"));
}
@Override @Override
public JSONObject getFirstPage() throws IOException { public JSONObject getFirstPage() throws IOException {
URL apiURL = new URL(baseURL + "&consumer_key=" + CONSUMER_KEY); URL apiURL = new URL(baseURL + "&consumer_key=" + CONSUMER_KEY);
logger.debug("apiURL: " + apiURL); logger.debug("apiURL: " + apiURL);
JSONObject json = Http.url(apiURL).getJSON(); JSONObject json = Http.url(apiURL).getJSON();
if (baseURL.contains("/blogs?")) {
if (baseURL.contains("/galleries?")) {
// We're in the root /galleries folder, need to get all images from all galleries.
JSONObject result = new JSONObject();
result.put("photos", new JSONArray());
// Iterate over every gallery
JSONArray jsonGalleries = json.getJSONArray("galleries");
for (int i = 0; i < jsonGalleries.length(); i++) {
if (i > 0) {
sleep(500);
}
JSONObject jsonGallery = jsonGalleries.getJSONObject(i);
long galleryID = jsonGallery.getLong("id");
String userID = Long.toString(jsonGallery.getLong("user_id"));
String blogURL = "https://api.500px.com/v1/users/" + userID + "/galleries/" + galleryID + "/items"
+ "?rpp=100"
+ "&image_size=5"
+ "&consumer_key=" + CONSUMER_KEY;
logger.info("Loading " + blogURL);
sendUpdate(STATUS.LOADING_RESOURCE, "Gallery ID " + galleryID + " for userID " + userID);
JSONObject thisJSON = Http.url(blogURL).getJSON();
JSONArray thisPhotos = thisJSON.getJSONArray("photos");
// Iterate over every image in this story
for (int j = 0; j < thisPhotos.length(); j++) {
result.getJSONArray("photos").put(thisPhotos.getJSONObject(j));
}
}
return result;
}
else if (baseURL.contains("/blogs?")) {
// List of stories to return // List of stories to return
JSONObject result = new JSONObject(); JSONObject result = new JSONObject();
result.put("photos", new JSONArray()); result.put("photos", new JSONArray());

View File

@ -21,7 +21,7 @@ import com.rarchives.ripme.utils.Utils;
public class UpdateUtils { public class UpdateUtils {
private static final Logger logger = Logger.getLogger(UpdateUtils.class); private static final Logger logger = Logger.getLogger(UpdateUtils.class);
private static final String DEFAULT_VERSION = "1.2.11"; private static final String DEFAULT_VERSION = "1.2.12";
private static final String updateJsonURL = "http://rarchives.com/ripme.json"; private static final String updateJsonURL = "http://rarchives.com/ripme.json";
private static final String updateJarURL = "http://rarchives.com/ripme.jar"; private static final String updateJarURL = "http://rarchives.com/ripme.jar";
private static final String mainFileName = "ripme.jar"; private static final String mainFileName = "ripme.jar";