package mops.gruppen2.service; import mops.gruppen2.domain.Group; import mops.gruppen2.domain.User; import mops.gruppen2.domain.dto.EventDTO; import mops.gruppen2.domain.event.Event; import mops.gruppen2.domain.exception.EventException; 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 groupIds Liste an IDs * @return Liste an Events */ public List getGroupEvents(List groupIds) { List eventDTOS = new ArrayList<>(); for (Long groupId : groupIds) { eventDTOS.addAll(eventRepository.findEventDTOByGroup_id(groupId)); } 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 Liste an Events * @return Liste an Projizierten Gruppen * @throws EventException Projektionsfehler */ public List projectEventList(List events) throws EventException { Map groupMap = new HashMap<>(); for (Event event : events) { Group group = getOrCreateGroup(groupMap, event.getGroupId()); event.apply(group); } return new ArrayList<>(groupMap.values()); } private Group getOrCreateGroup(Map groups, long groupId) { if (!groups.containsKey(groupId)) { groups.put(groupId, new Group()); } return groups.get(groupId); } private List removeUserGroups(List visibleGroups, List userGroups) { for (Group group : userGroups) { visibleGroups.remove(group); } return visibleGroups; } /** * Sucht alle Zeilen in der DB mit visibility=true. * Erstellt eine Liste aus öffentlichen Gruppen (ohen bereits beigetretenen Gruppen). * * @return Liste von projizierten Gruppen * @throws EventException Projektionsfehler */ public List getAllGroupWithVisibilityPublic(String userId) throws EventException { User user = new User(userId,null, null, null); List eventsVisible = eventService.translateEventDTOs(eventRepository.findAllEventsOfGroups(eventRepository.findGroup_idsWhereVisibility(Boolean.TRUE))); List visibleGroups = projectEventList(eventsVisible); List eventsUser = getGroupEvents(eventRepository.findGroup_idsWhereUser_id(userId)); List groups = projectEventList(eventsUser); List newGroups = new ArrayList<>(); for (Group group : groups) { if (group.getMembers().contains(user)) { newGroups.add(group); } } return removeUserGroups(visibleGroups, newGroups); } /** * Filtert alle öffentliche Gruppen nach dem Suchbegriff und gibt diese als Liste von Gruppen zurück. * Groß und Kleinschreibung wird nicht beachtet. * * @param search Der Suchstring * @return Liste von projizierten Gruppen * @throws EventException Projektionsfehler */ 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; } }