Refactor of all createGroups complete
Co-authored-by: AndiBuls <andreas.buls@uni-duesseldorf.de>
This commit is contained in:
@ -18,6 +18,7 @@ import mops.gruppen2.domain.exception.EventException;
|
|||||||
import mops.gruppen2.domain.exception.UserNotFoundException;
|
import mops.gruppen2.domain.exception.UserNotFoundException;
|
||||||
import mops.gruppen2.domain.exception.WrongFileException;
|
import mops.gruppen2.domain.exception.WrongFileException;
|
||||||
import mops.gruppen2.security.Account;
|
import mops.gruppen2.security.Account;
|
||||||
|
import org.keycloak.jose.jwk.JWK;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
@ -77,12 +78,25 @@ public class ControllerService {
|
|||||||
public void createGroupAsOrga(Account account, String title, String description, Boolean isVisibilityPrivate, Boolean isLecture, Boolean isMaximumInfinite, Long userMaximum, UUID parent, MultipartFile file) throws EventException, IOException {
|
public void createGroupAsOrga(Account account, String title, String description, Boolean isVisibilityPrivate, Boolean isLecture, Boolean isMaximumInfinite, Long userMaximum, UUID parent, MultipartFile file) throws EventException, IOException {
|
||||||
userMaximum = checkInfiniteUsers(isMaximumInfinite, userMaximum);
|
userMaximum = checkInfiniteUsers(isMaximumInfinite, userMaximum);
|
||||||
|
|
||||||
List<User> userList = readCsvFile(file);
|
List<User> newUsers = readCsvFile(file);
|
||||||
userMaximum = adjustUserMaximum((long) userList.size(), 1L, userMaximum);
|
|
||||||
|
List<User> oldUsers = new ArrayList<>();
|
||||||
|
User user = new User(account.getName(), "", "", "");
|
||||||
|
oldUsers.add(user);
|
||||||
|
|
||||||
|
removeOldUsersFromNewUsers(oldUsers, newUsers);
|
||||||
|
|
||||||
|
userMaximum = adjustUserMaximum((long) newUsers.size(), 1L, userMaximum);
|
||||||
|
|
||||||
UUID groupId = createGroup(account, title, description, isVisibilityPrivate, isLecture, isMaximumInfinite, userMaximum, parent);
|
UUID groupId = createGroup(account, title, description, isVisibilityPrivate, isLecture, isMaximumInfinite, userMaximum, parent);
|
||||||
|
|
||||||
addUserList(userList, groupId);
|
addUserList(newUsers, groupId);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void removeOldUsersFromNewUsers(List<User> oldUsers, List<User> newUsers){
|
||||||
|
for(User oldUser : oldUsers) {
|
||||||
|
newUsers.remove(oldUser);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user