package com.mycompany.myapp.web.rest; import com.codahale.metrics.annotation.Timed; import com.mycompany.myapp.domain.User; import com.mycompany.myapp.repository.UserRepository; import com.mycompany.myapp.security.AuthoritiesConstants; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import javax.annotation.security.RolesAllowed; import javax.inject.Inject; import javax.servlet.http.HttpServletResponse; /** * REST controller for managing users. */ @RestController @RequestMapping("/app") public class UserResource { private final Logger log = LoggerFactory.getLogger(UserResource.class); @Inject private UserRepository userRepository; /** * GET /rest/users/:login -> get the "login" user. */ @RequestMapping(value = "/rest/users/{login}", method = RequestMethod.GET, produces = "application/json") @Timed @RolesAllowed(AuthoritiesConstants.ADMIN) public User getUser(@PathVariable String login, HttpServletResponse response) { log.debug("REST request to get User : {}", login); User user = userRepository.findOne(login); if (user == null) { response.setStatus(HttpServletResponse.SC_NOT_FOUND); } return user; } }