forked from j62/ctbrec
1
0
Fork 0

Use live previews for Stripchat thumbs where available

This commit is contained in:
0xb00bface 2022-05-07 18:06:43 +02:00
parent 0c4cdfb795
commit be225a1613
3 changed files with 55 additions and 34 deletions

View File

@ -0,0 +1,24 @@
package ctbrec.ui.sites.stripchat;
import ctbrec.StringUtil;
import ctbrec.ui.tabs.PaginatedScheduledService;
import org.json.JSONObject;
import java.text.MessageFormat;
public abstract class AbstractStripchatUpdateService extends PaginatedScheduledService {
protected String getPreviewUrl(JSONObject model) {
try {
long id = model.getLong("id");
long timestamp = model.getLong("snapshotTimestamp");
String snapshotServer = model.getString("snapshotServer");
if (timestamp == 0 || StringUtil.isBlank(snapshotServer)) {
throw new IllegalStateException("Model seems to be offline");
}
return MessageFormat.format("https://img.strpst.com/{0}/thumbs/{1}/{2}_jpg", snapshotServer, String.valueOf(timestamp), String.valueOf(id));
} catch (Exception e) {
return model.optString("previewUrlThumbBig");
}
}
}

View File

@ -1,16 +1,5 @@
package ctbrec.ui.sites.stripchat; package ctbrec.ui.sites.stripchat;
import static ctbrec.Model.State.*;
import static ctbrec.io.HttpConstants.*;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.json.JSONArray;
import org.json.JSONObject;
import ctbrec.Config; import ctbrec.Config;
import ctbrec.Model; import ctbrec.Model;
import ctbrec.io.HttpException; import ctbrec.io.HttpException;
@ -18,14 +7,24 @@ import ctbrec.sites.stripchat.Stripchat;
import ctbrec.sites.stripchat.StripchatHttpClient; import ctbrec.sites.stripchat.StripchatHttpClient;
import ctbrec.sites.stripchat.StripchatModel; import ctbrec.sites.stripchat.StripchatModel;
import ctbrec.ui.SiteUiFactory; import ctbrec.ui.SiteUiFactory;
import ctbrec.ui.tabs.PaginatedScheduledService;
import javafx.concurrent.Task; import javafx.concurrent.Task;
import okhttp3.HttpUrl; import okhttp3.HttpUrl;
import okhttp3.Request; import okhttp3.Request;
import org.json.JSONArray;
import org.json.JSONObject;
public class StripchatFollowedUpdateService extends PaginatedScheduledService { import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import static ctbrec.Model.State.*;
import static ctbrec.io.HttpConstants.*;
public class StripchatFollowedUpdateService extends AbstractStripchatUpdateService {
private static final int PAGE_SIZE = 30; private static final int PAGE_SIZE = 30;
private Stripchat stripchat; private static final String FAVORITES = "/favorites";
private final Stripchat stripchat;
public StripchatFollowedUpdateService(Stripchat stripchat) { public StripchatFollowedUpdateService(Stripchat stripchat) {
this.stripchat = stripchat; this.stripchat = stripchat;
@ -33,7 +32,7 @@ public class StripchatFollowedUpdateService extends PaginatedScheduledService {
@Override @Override
protected Task<List<Model>> createTask() { protected Task<List<Model>> createTask() {
return new Task<List<Model>>() { return new Task<>() {
@Override @Override
public List<Model> call() throws IOException { public List<Model> call() throws IOException {
return loadModels(); return loadModels();
@ -62,13 +61,13 @@ public class StripchatFollowedUpdateService extends PaginatedScheduledService {
List<Model> models = new ArrayList<>(); List<Model> models = new ArrayList<>();
var urlBuilder = HttpUrl.parse(stripchat.getBaseUrl() + "/api/front/models/list").newBuilder(); var urlBuilder = HttpUrl.parse(stripchat.getBaseUrl() + "/api/front/models/list").newBuilder();
for (var i = 0; i < modelIdsToLoad.size(); i++) { for (var i = 0; i < modelIdsToLoad.size(); i++) {
urlBuilder.addQueryParameter("modelIds["+i+"]", modelIdsToLoad.get(i).toString()); urlBuilder.addQueryParameter("modelIds[" + i + "]", modelIdsToLoad.get(i).toString());
} }
var request = new Request.Builder() var request = new Request.Builder()
.url(urlBuilder.build()) .url(urlBuilder.build())
.header(ACCEPT, "*/*") .header(ACCEPT, "*/*")
.header(USER_AGENT, Config.getInstance().getSettings().httpUserAgent) .header(USER_AGENT, Config.getInstance().getSettings().httpUserAgent)
.header(REFERER, Stripchat.baseUri + "/favorites") .header(REFERER, Stripchat.baseUri + FAVORITES)
.header(CONTENT_TYPE, MIMETYPE_APPLICATION_JSON) .header(CONTENT_TYPE, MIMETYPE_APPLICATION_JSON)
.build(); .build();
try (var response = stripchat.getHttpClient().execute(request)) { try (var response = stripchat.getHttpClient().execute(request)) {
@ -80,7 +79,7 @@ public class StripchatFollowedUpdateService extends PaginatedScheduledService {
var user = users.getJSONObject(i); var user = users.getJSONObject(i);
StripchatModel model = stripchat.createModel(user.optString("username")); StripchatModel model = stripchat.createModel(user.optString("username"));
model.setDescription(user.optString("description")); model.setDescription(user.optString("description"));
model.setPreview(user.optString("previewUrlThumbBig")); model.setPreview(getPreviewUrl(user));
model.setOnlineState(mapStatus(user.optString("status"))); model.setOnlineState(mapStatus(user.optString("status")));
models.add(model); models.add(model);
} }
@ -96,13 +95,13 @@ public class StripchatFollowedUpdateService extends PaginatedScheduledService {
SiteUiFactory.getUi(stripchat).login(); SiteUiFactory.getUi(stripchat).login();
stripchat.getHttpClient().login(); stripchat.getHttpClient().login();
long userId = ((StripchatHttpClient) stripchat.getHttpClient()).getUserId(); long userId = ((StripchatHttpClient) stripchat.getHttpClient()).getUserId();
String url = stripchat.getBaseUrl() + "/api/front/users/" + userId + "/favorites"; String url = stripchat.getBaseUrl() + "/api/front/users/" + userId + FAVORITES;
var request = new Request.Builder() var request = new Request.Builder()
.url(url) .url(url)
.header(ACCEPT, MIMETYPE_APPLICATION_JSON) .header(ACCEPT, MIMETYPE_APPLICATION_JSON)
.header(USER_AGENT, Config.getInstance().getSettings().httpUserAgent) .header(USER_AGENT, Config.getInstance().getSettings().httpUserAgent)
.header(ORIGIN, Stripchat.baseUri) .header(ORIGIN, Stripchat.baseUri)
.header(REFERER, Stripchat.baseUri + "/favorites") .header(REFERER, Stripchat.baseUri + FAVORITES)
.header(CONTENT_TYPE, MIMETYPE_APPLICATION_JSON) .header(CONTENT_TYPE, MIMETYPE_APPLICATION_JSON)
.build(); .build();
try (var response = stripchat.getHttpClient().execute(request)) { try (var response = stripchat.getHttpClient().execute(request)) {
@ -121,15 +120,11 @@ public class StripchatFollowedUpdateService extends PaginatedScheduledService {
} }
protected ctbrec.Model.State mapStatus(String status) { protected ctbrec.Model.State mapStatus(String status) {
switch (status) { return switch (status) {
case "public": case "public" -> ONLINE;
return ONLINE; case "idle" -> AWAY;
case "idle": case "off" -> OFFLINE;
return AWAY; default -> UNKNOWN;
case "off": };
return OFFLINE;
default:
return UNKNOWN;
}
} }
} }

View File

@ -6,7 +6,6 @@ import ctbrec.io.HttpException;
import ctbrec.sites.stripchat.Stripchat; import ctbrec.sites.stripchat.Stripchat;
import ctbrec.sites.stripchat.StripchatModel; import ctbrec.sites.stripchat.StripchatModel;
import ctbrec.ui.SiteUiFactory; import ctbrec.ui.SiteUiFactory;
import ctbrec.ui.tabs.PaginatedScheduledService;
import javafx.concurrent.Task; import javafx.concurrent.Task;
import okhttp3.Request; import okhttp3.Request;
import org.json.JSONObject; import org.json.JSONObject;
@ -14,6 +13,8 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import java.io.IOException; import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -21,7 +22,7 @@ import java.util.Locale;
import static ctbrec.io.HttpConstants.*; import static ctbrec.io.HttpConstants.*;
public class StripchatUpdateService extends PaginatedScheduledService { public class StripchatUpdateService extends AbstractStripchatUpdateService {
private static final Logger LOG = LoggerFactory.getLogger(StripchatUpdateService.class); private static final Logger LOG = LoggerFactory.getLogger(StripchatUpdateService.class);
@ -71,17 +72,18 @@ public class StripchatUpdateService extends PaginatedScheduledService {
}; };
} }
private List<Model> parseModels(String body) { private List<Model> parseModels(String body) throws IOException {
List<Model> models = new ArrayList<>(); List<Model> models = new ArrayList<>();
var json = new JSONObject(body); var json = new JSONObject(body);
if (json.has("models")) { if (json.has("models")) {
var jsonModels = json.getJSONArray("models"); var jsonModels = json.getJSONArray("models");
Files.writeString(Path.of("/tmp/sc-models.json"), jsonModels.toString(2));
for (var i = 0; i < jsonModels.length(); i++) { for (var i = 0; i < jsonModels.length(); i++) {
var jsonModel = jsonModels.getJSONObject(i); var jsonModel = jsonModels.getJSONObject(i);
try { try {
StripchatModel model = stripchat.createModel(jsonModel.getString("username")); StripchatModel model = stripchat.createModel(jsonModel.getString("username"));
model.setDescription(""); model.setDescription("");
model.setPreview(jsonModel.optString("previewUrlThumbBig")); model.setPreview(getPreviewUrl(jsonModel));
model.setDisplayName(model.getName()); model.setDisplayName(model.getName());
model.setOnlineState(Model.State.ONLINE); model.setOnlineState(Model.State.ONLINE);
models.add(model); models.add(model);