An error occurred while loading the file. Please try again.
-
nivetha authored6c7c35c8
package com.tarento.retail.controller;
import java.util.List;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.tarento.retail.config.JwtTokenUtil;
import com.tarento.retail.dto.UserDto;
import com.tarento.retail.model.InstituteCourses;
import com.tarento.retail.model.LoginDto;
import com.tarento.retail.model.LoginUser;
import com.tarento.retail.model.Role;
import com.tarento.retail.model.User;
import com.tarento.retail.model.UserAuthentication;
import com.tarento.retail.model.UserProfile;
import com.tarento.retail.service.UserService;
import com.tarento.retail.util.Constants;
import com.tarento.retail.util.PathRoutes;
import com.tarento.retail.util.ResponseGenerator;
@RestController
public class AuthenticationController {
public static final Logger LOGGER = LoggerFactory.getLogger(AuthenticationController.class);
@Autowired
private AuthenticationManager authenticationManager;
@Autowired
private JwtTokenUtil jwtTokenUtil;
@Autowired
private UserService userService;
@Autowired
private UserDetailsService userDetailsService;
@RequestMapping(value = PathRoutes.AuthenticationRoutes.AUTH_LOGIN_POST, method = RequestMethod.POST)
public String register(@RequestBody LoginUser loginUser) throws JsonProcessingException {
User user = null;
LOGGER.info(" Starting the Authentication Check on LOGIN ");
if (loginUser.getUsername() != null && loginUser.getPassword() != null)// && loginUser.getPhoneNo() == null)
{
final Authentication authentication = authenticationManager.authenticate(
new UsernamePasswordAuthenticationToken(loginUser.getUsername(), loginUser.getPassword()));
SecurityContextHolder.getContext().setAuthentication(authentication);
user = userService.findOne(loginUser.getUsername());
LOGGER.info("Fetched a User for the Username ");
} else if (loginUser.getUsername() == null && loginUser.getPassword() == null
&& loginUser.getPhoneNo() != null) {
user = userService.findMobile(loginUser.getPhoneNo());
} else
return ResponseGenerator.failureResponse("Request Parameter mismatched");
if (user != null) {
7172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
final String token = jwtTokenUtil.generateToken(user);
UserAuthentication userAuthentication = new UserAuthentication();
userAuthentication.setUserId(user.getId());
userAuthentication.setAuthToken(token);
userAuthentication = userService.save(userAuthentication);
LOGGER.info("Saving the User Authentication on Auth Records Log");
List<Role> userRoles = userService.findAllRolesByUser(user.getId(), user.getOrgId(), null);
LOGGER.info("Fetched Roles Assigned for the User");
LoginDto loginDto = new LoginDto();
loginDto.setUserAvatarUrl(user.getAvatarUrl());
loginDto.setAuthToken(token);
loginDto.setUsername(user.getUsername());
loginDto.setUserId(user.getId());
loginDto.setOrgId(user.getOrgId());
loginDto.setCountryCode(user.getCountryCode());
loginDto.setRoles(userRoles);
return ResponseGenerator.successResponse(loginDto);
}
return ResponseGenerator.failureResponse("Invalid credentials. Please retry");
}
@RequestMapping(value = PathRoutes.AuthenticationRoutes.AUTH_TOKEN_VALIDATE_POST, method = RequestMethod.POST)
public Object validateToken(@RequestBody LoginDto token,
@RequestHeader(value = Constants.AUTH_HEADER) String authToken) {
String username = "";
String authTokenInfo = null;
if (token != null && StringUtils.isNotBlank(token.getAuthToken())) {
authTokenInfo = token.getAuthToken();
username = jwtTokenUtil.getUsernameFromToken(token.getAuthToken());
} else if (StringUtils.isNotBlank(authToken)) {
authTokenInfo = authToken;
username = jwtTokenUtil.getUsernameFromToken(authToken);
}
if (StringUtils.isNotBlank(username)) {
UserDetails userDetails = userDetailsService.loadUserByUsername(username);
if (jwtTokenUtil.validateToken(authTokenInfo, userDetails)) {
UserDto userDto = userService.findUserRolesActions(username);
LOGGER.info(userDto.toString());
return userDto;
}
}
return null;
}
@RequestMapping(value = PathRoutes.AuthenticationRoutes.SIGN_IN, method = RequestMethod.POST)
public String signIn(@RequestBody LoginUser loginUser) throws JsonProcessingException {
if (StringUtils.isNotBlank(loginUser.getUsername())) {
Boolean valid = Boolean.FALSE;
if (StringUtils.isNotBlank(loginUser.getOtp())) {
valid = userService.validateUserOTP(loginUser.getUsername(), loginUser.getOtp());
} else if (String.valueOf(loginUser.getPin()).length() == 4) {
valid = userService.validateUserPin(loginUser.getUsername(), loginUser.getPin());
}
if (valid) {
// Generate JWT token
User user = new User();
user.setUsername(loginUser.getUsername());
final String token = jwtTokenUtil.generateToken(user);
// get User profile details
UserProfile userProfile = userService.getUserProfile(loginUser.getUsername());
UserAuthentication userAuthentication = new UserAuthentication();
userAuthentication.setUserId(userProfile.getId());
userAuthentication.setAuthToken(token);
userAuthentication = userService.save(userAuthentication);
LOGGER.info("Saving the User Authentication on Auth Records Log");
userProfile.setAuthToken(token);
141142143144145146147148149150151152153154155156
// get user roles
List<Role> userRoles = userService.findAllRolesByUser(userProfile.getId(), userProfile.getOrgId(),
null);
LOGGER.info("Fetched Roles Assigned for the User");
userProfile.setRoles(userRoles);
List<InstituteCourses> instituteCourses = userService.findAllInstituteCourses(userProfile.getId());
userProfile.setInstituteCourses(instituteCourses);
return ResponseGenerator.successResponse(userProfile);
}
}
return ResponseGenerator.failureResponse(Constants.UNAUTHORIZED);
}
}