1
0
mirror of https://github.com/wulkanowy/wulkanowy.git synced 2025-01-19 06:26:51 -06:00

API fixes (#136)

This commit is contained in:
Mikołaj Pich 2018-06-10 19:46:34 +02:00 committed by Rafał Borcz
parent 81d177c270
commit 7b7be1eef1
5 changed files with 49 additions and 5 deletions

View File

@ -62,6 +62,7 @@ public class Client {
return; return;
} }
clearCookies();
this.symbol = new Login(this).login(email, password, symbol); this.symbol = new Login(this).login(email, password, symbol);
logger.info("Login successful on {} at {}", getHost(), new Date()); logger.info("Login successful on {} at {}", getHost(), new Date());
} }
@ -87,6 +88,10 @@ public class Client {
return cookies.getItems(); return cookies.getItems();
} }
public void clearCookies() {
cookies = new Cookies();
}
String getHost() { String getHost() {
return host; return host;
} }
@ -216,7 +221,7 @@ public class Client {
} }
if ("Błąd strony".equals(title)) { if ("Błąd strony".equals(title)) {
throw new NotLoggedInErrorException(title + " " + doc.selectFirst("body") + ", status: " + code); throw new NotLoggedInErrorException(title + " " + doc.body() + ", status: " + code);
} }
return doc; return doc;

View File

