67 lines
2.7 KiB
Java
67 lines
2.7 KiB
Java
package eu.eudat.controllers;
|
|
|
|
import eu.eudat.authorization.Permission;
|
|
import eu.eudat.exceptions.emailconfirmation.HasConfirmedEmailException;
|
|
import eu.eudat.exceptions.emailconfirmation.TokenExpiredException;
|
|
import eu.eudat.logic.managers.EmailConfirmationManager;
|
|
import eu.eudat.models.data.helpers.responses.ResponseItem;
|
|
import eu.eudat.types.ApiMessageCode;
|
|
import gr.cite.commons.web.authz.service.AuthorizationService;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.http.HttpStatus;
|
|
import org.springframework.http.ResponseEntity;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
import jakarta.transaction.Transactional;
|
|
|
|
import javax.management.InvalidApplicationException;
|
|
|
|
@RestController
|
|
@CrossOrigin
|
|
@RequestMapping(value = "/api/emailConfirmation/")
|
|
public class EmailConfirmation {
|
|
|
|
private EmailConfirmationManager emailConfirmationManager;
|
|
private final AuthorizationService authorizationService;
|
|
|
|
@Autowired
|
|
public EmailConfirmation(EmailConfirmationManager emailConfirmationManager, AuthorizationService authorizationService) {
|
|
this.emailConfirmationManager = emailConfirmationManager;
|
|
this.authorizationService = authorizationService;
|
|
}
|
|
|
|
@Transactional
|
|
@RequestMapping(method = RequestMethod.GET, value = {"/{emailToken}"})
|
|
public @ResponseBody
|
|
ResponseEntity<ResponseItem> emailConfirmation(@PathVariable(value = "emailToken") String token) {
|
|
try {
|
|
this.emailConfirmationManager.confirmEmail(token);
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem().status(ApiMessageCode.SUCCESS_MESSAGE));
|
|
} catch
|
|
(HasConfirmedEmailException | TokenExpiredException | InvalidApplicationException ex) {
|
|
if (ex instanceof TokenExpiredException) {
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(new ResponseItem().status(ApiMessageCode.NO_MESSAGE));
|
|
} else {
|
|
return ResponseEntity.status(HttpStatus.FOUND).body(new ResponseItem().status(ApiMessageCode.WARN_MESSAGE));
|
|
}
|
|
}
|
|
}
|
|
|
|
@Transactional
|
|
@RequestMapping(method = RequestMethod.POST, consumes = "application/json", produces = "application/json")
|
|
public @ResponseBody
|
|
ResponseEntity sendConfirmatioEmail(@RequestBody String email) {
|
|
this.authorizationService.authorizeForce(Permission.AuthenticatedRole);
|
|
|
|
try {
|
|
this.emailConfirmationManager.sendConfirmationEmail(email);
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem().status(ApiMessageCode.SUCCESS_MESSAGE));
|
|
} catch (Exception ex) {
|
|
if (ex instanceof HasConfirmedEmailException) {
|
|
return ResponseEntity.status(HttpStatus.FOUND).body(new ResponseItem().status(ApiMessageCode.WARN_MESSAGE));
|
|
}
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(new ResponseItem().status(ApiMessageCode.NO_MESSAGE));
|
|
}
|
|
}
|
|
}
|