further refactor of eventhandling
Co-Authored-By: Talha Caliskan <killerber4t@users.noreply.github.com> Co-Authored-By: tomvahl <tomvahl@users.noreply.github.com> Co-Authored-By: xxnitram <xxnitram@users.noreply.github.com> Co-Authored-By: kasch309 <kasch309@users.noreply.github.com>
This commit is contained in:
@ -21,7 +21,7 @@ public class Group {
|
||||
private long id;
|
||||
private String title;
|
||||
private String description;
|
||||
private final List<User> members;
|
||||
public List<User> members;
|
||||
private final Map<String, Role> roles;
|
||||
|
||||
private GroupType type;
|
||||
|
||||
@ -24,7 +24,8 @@ public class AddUserEvent extends Event {
|
||||
this.email = email;
|
||||
}
|
||||
|
||||
public void apply(Group group, User user) {
|
||||
public void apply(Group group) {
|
||||
User user = new User(this.user_id, this.givenname, this.familyname, this.email);
|
||||
group.getMembers().add(user);
|
||||
}
|
||||
}
|
||||
|
||||
@ -3,19 +3,27 @@ package mops.gruppen2.domain.event;
|
||||
import lombok.*;
|
||||
import mops.gruppen2.domain.Group;
|
||||
import mops.gruppen2.domain.User;
|
||||
import mops.gruppen2.domain.Group;
|
||||
|
||||
/**
|
||||
* Entfernt ein einzelnes Mitglied einer Gruppe.
|
||||
*/
|
||||
@Getter
|
||||
public class DeleteUserEvent extends Event {
|
||||
public class DeleteUserEvent extends Event {
|
||||
public DeleteUserEvent(Long group_id, String user_id) {
|
||||
super(group_id, user_id);
|
||||
}
|
||||
|
||||
public DeleteUserEvent() {}
|
||||
public DeleteUserEvent() {
|
||||
}
|
||||
|
||||
public void apply(Group group, User user) {
|
||||
group.getMembers().remove(user);
|
||||
public void apply(Group group) {
|
||||
for (User user : group.getMembers()) {
|
||||
if (user.getUser_id().equals(this.user_id)) {
|
||||
group.members.remove(user);
|
||||
group.getRoles().remove(user);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -6,11 +6,12 @@ import lombok.AllArgsConstructor;
|
||||
import lombok.Getter;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.Setter;
|
||||
import mops.gruppen2.domain.Group;
|
||||
|
||||
|
||||
@Getter
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
@JsonTypeInfo(
|
||||
include = JsonTypeInfo.As.PROPERTY,
|
||||
use = JsonTypeInfo.Id.NAME,
|
||||
@ -30,8 +31,5 @@ public class Event {
|
||||
String user_id;
|
||||
|
||||
|
||||
public Event(Long group_id,String user_id){
|
||||
this.group_id = group_id;
|
||||
this.user_id = user_id;
|
||||
}
|
||||
public void apply(Group group){}
|
||||
}
|
||||
|
||||
@ -1,6 +1,7 @@
|
||||
package mops.gruppen2.domain.event;
|
||||
|
||||
import lombok.*;
|
||||
import mops.gruppen2.domain.Exceptions.EventException;
|
||||
import mops.gruppen2.domain.Exceptions.UserNotFoundException;
|
||||
import mops.gruppen2.domain.Group;
|
||||
import mops.gruppen2.domain.Role;
|
||||
@ -17,19 +18,14 @@ import java.util.Optional;
|
||||
public class UpdateRoleEvent extends Event {
|
||||
|
||||
Role newRole;
|
||||
|
||||
public UpdateRoleEvent(Long event_id, Long group_id, String user_id, Role newRole) {
|
||||
super(event_id, group_id, user_id);
|
||||
this.newRole = newRole;
|
||||
}
|
||||
|
||||
public UpdateRoleEvent(Long group_id, String user_id, Role newRole) {
|
||||
super(group_id, user_id);
|
||||
this.newRole = newRole;
|
||||
}
|
||||
|
||||
private void apply(Group group) throws UserNotFoundException {
|
||||
User user;
|
||||
public void apply(Group group) {
|
||||
User user = new User(user_id, null, null, null);
|
||||
|
||||
Optional<User> userOptional = group.getMembers().stream()
|
||||
.filter(u -> u.getUser_id().equals(user_id))
|
||||
@ -38,7 +34,6 @@ public class UpdateRoleEvent extends Event {
|
||||
if (userOptional.isPresent()) {
|
||||
user = userOptional.get();
|
||||
} else {
|
||||
throw new UserNotFoundException("Nutzer wurde nicht gefunden!");
|
||||
}
|
||||
|
||||
if (group.getRoles().containsKey(user) && newRole == Role.MEMBER) {
|
||||
|
||||
Reference in New Issue
Block a user