forked from j62/ctbrec
1
0
Fork 0

Fix followed page for MFC

This commit is contained in:
0xboobface 2019-12-21 19:54:49 +01:00
parent 2fb2c932aa
commit 45d18c754a
1 changed files with 21 additions and 29 deletions

View File

@ -1,6 +1,5 @@
package ctbrec.ui.sites.myfreecams; package ctbrec.ui.sites.myfreecams;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
@ -26,13 +25,12 @@ import okhttp3.Response;
public class FriendsUpdateService extends PaginatedScheduledService { public class FriendsUpdateService extends PaginatedScheduledService {
private static final transient Logger LOG = LoggerFactory.getLogger(FriendsUpdateService.class); private static final Logger LOG = LoggerFactory.getLogger(FriendsUpdateService.class);
private MyFreeCams myFreeCams; private MyFreeCams myFreeCams;
private Mode mode = Mode.ONLINE; private Mode mode = Mode.ONLINE;
public static enum Mode { public enum Mode {
ONLINE, ONLINE, OFFLINE
OFFLINE
} }
public FriendsUpdateService(MyFreeCams myFreeCams) { public FriendsUpdateService(MyFreeCams myFreeCams) {
@ -50,10 +48,7 @@ public class FriendsUpdateService extends PaginatedScheduledService {
List<MyFreeCamsModel> models = new ArrayList<>(); List<MyFreeCamsModel> models = new ArrayList<>();
SiteUiFactory.getUi(myFreeCams).login(); SiteUiFactory.getUi(myFreeCams).login();
String url = myFreeCams.getBaseUrl() + "/php/manage_lists2.php?passcode=&list_type=friends&data_mode=online&get_user_list=1"; String url = myFreeCams.getBaseUrl() + "/php/manage_lists2.php?passcode=&list_type=friends&data_mode=online&get_user_list=1";
Request req = new Request.Builder() Request req = new Request.Builder().url(url).header("Referer", myFreeCams.getBaseUrl()).build();
.url(url)
.header("Referer", myFreeCams.getBaseUrl())
.build();
try (Response resp = myFreeCams.getHttpClient().execute(req)) { try (Response resp = myFreeCams.getHttpClient().execute(req)) {
if (resp.isSuccessful()) { if (resp.isSuccessful()) {
String body = resp.body().string().substring(4); String body = resp.body().string().substring(4);
@ -73,21 +68,18 @@ public class FriendsUpdateService extends PaginatedScheduledService {
st.setUid(uid); st.setUid(uid);
st.setLv(modelObject.getInt("lv")); st.setLv(modelObject.getInt("lv"));
st.setVs(127); st.setVs(127);
model.update(st, myFreeCams.getClient().getStreamUrl(st));
} }
models.add(model); models.add(model);
} }
} catch (Exception e) { } catch (Exception e) {
LOG.info("Exception getting friends list. Response was: {}", body); LOG.info("Exception getting friends list. Response was: {}", body, e);
} }
} else { } else {
LOG.error("Couldn't load friends list {} {}", resp.code(), resp.message()); LOG.error("Couldn't load friends list {} {}", resp.code(), resp.message());
} }
} }
boolean filterOnline = mode == Mode.ONLINE; boolean filterOnline = mode == Mode.ONLINE;
return models.stream() return models.stream().filter(m -> {
.filter(m -> {
try { try {
return m.isOnline() == filterOnline; return m.isOnline() == filterOnline;
} catch (Exception e) { } catch (Exception e) {
@ -95,7 +87,7 @@ public class FriendsUpdateService extends PaginatedScheduledService {
} }
}) })
.sorted((m1, m2) -> (int) (m2.getCamScore() - m1.getCamScore())) .sorted((m1, m2) -> (int) (m2.getCamScore() - m1.getCamScore()))
.skip((page-1) * 50) .skip((page - 1) * 50l)
.limit(50) .limit(50)
.collect(Collectors.toList()); .collect(Collectors.toList());
} }