Add support for Instagram albums
This commit is contained in:
commit
500120c762
@ -109,20 +109,7 @@ public class InstagramRipper extends AbstractJSONRipper {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private String getOriginalUrl(String imageURL) {
|
||||||
public List<String> getURLsFromJSON(JSONObject json) {
|
|
||||||
List<String> imageURLs = new ArrayList<String>();
|
|
||||||
JSONArray datas = json.getJSONArray("items");
|
|
||||||
for (int i = 0; i < datas.length(); i++) {
|
|
||||||
JSONObject data = (JSONObject) datas.get(i);
|
|
||||||
String imageURL;
|
|
||||||
if (data.has("videos")) {
|
|
||||||
imageURL = data.getJSONObject("videos").getJSONObject("standard_resolution").getString("url");
|
|
||||||
} else if (data.has("images")) {
|
|
||||||
imageURL = data.getJSONObject("images").getJSONObject("standard_resolution").getString("url");
|
|
||||||
} else {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
imageURL = imageURL.replaceAll("scontent.cdninstagram.com/hphotos-", "igcdn-photos-d-a.akamaihd.net/hphotos-ak-");
|
imageURL = imageURL.replaceAll("scontent.cdninstagram.com/hphotos-", "igcdn-photos-d-a.akamaihd.net/hphotos-ak-");
|
||||||
imageURL = imageURL.replaceAll("s640x640/", "");
|
imageURL = imageURL.replaceAll("s640x640/", "");
|
||||||
|
|
||||||
@ -132,7 +119,45 @@ public class InstagramRipper extends AbstractJSONRipper {
|
|||||||
imageURL = imageURL.replaceAll("c0.114.1080.1080/", "");
|
imageURL = imageURL.replaceAll("c0.114.1080.1080/", "");
|
||||||
|
|
||||||
imageURL = imageURL.replaceAll("\\?ig_cache_key.+$", "");
|
imageURL = imageURL.replaceAll("\\?ig_cache_key.+$", "");
|
||||||
|
return imageURL;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getMedia(JSONObject data) {
|
||||||
|
String imageURL = "";
|
||||||
|
if (data.has("videos")) {
|
||||||
|
imageURL = data.getJSONObject("videos").getJSONObject("standard_resolution").getString("url");
|
||||||
|
} else if (data.has("images")) {
|
||||||
|
imageURL = data.getJSONObject("images").getJSONObject("standard_resolution").getString("url");
|
||||||
|
}
|
||||||
|
return imageURL;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<String> getURLsFromJSON(JSONObject json) {
|
||||||
|
List<String> imageURLs = new ArrayList<String>();
|
||||||
|
JSONArray datas = json.getJSONArray("items");
|
||||||
|
for (int i = 0; i < datas.length(); i++) {
|
||||||
|
JSONObject data = (JSONObject) datas.get(i);
|
||||||
|
|
||||||
|
String dataType = data.getString("type");
|
||||||
|
if (dataType.equals("carousel")) {
|
||||||
|
JSONArray carouselMedias = data.getJSONArray("carousel_media");
|
||||||
|
for (int carouselIndex = 0; carouselIndex < carouselMedias.length(); carouselIndex++) {
|
||||||
|
JSONObject carouselMedia = (JSONObject) carouselMedias.get(carouselIndex);
|
||||||
|
String imageURL = getMedia(carouselMedia);
|
||||||
|
if (!imageURL.equals("")) {
|
||||||
|
imageURL = getOriginalUrl(imageURL);
|
||||||
imageURLs.add(imageURL);
|
imageURLs.add(imageURL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
String imageURL = getMedia(data);
|
||||||
|
if (!imageURL.equals("")) {
|
||||||
|
imageURL = getOriginalUrl(imageURL);
|
||||||
|
imageURLs.add(imageURL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (isThisATest()) {
|
if (isThisATest()) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user