package mops.gruppen2.service; import mops.gruppen2.domain.dto.EventDTO; import mops.gruppen2.domain.Exceptions.EventException; import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Visibility; import mops.gruppen2.domain.event.Event; import mops.gruppen2.repository.EventRepository; import mops.gruppen2.security.Account; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Service public class GroupService { private final EventService eventService; private final EventRepository eventRepository; public GroupService(EventService eventService, EventRepository eventRepository) { this.eventService = eventService; this.eventRepository = eventRepository; } /** Sucht in der DB alle Zeilen raus welche eine der Gruppen_ids hat. * Wandelt die Zeilen in Events um und gibt davon eine Liste zurück. * * @param group_ids * @return */ public List getGroupEvents(List group_ids) { List eventDTOS = new ArrayList<>(); for (Long group_id: group_ids) { eventDTOS.addAll(eventRepository.findEventDTOByGroup_id(group_id)); } return eventService.translateEventDTOs(eventDTOS); } /** Erzeugt eine neue Map wo Gruppen aus den Events erzeugt und den Gruppen_ids zugeordnet werden. * Die Gruppen werden als Liste zurückgegeben * * @param events * @return * @throws EventException */ public List projectEventList(List events) throws EventException { Map groupMap = new HashMap<>(); for (Event event : events) { Group group = getOrCreateGroup(groupMap, event.getGroup_id()); event.apply(group); } return new ArrayList<>(groupMap.values()); } /** guckt in der Map anhand der Id nach ob die Gruppe schon in der Map vorhanden ist, wenn nicht wird eine neue * Gruppe erzeugt * * @param groups * @param group_id * @return */ private Group getOrCreateGroup(Map groups, long group_id) { if (!groups.containsKey(group_id)) { groups.put(group_id, new Group()); } return groups.get(group_id); } private List removeUserGroups(List group_ids, List user_groups) { for (Long group_id: user_groups) { group_ids.remove(group_id); } return group_ids; } /** * sucht alle Zeilen in der DB wo die Visibility true ist und entfernt alle Gruppen des Users. * Erstellt eine Liste aus Gruppen. * @return * @throws EventException */ public List getAllGroupWithVisibilityPublic(String user_id) throws EventException { List group_ids = removeUserGroups(eventRepository.findGroup_idsWhereVisibility(Boolean.TRUE), eventRepository.findGroup_idsWhereUser_id(user_id)); List eventDTOS = eventRepository.findAllEventsOfGroups(group_ids); List events = eventService.translateEventDTOs(eventDTOS); List groups = projectEventList(events); return groups; } /** * Filtert alle öffentliche Gruppen nach dem suchbegriff und gibt diese als Liste von Gruppen zurück. * Groß und kleinschreibung wird beachtet. * @param search * @return * @throws EventException */ public List findGroupWith(String search, Account account) throws EventException { List groups = new ArrayList<>(); for (Group group: getAllGroupWithVisibilityPublic(account.getName())) { if (group.getTitle().toLowerCase().contains(search.toLowerCase()) || group.getDescription().toLowerCase().contains(search.toLowerCase())){ groups.add(group); } } return groups; } }