package org.nextprot.api.user.controller;
import java.util.List;
import org.jsondoc.core.annotation.Api;
import org.jsondoc.core.annotation.ApiAuthBasic;
import org.jsondoc.core.annotation.ApiBodyObject;
import org.jsondoc.core.annotation.ApiMethod;
import org.jsondoc.core.annotation.ApiPathParam;
import org.jsondoc.core.pojo.ApiVerb;
import org.nextprot.api.user.domain.UserApplication;
import org.nextprot.api.user.service.UserApplicationService;
import org.nextprot.api.user.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
/**
* Controller for operating (CRUD) on user applications
*
* @author Daniel Teixeira
*/
@Controller
@PreAuthorize("hasRole('ROLE_USER')")
@Api(name = "User Application", description = "Method to manipulate applications. Applications are program that access the API", group="User")
@ApiAuthBasic(roles={"ROLE_ADMIN"})
public class UserApplicationController {
@Autowired
private UserApplicationService userApplicationService;
@Autowired
private UserService userService;
@ApiMethod(path = "/user/{username}/applications", verb = ApiVerb.GET, description = "Gets all applications for a logged user", produces = {MediaType.APPLICATION_JSON_VALUE}, consumes = { MediaType.APPLICATION_JSON_VALUE})
@RequestMapping(value = "/user/applications", method = { RequestMethod.GET })
@ResponseBody
public List<UserApplication> getApplications(@PathVariable("username") String username) {
return userApplicationService.getUserApplicationsByOwnerId(userService.getUser(username).getId());
}
@ApiMethod(path = "/user/applications", verb = ApiVerb.POST, description = "Creates a user application for the current logged user", produces = {MediaType.APPLICATION_JSON_VALUE}, consumes = { MediaType.APPLICATION_JSON_VALUE})
@RequestMapping(value = "/user/applications", method = { RequestMethod.POST })
@ResponseBody
public UserApplication createApplication(@RequestBody @ApiBodyObject UserApplication userApplication) {
return userApplicationService.createUserApplication(userApplication);
}
@ApiMethod(path = "/user/applications/{id}", verb = ApiVerb.GET, description = "Gets the application of the current user", produces = {MediaType.APPLICATION_JSON_VALUE}, consumes = { MediaType.APPLICATION_JSON_VALUE})
@RequestMapping(value = "/user/applications/{id}", method = { RequestMethod.GET })
@ResponseBody
public UserApplication getApplication(@PathVariable @ApiPathParam(name = "id", description = "The User application id") Long id) {
return userApplicationService.getUserApplication(id);
}
@ApiMethod(path = "/user/applications/{id}", verb = ApiVerb.DELETE, description = "Deletes an application", produces = {MediaType.APPLICATION_JSON_VALUE}, consumes = { MediaType.APPLICATION_JSON_VALUE})
@RequestMapping(value = "/user/applications/{id}", method = { RequestMethod.DELETE })
public void deleteApplication(@PathVariable @ApiPathParam(name = "id", description = "The User application id") Long id) {
userApplicationService.deleteApplication(id);
}
}