@ -5,6 +5,8 @@ import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element; import org.jsoup.nodes.Element;
import org.jsoup.parser.Parser; import org.jsoup.parser.Parser;
import org.jsoup.select.Elements; import org.jsoup.select.Elements;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException; import java.io.IOException;
@ -21,6 +23,8 @@ public class Login {
private Client client; private Client client;
private static final Logger logger = LoggerFactory.getLogger(Login.class);
public Login(Client client) { public Login(Client client) {
this.client = client; this.client = client;
} }
@ -29,7 +33,8 @@ public class Login {
Document certDoc = sendCredentials(email, password); Document certDoc = sendCredentials(email, password);
if ("Błąd".equals(certDoc.title())) { if ("Błąd".equals(certDoc.title())) {
throw new NotLoggedInErrorException(certDoc.selectFirst("body").text()); client.clearCookies();
throw new NotLoggedInErrorException(certDoc.body().text());
} }
return sendCertificate(certDoc, symbol); return sendCertificate(certDoc, symbol);
@ -88,6 +93,7 @@ public class Login {
String title = targetDoc.title(); String title = targetDoc.title();
if ("Working...".equals(title)) { // on adfs login if ("Working...".equals(title)) { // on adfs login
logger.info("ADFS login");
title = sendCertData(targetDoc).title(); title = sendCertData(targetDoc).title();
} }
@ -96,6 +102,7 @@ public class Login {
} }
if (!"Uonet+".equals(title)) { if (!"Uonet+".equals(title)) {
logger.debug("Login failed. Body: {}", targetDoc.body());
throw new LoginErrorException("Expected page title `UONET+`, got " + title); throw new LoginErrorException("Expected page title `UONET+`, got " + title);
} }

View File

@ -3,6 +3,8 @@ package io.github.wulkanowy.api.timetable;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.jsoup.nodes.Element; import org.jsoup.nodes.Element;
import org.jsoup.select.Elements; import org.jsoup.select.Elements;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
@ -13,8 +15,8 @@ import io.github.wulkanowy.api.VulcanException;
import io.github.wulkanowy.api.generic.Lesson; import io.github.wulkanowy.api.generic.Lesson;
import io.github.wulkanowy.api.generic.Week; import io.github.wulkanowy.api.generic.Week;
import static io.github.wulkanowy.api.DateTimeUtilsKt.getFormattedDate;
import static io.github.wulkanowy.api.DateTimeUtilsKt.getDateAsTick; import static io.github.wulkanowy.api.DateTimeUtilsKt.getDateAsTick;
import static io.github.wulkanowy.api.DateTimeUtilsKt.getFormattedDate;
public class Timetable { public class Timetable {
@ -22,6 +24,8 @@ public class Timetable {
private SnP snp; private SnP snp;
private static final Logger logger = LoggerFactory.getLogger(Timetable.class);
public Timetable(SnP snp) { public Timetable(SnP snp) {
this.snp = snp; this.snp = snp;
} }
@ -45,8 +49,13 @@ public class Timetable {
private List<TimetableDay> getDays(Elements tableHeaderCells) { private List<TimetableDay> getDays(Elements tableHeaderCells) {
List<TimetableDay> days = new ArrayList<>(); List<TimetableDay> days = new ArrayList<>();
int numberOfDays = tableHeaderCells.size();
for (int i = 2; i < 7; i++) { if (numberOfDays > 7) {
logger.info("Number of days: {}", numberOfDays);
}
for (int i = 2; i < numberOfDays; i++) {
String[] dayHeaderCell = tableHeaderCells.get(i).html().split("<br>"); String[] dayHeaderCell = tableHeaderCells.get(i).html().split("<br>");
TimetableDay day = new TimetableDay(); TimetableDay day = new TimetableDay();
@ -127,6 +136,11 @@ public class Timetable {
private void addLessonInfoFromElement(Lesson lesson, Element e) { private void addLessonInfoFromElement(Lesson lesson, Element e) {
Elements spans = e.select("span"); Elements spans = e.select("span");
if (spans.isEmpty()) {
logger.warn("Lesson span is empty");
return;
}
addTypeInfo(lesson, spans); addTypeInfo(lesson, spans);
addNormalLessonInfo(lesson, spans); addNormalLessonInfo(lesson, spans);
addChangesInfo(lesson, spans); addChangesInfo(lesson, spans);
@ -213,6 +227,10 @@ public class Timetable {
} }
private String[] getLessonAndGroupInfoFromSpan(Element span) { private String[] getLessonAndGroupInfoFromSpan(Element span) {
if (!span.text().contains("[")) {
return new String[] {span.text(), ""};
}
String[] subjectNameArray = span.text().split(" "); String[] subjectNameArray = span.text().split(" ");
String groupName = subjectNameArray[subjectNameArray.length - 1]; String groupName = subjectNameArray[subjectNameArray.length - 1];

View File

@ -156,6 +156,7 @@ public class TimetableTest extends StudentAndParentTestCase {
Assert.assertEquals("poprzednio: Wychowanie fizyczne", full.getWeekTable().getDay(4).getLesson(2).getDescription()); Assert.assertEquals("poprzednio: Wychowanie fizyczne", full.getWeekTable().getDay(4).getLesson(2).getDescription());
Assert.assertEquals("egzamin", full.getWeekTable().getDay(3).getLesson(0).getDescription()); Assert.assertEquals("egzamin", full.getWeekTable().getDay(3).getLesson(0).getDescription());
Assert.assertEquals("", full.getWeekTable().getDay(4).getLesson(1).getDescription()); Assert.assertEquals("", full.getWeekTable().getDay(4).getLesson(1).getDescription());
Assert.assertEquals("poprzednio: Zajęcia z wychowawcą", full.getWeekTable().getDay(4).getLesson(5).getDescription());
Assert.assertEquals("opis w uwadze bez klasy w spanie", full.getWeekTable().getDay(4).getLesson(4).getDescription()); Assert.assertEquals("opis w uwadze bez klasy w spanie", full.getWeekTable().getDay(4).getLesson(4).getDescription());
Assert.assertEquals("", holidays.getWeekTable().getDay(3).getLesson(3).getDescription()); Assert.assertEquals("", holidays.getWeekTable().getDay(3).getLesson(3).getDescription());
} }

View File

@ -364,7 +364,20 @@
<span></span> <span></span>
</div> </div>
</td> </td>
<td></td> <td>
<div>
<span class="">Tworzenie i administrowanie bazami danych [zaw2]</span>
<span class=""></span>
<span class=""></span>
<span class=""></span>
</div>
<div>
<span class="x-treelabel-ppl x-treelabel-inv">Zajęcia z wychowawcą</span>
<span class="x-treelabel-ppl x-treelabel-inv">Małgorzata Kowal</span>
<span class="x-treelabel-ppl x-treelabel-inv">43</span>
<span class="x-treelabel-rlz">(zmiana organizacji zajęć)</span>
</div>
</td>
</tr> </tr>
<tr> <tr>
<td>6</td> <td>6</td>