UserViewController.java
2.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
package net.ziemers.swxercise.ui;
import java.util.Collection;
import javax.enterprise.context.ApplicationScoped;
import javax.inject.Inject;
import javax.ws.rs.*;
import javax.ws.rs.core.MediaType;
import net.ziemers.swxercise.lg.model.user.User;
import net.ziemers.swxercise.lg.user.dto.UserDto;
import net.ziemers.swxercise.lg.user.service.UserService;
@ApplicationScoped
@Path(UserViewController.webContextPath)
public class UserViewController {
static final String webContextPath = "/users";
@Inject
private UserService userService;
/**
* Liefert alle User-Objekte zurück.
*
* @return die User-Objekte.
*/
@GET
@Produces(MediaType.APPLICATION_JSON)
public Collection<User> getAllUsers() {
return userService.findAllUsers();
}
/**
* Liefert das User-Objekt mit der gewünschten Id zurück.
*
* Aufruf:
* GET http://localhost:8080/swxercise/rest/users/42
*
* @param id die Id des gewünschten User-Objekts
* @return das User-Objekt.
*/
@GET
@Path("{id}")
@Produces(MediaType.APPLICATION_JSON)
public User getById(@PathParam("id") Long id) {
return userService.findUser(id);
}
/**
* Erstellt ein neues User-Objekt mit den gewünschten Eigenschaften, welche mittels {@link UserDto} definiert werden.
*
* Aufruf:
* POST http://localhost:8080/swxercise/rest/users
*
* @param dto das mittels der als JSON-Objekt übergebenenen Eigenschaften zu füllende {@link UserDto}
* @return "Ok", wenn die Erstellung des User-Objekts erfolgreich war.
* @throws Exception wirft eine Exception, wenn das Erstellen des UserDto fehlschlug
*/
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces({MediaType.TEXT_PLAIN})
public String createUser(UserDto dto) throws Exception {
userService.createUser(dto);
return "Ok";
}
/**
* Aktualisiert das User-Objekt mit der gewünschten Id mit den Eigenschaften, welche mittels {@link UserDto} definiert werden.
*
* Aufruf:
* PUT http://localhost:8080/swxercise/rest/users/42
*
* @param id die Id des gewünschten User-Objekts
* @return "Ok", wenn die Erstellung des User-Objekts erfolgreich war.
* @throws Exception wirft eine Exception, wenn das Erstellen des UserDto fehlschlug
*/
@PUT
@Path("{id}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces({MediaType.TEXT_PLAIN})
public String updateUser(@PathParam("id") Long id) throws Exception {
// TODO noch zu implementieren
return "Ok";
}
/**
* Löscht das User-Objekt mit der gewünschten Id.
*
* @param id die Id des gewünschten User-Objekts
* @return "Ok", wenn die Erstellung des User-Objekts erfolgreich war.
*/
@DELETE
@Path("{id}")
@Produces({MediaType.TEXT_PLAIN})
public String deleteUser(@PathParam("id") Long id) {
userService.deleteUser(id);
return "Ok";
}
}