Compare commits

...

5 Commits

2 changed files with 29 additions and 4 deletions

View File

@@ -8,6 +8,8 @@ import com.google.api.services.calendar.model.EventReminder;
import com.google.api.services.calendar.model.Events; import com.google.api.services.calendar.model.Events;
import de.jeyp91.tippliga.TLWLeague; import de.jeyp91.tippliga.TLWLeague;
import de.jeyp91.tippliga.TLWMatchday; import de.jeyp91.tippliga.TLWMatchday;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.io.IOException; import java.io.IOException;
import java.time.LocalDateTime; import java.time.LocalDateTime;
@@ -22,6 +24,7 @@ import static de.jeyp91.googlecalendar.GoogleCalendarConnector.getSerivce;
public class TippligaGoogleEventManager { public class TippligaGoogleEventManager {
private static List<Event> allEvents = null; private static List<Event> allEvents = null;
private static final Logger logger = LogManager.getLogger(TippligaGoogleEventManager.class);
public static List<Event> getAllEvents(Integer season) { public static List<Event> getAllEvents(Integer season) {
if(allEvents == null) { if(allEvents == null) {
@@ -56,8 +59,8 @@ public class TippligaGoogleEventManager {
public static Event findEvent(List<Event> allEvents, Integer season, Integer league, Integer matchday, Integer deliveryDateNumber) { public static Event findEvent(List<Event> allEvents, Integer season, Integer league, Integer matchday, Integer deliveryDateNumber) {
String description = getDescription(season, league, matchday, deliveryDateNumber); String description = getDescription(season, league, matchday, deliveryDateNumber);
for (Event allEvent : allEvents) { for (Event event : allEvents) {
if (allEvent.getDescription().equals(description)) return allEvent; if (event.getDescription().replaceAll("\\s+","").equals(description.replaceAll("\\s+",""))) return event;
} }
return null; return null;
} }
@@ -75,7 +78,11 @@ public class TippligaGoogleEventManager {
createNewEvent(matchday, deliveryDateString, deliverDateNumber); createNewEvent(matchday, deliveryDateString, deliverDateNumber);
} }
else { else {
updateEvent(event, matchday, deliveryDateString, deliverDateNumber); String googleEventStart = event.getStart().getDateTime().toString();
String googleEventStartBeautified = googleEventStart.substring(0, 19).replace("T", " ");
if(!googleEventStartBeautified.equals(deliveryDateString)) {
updateEvent(event, matchday, deliveryDateString, deliverDateNumber);
}
} }
} }
@@ -85,6 +92,7 @@ public class TippligaGoogleEventManager {
Event event = getEvent(matchday, deliveryDateString, deliverDateNumber); Event event = getEvent(matchday, deliveryDateString, deliverDateNumber);
try { try {
logger.info("Create new google calendar event for " + matchday.getSeason() + ", " + matchday.getLeague() + ", " + matchday.getMatchday() + ", " + deliverDateNumber);
getSerivce().events().insert(calendarUrl, event).execute(); getSerivce().events().insert(calendarUrl, event).execute();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
@@ -97,6 +105,7 @@ public class TippligaGoogleEventManager {
Event event = getEvent(matchday, deliveryDateString, deliverDateNumber); Event event = getEvent(matchday, deliveryDateString, deliverDateNumber);
try { try {
logger.info("Update google calendar event for " + matchday.getSeason() + ", " + matchday.getLeague() + ", " + matchday.getMatchday() + ", " + deliverDateNumber);
Calendar.Events events = getSerivce().events(); Calendar.Events events = getSerivce().events();
events.update(calendarUrl, oldEvent.getId(), event).execute(); events.update(calendarUrl, oldEvent.getId(), event).execute();
} catch (IOException e) { } catch (IOException e) {
@@ -110,6 +119,7 @@ public class TippligaGoogleEventManager {
Event event = findEvent(getAllEvents(matchday.getSeason()), matchday.getSeason(), matchday.getLeague(), matchday.getMatchday(), deliverDateNumber); Event event = findEvent(getAllEvents(matchday.getSeason()), matchday.getSeason(), matchday.getLeague(), matchday.getMatchday(), deliverDateNumber);
if(event != null) { if(event != null) {
try { try {
logger.info("Delete google calendar event for " + matchday.getSeason() + ", " + matchday.getLeague() + ", " + matchday.getMatchday() + ", " + deliverDateNumber);
getSerivce().events().delete(calendarUrl, event.getId()).execute(); getSerivce().events().delete(calendarUrl, event.getId()).execute();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
@@ -117,11 +127,19 @@ public class TippligaGoogleEventManager {
} }
} }
public static void deleteAllEvents(int season) throws IOException {
String calendarUrl = CalendarConfigProvider.getCalendarUrl();
List<Event> events = getAllEvents(season);
for(Event event : events ) {
getSerivce().events().delete(calendarUrl, event.getId()).execute();
}
}
private static Event getEvent(TLWMatchday matchday, String deliveryDateString, Integer deliverDateNumber) { private static Event getEvent(TLWMatchday matchday, String deliveryDateString, Integer deliverDateNumber) {
String matchdayName = matchday.getMatchdayName().equals("") ? matchday.getMatchday().toString() + ". Spieltag" : matchday.getMatchdayName(); String matchdayName = matchday.getMatchdayName().equals("") ? matchday.getMatchday().toString() + ". Spieltag" : matchday.getMatchdayName();
String summary = TLWLeague.getLeagueNameCalendar(matchday.getLeague()) + " " + matchdayName + " tippen!"; String summary = TLWLeague.getLeagueNameCalendar(matchday.getLeague()) + " " + matchdayName + " tippen!";
if(deliverDateNumber > 1) summary += " " + deliverDateNumber + ". Chance \uD83D\uDE43"; if(deliverDateNumber > 1) summary += " " + deliverDateNumber + ". Chance \uD83D\uDE43";
String description = getDescription(matchday.getSeason(), matchday.getLeague() == 2 ? 1 : matchday.getLeague(), matchday.getMatchday(), deliverDateNumber); String description = getDescription(matchday.getSeason(), matchday.getLeague(), matchday.getMatchday(), deliverDateNumber);
String location = "https://tippliga-wuerzburg.de/app.php/football/bet"; String location = "https://tippliga-wuerzburg.de/app.php/football/bet";
LocalDateTime deliveryLocalDateTime = LocalDateTime.parse(deliveryDateString.replace(" ", "T")); LocalDateTime deliveryLocalDateTime = LocalDateTime.parse(deliveryDateString.replace(" ", "T"));
@@ -149,6 +167,7 @@ public class TippligaGoogleEventManager {
} }
private static String getDescription(Integer season, Integer league, Integer matchday, Integer deliverDateNumber) { private static String getDescription(Integer season, Integer league, Integer matchday, Integer deliverDateNumber) {
league = league == 2 ? 1 : league;
return "Saison: " + season + "\n" + "Liga: " + league + "\n" + "Spieltag: " + matchday + "\n" + "Abgabeschluss: " + deliverDateNumber; return "Saison: " + season + "\n" + "Liga: " + league + "\n" + "Spieltag: " + matchday + "\n" + "Abgabeschluss: " + deliverDateNumber;
} }

View File

@@ -6,6 +6,7 @@ import de.jeyp91.tippliga.TLWMatchday;
import de.jeyp91.tippliga.TLWMatchdaysCreator; import de.jeyp91.tippliga.TLWMatchdaysCreator;
import org.junit.Test; import org.junit.Test;
import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@@ -94,4 +95,9 @@ public class TippligaGoogleEventManagerTest {
TippligaGoogleEventManager.deleteEvent(tlwMatchday, 3); TippligaGoogleEventManager.deleteEvent(tlwMatchday, 3);
}); });
} }
@Test
public void deleteAllEventsTest() throws IOException {
TippligaGoogleEventManager.deleteAllEvents(2023);
}
} }