forked from j62/ctbrec
1
0
Fork 0

Add "New" tab to each site where it was missing

This commit is contained in:
0xboobface 2020-06-07 13:53:54 +02:00
parent fdce3bcec0
commit acd6126619
14 changed files with 201 additions and 117 deletions

View File

@ -29,6 +29,7 @@ public class Cam4TabProvider extends TabProvider {
tabs.add(createTab("Male", cam4.getBaseUrl() + "/directoryResults?online=true&gender=male&orderBy=MOST_VIEWERS")); tabs.add(createTab("Male", cam4.getBaseUrl() + "/directoryResults?online=true&gender=male&orderBy=MOST_VIEWERS"));
tabs.add(createTab("Couples", cam4.getBaseUrl() + "/directoryResults?online=true&broadcastType=male_group&broadcastType=female_group&broadcastType=male_female_group&orderBy=MOST_VIEWERS")); tabs.add(createTab("Couples", cam4.getBaseUrl() + "/directoryResults?online=true&broadcastType=male_group&broadcastType=female_group&broadcastType=male_female_group&orderBy=MOST_VIEWERS"));
tabs.add(createTab("HD", cam4.getBaseUrl() + "/directoryResults?online=true&hd=true&orderBy=MOST_VIEWERS")); tabs.add(createTab("HD", cam4.getBaseUrl() + "/directoryResults?online=true&hd=true&orderBy=MOST_VIEWERS"));
tabs.add(createTab("New", cam4.getBaseUrl() + "/directoryResults?online=true&gender=female&orderBy=MOST_VIEWERS&newPerformer=true"));
followed = new Cam4FollowedTab(cam4); followed = new Cam4FollowedTab(cam4);
followed.setRecorder(recorder); followed.setRecorder(recorder);

View File

@ -28,7 +28,6 @@ import ctbrec.ui.SiteUiFactory;
import ctbrec.ui.tabs.TabSelectionListener; import ctbrec.ui.tabs.TabSelectionListener;
import javafx.application.Platform; import javafx.application.Platform;
import javafx.beans.value.ChangeListener; import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.concurrent.Task; import javafx.concurrent.Task;
import javafx.geometry.Insets; import javafx.geometry.Insets;
import javafx.scene.Cursor; import javafx.scene.Cursor;
@ -52,12 +51,11 @@ import okhttp3.Response;
public class CamsodaShowsTab extends Tab implements TabSelectionListener { public class CamsodaShowsTab extends Tab implements TabSelectionListener {
private static final transient Logger LOG = LoggerFactory.getLogger(CamsodaShowsTab.class); private static final Logger LOG = LoggerFactory.getLogger(CamsodaShowsTab.class);
private Camsoda camsoda; private Camsoda camsoda;
private Recorder recorder; private Recorder recorder;
private GridPane showList; private GridPane showList;
private ProgressIndicator progressIndicator;
public CamsodaShowsTab(Camsoda camsoda, Recorder recorder) { public CamsodaShowsTab(Camsoda camsoda, Recorder recorder) {
this.camsoda = camsoda; this.camsoda = camsoda;
@ -70,7 +68,7 @@ public class CamsodaShowsTab extends Tab implements TabSelectionListener {
showList.setPadding(new Insets(5)); showList.setPadding(new Insets(5));
showList.setHgap(5); showList.setHgap(5);
showList.setVgap(5); showList.setVgap(5);
progressIndicator = new ProgressIndicator(); ProgressIndicator progressIndicator = new ProgressIndicator();
progressIndicator.setPrefSize(100, 100); progressIndicator.setPrefSize(100, 100);
setContent(progressIndicator); setContent(progressIndicator);
setClosable(false); setClosable(false);
@ -101,7 +99,7 @@ public class CamsodaShowsTab extends Tab implements TabSelectionListener {
} }
return boxes; return boxes;
} else { } else {
LOG.error("Couldn't load upcoming camsoda shows. Unexpected response: {}", json.toString()); LOG.error("Couldn't load upcoming camsoda shows. Unexpected response: {}", json);
showErrorDialog("Oh no!", "Couldn't load upcoming CamSoda shows", "Got an unexpected response from server"); showErrorDialog("Oh no!", "Couldn't load upcoming CamSoda shows", "Got an unexpected response from server");
} }
} else { } else {
@ -143,6 +141,7 @@ public class CamsodaShowsTab extends Tab implements TabSelectionListener {
@Override @Override
public void deselected() { public void deselected() {
// nothing to do
} }
private void showErrorDialog(String title, String head, String msg) { private void showErrorDialog(String title, String head, String msg) {
@ -257,16 +256,12 @@ public class CamsodaShowsTab extends Tab implements TabSelectionListener {
} }
Platform.runLater(() -> { Platform.runLater(() -> {
Image img = new Image(imageUrl, 1000, thumbSize, true, true, true); Image img = new Image(imageUrl, 1000, thumbSize, true, true, true);
img.progressProperty().addListener(new ChangeListener<Number>() { img.progressProperty().addListener((ChangeListener<Number>) (observable, oldValue, newValue) -> {
@Override if (newValue.doubleValue() == 1.0) {
public void changed(ObservableValue<? extends Number> observable, Number oldValue, Number newValue) { thumb.setImage(img);
if (newValue.doubleValue() == 1.0) { root.setLeft(thumb);
thumb.setImage(img);
root.setLeft(thumb);
}
} }
}); });
}); });
} }
} }

View File

@ -4,9 +4,11 @@ import static ctbrec.sites.camsoda.Camsoda.*;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.Predicate;
import ctbrec.recorder.Recorder; import ctbrec.recorder.Recorder;
import ctbrec.sites.camsoda.Camsoda; import ctbrec.sites.camsoda.Camsoda;
import ctbrec.sites.camsoda.CamsodaModel;
import ctbrec.ui.tabs.TabProvider; import ctbrec.ui.tabs.TabProvider;
import ctbrec.ui.tabs.ThumbOverviewTab; import ctbrec.ui.tabs.ThumbOverviewTab;
import javafx.scene.Scene; import javafx.scene.Scene;
@ -27,7 +29,8 @@ public class CamsodaTabProvider extends TabProvider {
@Override @Override
public List<Tab> getTabs(Scene scene) { public List<Tab> getTabs(Scene scene) {
List<Tab> tabs = new ArrayList<>(); List<Tab> tabs = new ArrayList<>();
tabs.add(createTab("Online", BASE_URI + "/api/v1/browse/online")); tabs.add(createTab("Online", BASE_URI + "/api/v1/browse/online", m -> true));
tabs.add(createTab("New", BASE_URI + "/api/v1/browse/online", CamsodaModel::isNew));
followedTab.setRecorder(recorder); followedTab.setRecorder(recorder);
followedTab.setScene(scene); followedTab.setScene(scene);
tabs.add(followedTab); tabs.add(followedTab);
@ -40,8 +43,8 @@ public class CamsodaTabProvider extends TabProvider {
return followedTab; return followedTab;
} }
private Tab createTab(String title, String url) { private Tab createTab(String title, String url, Predicate<CamsodaModel> filter) {
CamsodaUpdateService updateService = new CamsodaUpdateService(url, false, camsoda); CamsodaUpdateService updateService = new CamsodaUpdateService(url, false, camsoda, filter);
ThumbOverviewTab tab = new ThumbOverviewTab(title, updateService, camsoda); ThumbOverviewTab tab = new ThumbOverviewTab(title, updateService, camsoda);
tab.setRecorder(recorder); tab.setRecorder(recorder);
return tab; return tab;

View File

@ -6,6 +6,7 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.Objects; import java.util.Objects;
import java.util.function.Predicate;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import org.json.JSONArray; import org.json.JSONArray;
@ -33,10 +34,13 @@ public class CamsodaUpdateService extends PaginatedScheduledService {
private Camsoda camsoda; private Camsoda camsoda;
int modelsPerPage = 50; int modelsPerPage = 50;
public CamsodaUpdateService(String url, boolean loginRequired, Camsoda camsoda) { private Predicate<CamsodaModel> filter;
public CamsodaUpdateService(String url, boolean loginRequired, Camsoda camsoda, Predicate<CamsodaModel> filter) {
this.url = url; this.url = url;
this.loginRequired = loginRequired; this.loginRequired = loginRequired;
this.camsoda = camsoda; this.camsoda = camsoda;
this.filter = filter;
} }
@Override @Override
@ -44,90 +48,94 @@ public class CamsodaUpdateService extends PaginatedScheduledService {
return new Task<List<Model>>() { return new Task<List<Model>>() {
@Override @Override
public List<Model> call() throws IOException { public List<Model> call() throws IOException {
List<CamsodaModel> models = new ArrayList<>(); return loadOnlineModels().stream()
if(loginRequired && StringUtil.isBlank(ctbrec.Config.getInstance().getSettings().username)) { .sorted((m1,m2) -> (int)(m2.getSortOrder() - m1.getSortOrder()))
return Collections.emptyList(); .filter(filter)
} else { .skip( (page-1) * modelsPerPage)
String url = CamsodaUpdateService.this.url; .limit(modelsPerPage)
LOG.debug("Fetching page {}", url); .collect(Collectors.toList());
if(loginRequired) {
SiteUiFactory.getUi(camsoda).login();
}
Request request = new Request.Builder().url(url).build();
try(Response response = camsoda.getHttpClient().execute(request)) {
if (response.isSuccessful()) {
JSONObject json = new JSONObject(response.body().string());
if(json.has("status") && json.getBoolean("status")) {
JSONArray template = json.getJSONArray("template");
JSONArray results = json.getJSONArray("results");
for (int i = 0; i < results.length(); i++) {
JSONObject result = results.getJSONObject(i);
try {
if(result.has("tpl")) {
JSONArray tpl = result.getJSONArray("tpl");
String name = tpl.getString(getTemplateIndex(template, "username"));
CamsodaModel model = (CamsodaModel) camsoda.createModel(name);
model.setDescription(tpl.getString(getTemplateIndex(template, "subject_html")));
model.setSortOrder(tpl.getFloat(getTemplateIndex(template, "sort_value")));
String preview = "https:" + tpl.getString(getTemplateIndex(template, "thumb"));
model.setPreview(preview);
String displayName = tpl.getString(getTemplateIndex(template, "display_name"));
model.setDisplayName(displayName.replaceAll("[^a-zA-Z0-9]", ""));
if(model.getDisplayName().isBlank()) {
model.setDisplayName(name);
}
models.add(model);
} else {
String name = result.getString("username");
CamsodaModel model = (CamsodaModel) camsoda.createModel(name);
model.setSortOrder(result.getFloat("sort_value"));
models.add(model);
if(result.has("status")) {
model.setOnlineStateByStatus(result.getString("status"));
}
if(result.has("display_name")) {
model.setDisplayName(result.getString("display_name").replaceAll("[^a-zA-Z0-9]", ""));
if(model.getDisplayName().isBlank()) {
model.setDisplayName(name);
}
}
if(result.has("thumb")) {
String previewUrl = "https:" + result.getString("thumb");
model.setPreview(previewUrl);
}
}
} catch (Exception e) {
LOG.warn("Couldn't parse one of the models: {}", result, e);
}
}
return models.stream()
.sorted((m1,m2) -> (int)(m2.getSortOrder() - m1.getSortOrder()))
.skip( (page-1) * modelsPerPage)
.limit(modelsPerPage)
.collect(Collectors.toList());
} else {
LOG.debug("Response was not successful: {}", json);
return Collections.emptyList();
}
} else {
throw new HttpException(response.code(), response.message());
}
}
}
}
private int getTemplateIndex(JSONArray template, String string) {
for (int i = 0; i < template.length(); i++) {
String s = template.getString(i);
if(Objects.equals(s, string)) {
return i;
}
}
throw new NoSuchElementException(string + " not found in template: " + template.toString());
} }
}; };
} }
protected List<CamsodaModel> loadOnlineModels() throws IOException {
List<CamsodaModel> models = new ArrayList<>();
if(loginRequired && StringUtil.isBlank(ctbrec.Config.getInstance().getSettings().username)) {
return Collections.emptyList();
} else {
String url = CamsodaUpdateService.this.url;
LOG.debug("Fetching page {}", url);
if(loginRequired) {
SiteUiFactory.getUi(camsoda).login();
}
Request request = new Request.Builder().url(url).build();
try(Response response = camsoda.getHttpClient().execute(request)) {
if (response.isSuccessful()) {
JSONObject json = new JSONObject(response.body().string());
if(json.has("status") && json.getBoolean("status")) {
JSONArray template = json.getJSONArray("template");
JSONArray results = json.getJSONArray("results");
for (int i = 0; i < results.length(); i++) {
JSONObject result = results.getJSONObject(i);
try {
if(result.has("tpl")) {
JSONArray tpl = result.getJSONArray("tpl");
String name = tpl.getString(getTemplateIndex(template, "username"));
CamsodaModel model = (CamsodaModel) camsoda.createModel(name);
model.setDescription(tpl.getString(getTemplateIndex(template, "subject_html")));
model.setSortOrder(tpl.getFloat(getTemplateIndex(template, "sort_value")));
String preview = "https:" + tpl.getString(getTemplateIndex(template, "thumb"));
model.setPreview(preview);
String displayName = tpl.getString(getTemplateIndex(template, "display_name"));
model.setDisplayName(displayName.replaceAll("[^a-zA-Z0-9]", ""));
if(model.getDisplayName().isBlank()) {
model.setDisplayName(name);
}
model.setNew(result.optBoolean("new"));
models.add(model);
} else {
String name = result.getString("username");
CamsodaModel model = (CamsodaModel) camsoda.createModel(name);
model.setSortOrder(result.getFloat("sort_value"));
if(result.has("status")) {
model.setOnlineStateByStatus(result.getString("status"));
}
if(result.has("display_name")) {
model.setDisplayName(result.getString("display_name").replaceAll("[^a-zA-Z0-9]", ""));
if(model.getDisplayName().isBlank()) {
model.setDisplayName(name);
}
}
if(result.has("thumb")) {
String previewUrl = "https:" + result.getString("thumb");
model.setPreview(previewUrl);
}
model.setNew(result.optBoolean("new"));
models.add(model);
}
} catch (Exception e) {
LOG.warn("Couldn't parse one of the models: {}", result, e);
}
}
return models;
} else {
LOG.debug("Response was not successful: {}", json);
return Collections.emptyList();
}
} else {
throw new HttpException(response.code(), response.message());
}
}
}
}
private int getTemplateIndex(JSONArray template, String string) {
for (int i = 0; i < template.length(); i++) {
String s = template.getString(i);
if(Objects.equals(s, string)) {
return i;
}
}
throw new NoSuchElementException(string + " not found in template: " + template.toString());
}
} }

View File

@ -27,6 +27,7 @@ public class ChaturbateTabProvider extends TabProvider {
List<Tab> tabs = new ArrayList<>(); List<Tab> tabs = new ArrayList<>();
tabs.add(createTab("Featured", chaturbate.getBaseUrl() + "/")); tabs.add(createTab("Featured", chaturbate.getBaseUrl() + "/"));
tabs.add(createTab("Female", chaturbate.getBaseUrl() + "/female-cams/")); tabs.add(createTab("Female", chaturbate.getBaseUrl() + "/female-cams/"));
tabs.add(createTab("New Female", chaturbate.getBaseUrl() + "/new-cams/female/"));
tabs.add(createTab("Male", chaturbate.getBaseUrl() + "/male-cams/")); tabs.add(createTab("Male", chaturbate.getBaseUrl() + "/male-cams/"));
tabs.add(createTab("Couples", chaturbate.getBaseUrl() + "/couple-cams/")); tabs.add(createTab("Couples", chaturbate.getBaseUrl() + "/couple-cams/"));
tabs.add(createTab("Trans", chaturbate.getBaseUrl() + "/trans-cams/")); tabs.add(createTab("Trans", chaturbate.getBaseUrl() + "/trans-cams/"));

View File

@ -2,8 +2,10 @@ package ctbrec.ui.sites.flirt4free;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.Predicate;
import ctbrec.sites.flirt4free.Flirt4Free; import ctbrec.sites.flirt4free.Flirt4Free;
import ctbrec.sites.flirt4free.Flirt4FreeModel;
import ctbrec.ui.tabs.TabProvider; import ctbrec.ui.tabs.TabProvider;
import ctbrec.ui.tabs.ThumbOverviewTab; import ctbrec.ui.tabs.ThumbOverviewTab;
import javafx.scene.Scene; import javafx.scene.Scene;
@ -24,9 +26,10 @@ public class Flirt4FreeTabProvider extends TabProvider {
@Override @Override
public List<Tab> getTabs(Scene scene) { public List<Tab> getTabs(Scene scene) {
List<Tab> tabs = new ArrayList<>(); List<Tab> tabs = new ArrayList<>();
tabs.add(createTab("Girls", flirt4Free.getBaseUrl() + "/live/girls/")); tabs.add(createTab("Girls", flirt4Free.getBaseUrl() + "/live/girls/", m -> true));
tabs.add(createTab("Boys", flirt4Free.getBaseUrl() + "/live/guys/")); tabs.add(createTab("New Girls", flirt4Free.getBaseUrl() + "/live/girls/", Flirt4FreeModel::isNew));
tabs.add(createTab("Trans", flirt4Free.getBaseUrl() + "/live/trans/")); tabs.add(createTab("Boys", flirt4Free.getBaseUrl() + "/live/guys/", m -> true));
tabs.add(createTab("Trans", flirt4Free.getBaseUrl() + "/live/trans/", m -> true));
tabs.add(followedTab); tabs.add(followedTab);
return tabs; return tabs;
} }
@ -36,8 +39,8 @@ public class Flirt4FreeTabProvider extends TabProvider {
return followedTab; return followedTab;
} }
private ThumbOverviewTab createTab(String title, String url) { private ThumbOverviewTab createTab(String title, String url, Predicate<Flirt4FreeModel> filter) {
Flirt4FreeUpdateService s = new Flirt4FreeUpdateService(flirt4Free, url); Flirt4FreeUpdateService s = new Flirt4FreeUpdateService(flirt4Free, url, filter);
ThumbOverviewTab tab = new ThumbOverviewTab(title, s, flirt4Free); ThumbOverviewTab tab = new ThumbOverviewTab(title, s, flirt4Free);
tab.setRecorder(flirt4Free.getRecorder()); tab.setRecorder(flirt4Free.getRecorder());
s.setPeriod(Duration.seconds(60)); s.setPeriod(Duration.seconds(60));

View File

@ -5,6 +5,8 @@ import static ctbrec.io.HttpConstants.*;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Optional;
import java.util.function.Predicate;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -32,10 +34,12 @@ public class Flirt4FreeUpdateService extends PaginatedScheduledService {
private static final int MODELS_PER_PAGE = 40; private static final int MODELS_PER_PAGE = 40;
private String url; private String url;
private Flirt4Free flirt4Free; private Flirt4Free flirt4Free;
private Predicate<Flirt4FreeModel> filter;
public Flirt4FreeUpdateService(Flirt4Free flirt4Free, String url) { public Flirt4FreeUpdateService(Flirt4Free flirt4Free, String url, Predicate<Flirt4FreeModel> filter) {
this.flirt4Free = flirt4Free; this.flirt4Free = flirt4Free;
this.url = url; this.url = url;
this.filter = filter;
} }
@Override @Override
@ -60,7 +64,7 @@ public class Flirt4FreeUpdateService extends PaginatedScheduledService {
} }
private List<Model> parseResponse(Response response) throws IOException { private List<Model> parseResponse(Response response) throws IOException {
List<Model> models = new ArrayList<>(); List<Flirt4FreeModel> models = new ArrayList<>();
String body = response.body().string(); String body = response.body().string();
Matcher m = Pattern.compile("window\\.homepageData = (\\{.*\\})", Pattern.DOTALL).matcher(body); Matcher m = Pattern.compile("window\\.homepageData = (\\{.*\\})", Pattern.DOTALL).matcher(body);
if (m.find()) { if (m.find()) {
@ -68,12 +72,13 @@ public class Flirt4FreeUpdateService extends PaginatedScheduledService {
JSONArray modelData = data.getJSONArray("liveModels"); JSONArray modelData = data.getJSONArray("liveModels");
LOG.debug("Found {} models", modelData.length()); LOG.debug("Found {} models", modelData.length());
for (int i = 0; i < modelData.length(); i++) { for (int i = 0; i < modelData.length(); i++) {
Model model = parseModel(modelData.getString(i)); Flirt4FreeModel model = parseModel(modelData.getString(i));
if (model != null) { if (model != null) {
models.add(model); models.add(model);
} }
} }
return models.stream() return models.stream()
.filter(filter)
.skip((page - 1) * MODELS_PER_PAGE) .skip((page - 1) * MODELS_PER_PAGE)
.limit(MODELS_PER_PAGE) .limit(MODELS_PER_PAGE)
.collect(Collectors.toList()); .collect(Collectors.toList());
@ -82,7 +87,7 @@ public class Flirt4FreeUpdateService extends PaginatedScheduledService {
} }
} }
private Model parseModel(String modelHtml) { private Flirt4FreeModel parseModel(String modelHtml) {
if (modelHtml.trim().isEmpty() || !modelHtml.contains("modelLink")) { if (modelHtml.trim().isEmpty() || !modelHtml.contains("modelLink")) {
return null; return null;
} }
@ -114,6 +119,7 @@ public class Flirt4FreeUpdateService extends PaginatedScheduledService {
model.setStreamUrl(streamUrl); model.setStreamUrl(streamUrl);
model.setOnlineState(ctbrec.Model.State.ONLINE); model.setOnlineState(ctbrec.Model.State.ONLINE);
model.setOnline(true); model.setOnline(true);
model.setNew(!Optional.ofNullable(modelDiv.attr("data-model-new")).orElse("0").equals("0"));
return model; return model;
} }
} }

View File

@ -25,6 +25,7 @@ public class LiveJasminTabProvider extends TabProvider {
tabs.add(createTab("Girls", liveJasmin.getBaseUrl() + "/en/girl/?listPageOrderType=most_popular")); tabs.add(createTab("Girls", liveJasmin.getBaseUrl() + "/en/girl/?listPageOrderType=most_popular"));
tabs.add(createTab("Girls HD", liveJasmin.getBaseUrl() + "/en/girl/hd/?listPageOrderType=most_popular")); tabs.add(createTab("Girls HD", liveJasmin.getBaseUrl() + "/en/girl/hd/?listPageOrderType=most_popular"));
tabs.add(createTab("New Girls", liveJasmin.getBaseUrl() + "/en/girls/newbie/?listPageOrderType=most_popular"));
tabs.add(createTab("Boys", liveJasmin.getBaseUrl() + "/en/boy/?listPageOrderType=most_popular")); tabs.add(createTab("Boys", liveJasmin.getBaseUrl() + "/en/boy/?listPageOrderType=most_popular"));
tabs.add(createTab("Boys HD", liveJasmin.getBaseUrl() + "/en/boy/hd/?listPageOrderType=most_popular")); tabs.add(createTab("Boys HD", liveJasmin.getBaseUrl() + "/en/boy/hd/?listPageOrderType=most_popular"));

View File

@ -44,6 +44,11 @@ public class MyFreeCamsTabProvider extends TabProvider {
pop.setRecorder(recorder); pop.setRecorder(recorder);
tabs.add(pop); tabs.add(pop);
updateService = new NewModelService();
ThumbOverviewTab newModels = new ThumbOverviewTab("New", updateService, myFreeCams);
newModels.setRecorder(recorder);
tabs.add(newModels);
MyFreeCamsTableTab table = new MyFreeCamsTableTab(myFreeCams); MyFreeCamsTableTab table = new MyFreeCamsTableTab(myFreeCams);
tabs.add(table); tabs.add(table);

View File

@ -0,0 +1,38 @@
package ctbrec.ui.sites.myfreecams;
import java.io.IOException;
import java.util.List;
import java.util.stream.Collectors;
import ctbrec.Model;
import ctbrec.sites.mfc.MyFreeCamsClient;
import ctbrec.ui.tabs.PaginatedScheduledService;
import javafx.concurrent.Task;
public class NewModelService extends PaginatedScheduledService {
@Override
protected Task<List<Model>> createTask() {
return new Task<List<Model>>() {
@Override
public List<Model> call() throws IOException {
MyFreeCamsClient client = MyFreeCamsClient.getInstance();
int modelsPerPage = 50;
return client.getModels().stream()
.filter(m -> m.getPreview() != null)
.filter(m -> m.getStreamUrl() != null)
.filter(m -> {
try {
return m.isNew();
} catch (Exception e) {
return false;
}
})
.sorted((m1, m2) -> m2.getViewerCount() - m1.getViewerCount())
.skip( (page-1) * modelsPerPage)
.limit(modelsPerPage)
.collect(Collectors.toList());
}
};
}
}

View File

@ -32,6 +32,7 @@ public class StripchatTabProvider extends TabProvider {
List<Tab> tabs = new ArrayList<>(); List<Tab> tabs = new ArrayList<>();
tabs.add(createTab("Girls", MessageFormat.format(urlTemplate, "girls"))); tabs.add(createTab("Girls", MessageFormat.format(urlTemplate, "girls")));
tabs.add(createTab("Girls HD", stripchat.getBaseUrl() + "/api/front/models?primaryTag=girls&filterGroupTags=%5B%5B%22autoTagHd%22%5D%5D&parentTag=autoTagHd")); tabs.add(createTab("Girls HD", stripchat.getBaseUrl() + "/api/front/models?primaryTag=girls&filterGroupTags=%5B%5B%22autoTagHd%22%5D%5D&parentTag=autoTagHd"));
tabs.add(createTab("New Girls", stripchat.getBaseUrl() +"/api/front/models?primaryTag=girls&filterGroupTags=%5B%5B%22autoTagNew%22%5D%5D&parentTag=autoTagNew"));
tabs.add(createTab("Couples", MessageFormat.format(urlTemplate, "couples"))); tabs.add(createTab("Couples", MessageFormat.format(urlTemplate, "couples")));
tabs.add(createTab("Boys", MessageFormat.format(urlTemplate, "men"))); tabs.add(createTab("Boys", MessageFormat.format(urlTemplate, "men")));
tabs.add(createTab("Trans", MessageFormat.format(urlTemplate, "trans"))); tabs.add(createTab("Trans", MessageFormat.format(urlTemplate, "trans")));

View File

@ -46,6 +46,8 @@ public class CamsodaModel extends AbstractModel {
private static final Logger LOG = LoggerFactory.getLogger(CamsodaModel.class); private static final Logger LOG = LoggerFactory.getLogger(CamsodaModel.class);
private String streamUrl; private String streamUrl;
private transient List<StreamSource> streamSources = null; private transient List<StreamSource> streamSources = null;
private transient boolean isNew;
private float sortOrder = 0; private float sortOrder = 0;
private Random random = new Random(); private Random random = new Random();
int[] resolution = new int[2]; int[] resolution = new int[2];
@ -318,4 +320,12 @@ public class CamsodaModel extends AbstractModel {
public void setSortOrder(float sortOrder) { public void setSortOrder(float sortOrder) {
this.sortOrder = sortOrder; this.sortOrder = sortOrder;
} }
public boolean isNew() {
return isNew;
}
public void setNew(boolean isNew) {
this.isNew = isNew;
}
} }

View File

@ -54,6 +54,7 @@ public class Flirt4FreeModel extends AbstractModel {
private Object monitor = new Object(); private Object monitor = new Object();
private boolean online = false; private boolean online = false;
private boolean isInteractiveShow = false; private boolean isInteractiveShow = false;
private boolean isNew = false;
private String userIdt = ""; private String userIdt = "";
private String userIp = "0.0.0.0"; private String userIp = "0.0.0.0";
@ -471,6 +472,14 @@ public class Flirt4FreeModel extends AbstractModel {
online = b; online = b;
} }
public boolean isNew() {
return isNew;
}
public void setNew(boolean isNew) {
this.isNew = isNew;
}
private void acquireSlot() throws InterruptedException { private void acquireSlot() throws InterruptedException {
//LOG.debug("Acquire: {}", requestThrottle.availablePermits()); //LOG.debug("Acquire: {}", requestThrottle.availablePermits());
requestThrottle.acquire(); requestThrottle.acquire();

View File

@ -1,6 +1,7 @@
package ctbrec.sites.mfc; package ctbrec.sites.mfc;
import static ctbrec.io.HttpConstants.*; import static ctbrec.io.HttpConstants.*;
import static java.util.Optional.*;
import java.io.IOException; import java.io.IOException;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
@ -10,7 +11,6 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import java.util.Objects; import java.util.Objects;
import java.util.Optional;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import javax.xml.bind.JAXBException; import javax.xml.bind.JAXBException;
@ -101,10 +101,6 @@ public class MyFreeCamsModel extends AbstractModel {
return new HlsStreamSourceProvider(getSite().getHttpClient()); return new HlsStreamSourceProvider(getSite().getHttpClient());
} }
private boolean isHlsStream() {
return Optional.ofNullable(streamUrl).orElse("").contains(".m3u8");
}
private String updateStreamUrl() { private String updateStreamUrl() {
if(streamUrl == null) { if(streamUrl == null) {
MyFreeCams mfc = (MyFreeCams) getSite(); MyFreeCams mfc = (MyFreeCams) getSite();
@ -203,6 +199,12 @@ public class MyFreeCamsModel extends AbstractModel {
this.camScore = camScore; this.camScore = camScore;
} }
public boolean isNew() {
MyFreeCams mfc = (MyFreeCams) getSite();
SessionState sessionState = mfc.getClient().getSessionState(this);
return ofNullable(sessionState).map(SessionState::getM).map(Model::getNewModel).orElse(0) == 1;
}
public void setMfcState(ctbrec.sites.mfc.State state) { public void setMfcState(ctbrec.sites.mfc.State state) {
this.state = state; this.state = state;
} }
@ -221,7 +223,8 @@ public class MyFreeCamsModel extends AbstractModel {
setName(state.getNm()); setName(state.getNm());
setMfcState(ctbrec.sites.mfc.State.of(state.getVs())); setMfcState(ctbrec.sites.mfc.State.of(state.getVs()));
setStreamUrl(streamUrl); setStreamUrl(streamUrl);
setCamScore(Optional.ofNullable(state.getM()).map(Model::getCamscore).orElse(0.0)); setCamScore(ofNullable(state.getM()).map(Model::getCamscore).orElse(0.0));
// preview // preview
String uidString = state.getUid().toString(); String uidString = state.getUid().toString();
@ -237,14 +240,14 @@ public class MyFreeCamsModel extends AbstractModel {
setPreview(previewUrl); setPreview(previewUrl);
// tags // tags
Optional.ofNullable(state.getM()).map(Model::getTags).ifPresent(tags -> { ofNullable(state.getM()).map(Model::getTags).ifPresent(tags -> {
ArrayList<String> t = new ArrayList<>(); ArrayList<String> t = new ArrayList<>();
t.addAll(tags); t.addAll(tags);
setTags(t); setTags(t);
}); });
// description // description
Optional.ofNullable(state.getM()).map(Model::getTopic).ifPresent(topic -> { ofNullable(state.getM()).map(Model::getTopic).ifPresent(topic -> {
try { try {
setDescription(URLDecoder.decode(topic, "utf-8")); setDescription(URLDecoder.decode(topic, "utf-8"));
} catch (UnsupportedEncodingException e) { } catch (UnsupportedEncodingException e) {
@ -252,7 +255,7 @@ public class MyFreeCamsModel extends AbstractModel {
} }
}); });
viewerCount = Optional.ofNullable(state.getM()).map(Model::getRc).orElse(0); viewerCount = ofNullable(state.getM()).map(Model::getRc).orElse(0);
} }
private String getLivePreviewUrl(SessionState state) { private String getLivePreviewUrl(SessionState state) {