forked from j62/ctbrec
Add "New" tab to each site where it was missing
This commit is contained in:
parent
fdce3bcec0
commit
acd6126619
|
@ -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);
|
||||||
|
|
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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/"));
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"));
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
|
@ -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")));
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue