1

Exception rework: clearer message + origin

Co-authored-by: [Mahgs] <maxoerter@gmx.de>
Co-authored-by: Christoph <tobi@urpost.de>
This commit is contained in:
Christoph
2020-03-18 18:49:40 +01:00
parent 2d8472bd4a
commit b1460abe48
20 changed files with 76 additions and 111 deletions

View File

@ -1,11 +1,5 @@
package mops.gruppen2; package mops.gruppen2;
import lombok.Setter;
import mops.gruppen2.domain.Exceptions.EventException;
import mops.gruppen2.domain.Group;
import mops.gruppen2.service.EventService;
import mops.gruppen2.service.GroupService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
@ -18,7 +12,6 @@ import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2; import springfox.documentation.swagger2.annotations.EnableSwagger2;
import java.util.Collections; import java.util.Collections;
import java.util.List;
@SpringBootApplication @SpringBootApplication
@EnableSwagger2 @EnableSwagger2

View File

@ -2,19 +2,17 @@ package mops.gruppen2.controller;
import mops.gruppen2.config.Gruppen2Config; import mops.gruppen2.config.Gruppen2Config;
import mops.gruppen2.domain.Exceptions.EventException; import mops.gruppen2.domain.Exceptions.EventException;
import mops.gruppen2.domain.Exceptions.GroupNotFoundException;
import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Group;
import mops.gruppen2.domain.Role;
import mops.gruppen2.domain.User; import mops.gruppen2.domain.User;
import mops.gruppen2.domain.Visibility;
import mops.gruppen2.domain.event.CreateGroupEvent;
import mops.gruppen2.security.Account; import mops.gruppen2.security.Account;
import mops.gruppen2.service.*; import mops.gruppen2.service.*;
import org.keycloak.adapters.springsecurity.token.KeycloakAuthenticationToken; import org.keycloak.adapters.springsecurity.token.KeycloakAuthenticationToken;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.ui.Model; import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import org.springframework.web.client.RestTemplate;
import org.springframework.web.context.annotation.SessionScope; import org.springframework.web.context.annotation.SessionScope;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.server.ResponseStatusException; import org.springframework.web.server.ResponseStatusException;
@ -33,15 +31,13 @@ public class Gruppen2Controller {
Gruppen2Config gruppen2Config; Gruppen2Config gruppen2Config;
private final KeyCloakService keyCloakService; private final KeyCloakService keyCloakService;
private final EventService eventService;
private final GroupService groupService; private final GroupService groupService;
private final UserService userService; private final UserService userService;
private final ControllerService controllerService; private final ControllerService controllerService;
private final InviteLinkRepositoryService inviteLinkRepositoryService; private final InviteLinkRepositoryService inviteLinkRepositoryService;
public Gruppen2Controller(KeyCloakService keyCloakService, EventService eventService, GroupService groupService, UserService userService, ControllerService controllerService, InviteLinkRepositoryService inviteLinkRepositoryService) { public Gruppen2Controller(KeyCloakService keyCloakService, GroupService groupService, UserService userService, ControllerService controllerService, InviteLinkRepositoryService inviteLinkRepositoryService) {
this.keyCloakService = keyCloakService; this.keyCloakService = keyCloakService;
this.eventService = eventService;
this.groupService = groupService; this.groupService = groupService;
this.userService = userService; this.userService = userService;
this.controllerService = controllerService; this.controllerService = controllerService;
@ -138,7 +134,8 @@ public class Gruppen2Controller {
model.addAttribute("admin", Role.ADMIN); model.addAttribute("admin", Role.ADMIN);
return "detailsMember"; return "detailsMember";
} }
throw new GroupNotFoundException();
throw new GroupNotFoundException(this.getClass().toString());
} }
@RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"}) @RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"})
@ -162,7 +159,7 @@ public class Gruppen2Controller {
model.addAttribute("group", group); model.addAttribute("group", group);
return "detailsNoMember"; return "detailsNoMember";
} }
throw new GroupNotFoundException(); throw new GroupNotFoundException(this.getClass().toString());
} }
@RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"}) @RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"})
@ -174,7 +171,7 @@ public class Gruppen2Controller {
model.addAttribute("group", group); model.addAttribute("group", group);
return "redirect:/gruppen2/detailsSearch?id=" + group.getId(); return "redirect:/gruppen2/detailsSearch?id=" + group.getId();
} }
throw new GroupNotFoundException(); throw new GroupNotFoundException(this.getClass().toString());
} }
@RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"}) @RolesAllowed({"ROLE_orga", "ROLE_studentin", "ROLE_actuator"})

View File

@ -3,15 +3,10 @@ package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
import org.springframework.web.server.ResponseStatusException; import org.springframework.web.server.ResponseStatusException;
public class EventException extends ResponseStatusException { public abstract class EventException extends ResponseStatusException {
private String msg;
public EventException(String msg, HttpStatus status) { public EventException(HttpStatus status, String msg, String info) {
super(status, msg); super(status, msg + " (" + info + ")");
} }
@Override
public String getMessage() {
return msg;
}
} }

View File

@ -3,11 +3,8 @@ package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
public class GroupIdMismatchException extends EventException { public class GroupIdMismatchException extends EventException {
public GroupIdMismatchException(String msg) {
super("Falsche Gruppe für Event." + " (" + msg + ")", HttpStatus.INTERNAL_SERVER_ERROR);
}
public GroupIdMismatchException() { public GroupIdMismatchException(String info) {
super("", HttpStatus.INTERNAL_SERVER_ERROR); super(HttpStatus.INTERNAL_SERVER_ERROR, "Falsche Gruppe für Event.", info);
} }
} }

View File

@ -3,11 +3,8 @@ package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
public class GroupNotFoundException extends EventException { public class GroupNotFoundException extends EventException {
public GroupNotFoundException(String msg) {
super(msg, HttpStatus.NOT_FOUND);
}
public GroupNotFoundException() { public GroupNotFoundException(String info) {
super("Gruppe nicht gefunden.", HttpStatus.NOT_FOUND); super(HttpStatus.NOT_FOUND, "Gruppe wurde nicht gefunden.", info);
} }
} }

View File

@ -0,0 +1,10 @@
package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus;
public class NoValueException extends EventException {
public NoValueException(String info) {
super(HttpStatus.NO_CONTENT, "Eine Information fehlt.", info);
}
}

View File

@ -3,11 +3,8 @@ package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
public class UserAlreadyExistsException extends EventException { public class UserAlreadyExistsException extends EventException {
public UserAlreadyExistsException(String msg) {
super(msg, HttpStatus.INTERNAL_SERVER_ERROR);
}
public UserAlreadyExistsException() { public UserAlreadyExistsException(String info) {
super("Der User existiert bereits.", HttpStatus.INTERNAL_SERVER_ERROR); super(HttpStatus.INTERNAL_SERVER_ERROR, "Der User existiert bereits.", info);
} }
} }

View File

@ -3,11 +3,8 @@ package mops.gruppen2.domain.Exceptions;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
public class UserNotFoundException extends EventException { public class UserNotFoundException extends EventException {
public UserNotFoundException(String msg) {
super(msg, HttpStatus.NOT_FOUND);
}
public UserNotFoundException() { public UserNotFoundException(String info) {
super("Der User wurde nicht gefunden.", HttpStatus.NOT_FOUND); super(HttpStatus.NOT_FOUND, "Der User wurde nicht gefunden.", info);
} }
} }

View File

@ -4,11 +4,11 @@ import lombok.AllArgsConstructor;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import lombok.Getter; import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import mops.gruppen2.domain.Exceptions.UserAlreadyExistsException;
import mops.gruppen2.domain.Exceptions.UserNotFoundException;
import mops.gruppen2.domain.event.*;
import java.util.*; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/** /**
* Repräsentiert den aggregierten Zustand einer Gruppe. * Repräsentiert den aggregierten Zustand einer Gruppe.
@ -18,7 +18,7 @@ import java.util.*;
@Setter @Setter
@AllArgsConstructor @AllArgsConstructor
public class Group { public class Group {
private long id; private Long id;
private String title; private String title;
private String description; private String description;
private final List<User> members; private final List<User> members;

View File

@ -16,9 +16,10 @@ import mops.gruppen2.domain.User;
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
public class AddUserEvent extends Event { public class AddUserEvent extends Event {
String givenname;
String familyname; private String givenname;
String email; private String familyname;
private String email;
public AddUserEvent(Long group_id, String user_id, String givenname, String familyname, String email) { public AddUserEvent(Long group_id, String user_id, String givenname, String familyname, String email) {
super(group_id, user_id); super(group_id, user_id);
@ -32,7 +33,7 @@ public class AddUserEvent extends Event {
User user = new User(this.user_id, this.givenname, this.familyname, this.email); User user = new User(this.user_id, this.givenname, this.familyname, this.email);
if (group.getMembers().contains(user)) { if (group.getMembers().contains(user)) {
throw new UserAlreadyExistsException(); throw new UserAlreadyExistsException(this.getClass().toString());
} }
group.getMembers().add(user); group.getMembers().add(user);

View File

@ -11,6 +11,7 @@ import mops.gruppen2.domain.Visibility;
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
public class CreateGroupEvent extends Event { public class CreateGroupEvent extends Event {
private Visibility groupVisibility; private Visibility groupVisibility;
private Long groupParent; private Long groupParent;
private GroupType groupType; private GroupType groupType;

View File

@ -13,6 +13,7 @@ import mops.gruppen2.domain.User;
@Getter @Getter
@NoArgsConstructor @NoArgsConstructor
public class DeleteUserEvent extends Event { public class DeleteUserEvent extends Event {
public DeleteUserEvent(Long group_id, String user_id) { public DeleteUserEvent(Long group_id, String user_id) {
super(group_id, user_id); super(group_id, user_id);
} }
@ -26,6 +27,6 @@ public class DeleteUserEvent extends Event {
return; return;
} }
} }
throw new UserNotFoundException("Der User existiert nicht"); throw new UserNotFoundException(this.getClass().toString());
} }
} }

View File

@ -7,12 +7,9 @@ import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.Setter; import lombok.Setter;
import mops.gruppen2.domain.Exceptions.EventException; import mops.gruppen2.domain.Exceptions.EventException;
import mops.gruppen2.domain.Exceptions.GroupIdMismatchException;
import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Group;
@Getter
@NoArgsConstructor
@AllArgsConstructor
@JsonTypeInfo( @JsonTypeInfo(
include = JsonTypeInfo.As.PROPERTY, include = JsonTypeInfo.As.PROPERTY,
use = JsonTypeInfo.Id.NAME, use = JsonTypeInfo.Id.NAME,
@ -26,27 +23,27 @@ import mops.gruppen2.domain.Group;
@JsonSubTypes.Type(value = UpdateGroupTitleEvent.class, name = "UpdateGroupTitleEvent"), @JsonSubTypes.Type(value = UpdateGroupTitleEvent.class, name = "UpdateGroupTitleEvent"),
@JsonSubTypes.Type(value = UpdateRoleEvent.class, name = "UpdateRoleEvent"), @JsonSubTypes.Type(value = UpdateRoleEvent.class, name = "UpdateRoleEvent"),
}) })
@Getter
@Setter @Setter
public class Event { @NoArgsConstructor // Needed by Lombok in Subclasses
Long group_id; @AllArgsConstructor
String user_id; public abstract class Event {
protected Long group_id;
protected String user_id;
public void apply(Group group) throws EventException { public void apply(Group group) throws EventException {
checkGroupIdMatch(group.getId()); checkGroupIdMatch(group.getId());
applyEvent(group); applyEvent(group);
} }
protected void applyEvent(Group group) throws EventException { protected abstract void applyEvent(Group group) throws EventException;
}
private void checkGroupIdMatch(Long group_id) { private void checkGroupIdMatch(Long group_id) {
if (this.group_id.equals(group_id)) { if (group_id == null || this.group_id.equals(group_id)) {
return; return;
} }
//throw new GroupIdMismatchException(this.getClass().toString()); throw new GroupIdMismatchException(this.getClass().toString());
System.out.println(group_id);
System.out.println(this.group_id);
} }
} }

View File

@ -3,6 +3,7 @@ package mops.gruppen2.domain.event;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Getter; import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import mops.gruppen2.domain.Exceptions.NoValueException;
import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Group;
/** /**
@ -12,7 +13,8 @@ import mops.gruppen2.domain.Group;
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
public class UpdateGroupDescriptionEvent extends Event { public class UpdateGroupDescriptionEvent extends Event {
String newGroupDescription;
private String newGroupDescription;
public UpdateGroupDescriptionEvent(Long group_id, String user_id, String newGroupDescription) { public UpdateGroupDescriptionEvent(Long group_id, String user_id, String newGroupDescription) {
super(group_id, user_id); super(group_id, user_id);
@ -21,6 +23,10 @@ public class UpdateGroupDescriptionEvent extends Event {
@Override @Override
public void applyEvent(Group group) { public void applyEvent(Group group) {
if (this.newGroupDescription.isEmpty()) {
throw new NoValueException(this.getClass().toString());
}
group.setDescription(this.newGroupDescription); group.setDescription(this.newGroupDescription);
} }
} }

View File

@ -3,6 +3,7 @@ package mops.gruppen2.domain.event;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Getter; import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import mops.gruppen2.domain.Exceptions.NoValueException;
import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Group;
/** /**
@ -12,7 +13,8 @@ import mops.gruppen2.domain.Group;
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
public class UpdateGroupTitleEvent extends Event { public class UpdateGroupTitleEvent extends Event {
String newGroupTitle;
private String newGroupTitle;
public UpdateGroupTitleEvent(Long group_id, String user_id, String newGroupTitle) { public UpdateGroupTitleEvent(Long group_id, String user_id, String newGroupTitle) {
super(group_id, user_id); super(group_id, user_id);
@ -21,6 +23,10 @@ public class UpdateGroupTitleEvent extends Event {
@Override @Override
public void applyEvent(Group group) { public void applyEvent(Group group) {
if (this.getNewGroupTitle().isEmpty()) {
throw new NoValueException(this.getClass().toString());
}
group.setTitle(this.newGroupTitle); group.setTitle(this.newGroupTitle);
} }

View File

@ -15,7 +15,7 @@ import mops.gruppen2.domain.Role;
@NoArgsConstructor @NoArgsConstructor
public class UpdateRoleEvent extends Event { public class UpdateRoleEvent extends Event {
Role newRole; private Role newRole;
public UpdateRoleEvent(Long group_id, String user_id, Role newRole) { public UpdateRoleEvent(Long group_id, String user_id, Role newRole) {
super(group_id, user_id); super(group_id, user_id);
@ -24,10 +24,11 @@ public class UpdateRoleEvent extends Event {
@Override @Override
public void applyEvent(Group group) throws UserNotFoundException { public void applyEvent(Group group) throws UserNotFoundException {
if (!group.getRoles().containsKey(user_id)) { if (group.getRoles().containsKey(user_id)) {
throw new UserNotFoundException(); group.getRoles().put(this.user_id, this.newRole);
} }
group.getRoles().put(this.user_id, this.newRole);
throw new UserNotFoundException(this.getClass().toString());
} }
} }

View File

@ -1,8 +1,7 @@
package mops.gruppen2.service; package mops.gruppen2.service;
import mops.gruppen2.domain.*;
import mops.gruppen2.domain.Exceptions.EventException; import mops.gruppen2.domain.Exceptions.EventException;
import mops.gruppen2.domain.*;
import mops.gruppen2.domain.event.*; import mops.gruppen2.domain.event.*;
import mops.gruppen2.security.Account; import mops.gruppen2.security.Account;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -47,12 +46,11 @@ public class ControllerService {
CreateGroupEvent createGroupEvent = new CreateGroupEvent(group_id, account.getName(), null , GroupType.SIMPLE, visibility1); CreateGroupEvent createGroupEvent = new CreateGroupEvent(group_id, account.getName(), null , GroupType.SIMPLE, visibility1);
eventService.saveEvent(createGroupEvent); eventService.saveEvent(createGroupEvent);
User user = new User(account.getName(), account.getGivenname(), account.getFamilyname(), account.getEmail());
addUser(account, group_id); addUser(account, group_id);
updateTitle(account, group_id, title); updateTitle(account, group_id, title);
updateDescription(account, group_id, description); updateDescription(account, group_id, description);
updateRole(user.getUser_id(), group_id); updateRole(account.getName(), group_id);
} }
private void createInviteLink(Long group_id) { private void createInviteLink(Long group_id) {

View File

@ -66,9 +66,11 @@ public class EventService {
*/ */
public Long checkGroup() { public Long checkGroup() {
Long maxGroupID = eventStore.getMaxGroupID(); Long maxGroupID = eventStore.getMaxGroupID();
if (maxGroupID == null) { if (maxGroupID == null) {
return 1L; return 1L;
} }
return maxGroupID + 1; return maxGroupID + 1;
} }

View File

@ -1,9 +1,8 @@
package mops.gruppen2.service; package mops.gruppen2.service;
import mops.gruppen2.domain.dto.EventDTO;
import mops.gruppen2.domain.Exceptions.EventException; import mops.gruppen2.domain.Exceptions.EventException;
import mops.gruppen2.domain.Group; import mops.gruppen2.domain.Group;
import mops.gruppen2.domain.Visibility; import mops.gruppen2.domain.dto.EventDTO;
import mops.gruppen2.domain.event.Event; import mops.gruppen2.domain.event.Event;
import mops.gruppen2.repository.EventRepository; import mops.gruppen2.repository.EventRepository;
import mops.gruppen2.security.Account; import mops.gruppen2.security.Account;

View File

@ -1,30 +0,0 @@
package mops.gruppen2.service;
import com.fasterxml.jackson.core.JsonProcessingException;
import mops.gruppen2.domain.Role;
import mops.gruppen2.domain.event.*;
import mops.gruppen2.repository.EventRepository;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.mock;
class SerializationServiceTest {
SerializationService serializationService;
@BeforeEach
public void setUp() {
serializationService = new SerializationService(mock(EventRepository.class));
}
@Test
void serializeEventTest() throws JsonProcessingException {
Event event = new Event(1L,"1");
assertThat(serializationService.serializeEvent(event)).isEqualTo("{\"type\":\"Event\",\"group_id\":1,\"user_id\":\"1\"}");
}
}