Skip to content
This repository was archived by the owner on Sep 22, 2023. It is now read-only.
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package pt.ua.deti.codespell.codespellbackend.exception.implementations;

public class InvalidEmailException extends RuntimeException{
public InvalidEmailException(String message) {
super(message);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package pt.ua.deti.codespell.codespellbackend.exception.implementations;

public class InvalidPasswordException extends RuntimeException{
public InvalidPasswordException(String message) {
super(message);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package pt.ua.deti.codespell.codespellbackend.exception.implementations;

public class InvalidUsernameException extends RuntimeException{
public InvalidUsernameException(String message) {
super(message);
}
}
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
package pt.ua.deti.codespell.codespellbackend.service;

import java.util.regex.Pattern;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.lang.NonNull;
import org.springframework.stereotype.Service;
import pt.ua.deti.codespell.codespellbackend.exception.implementations.ExistentUserException;
import pt.ua.deti.codespell.codespellbackend.exception.implementations.InvalidEmailException;
import pt.ua.deti.codespell.codespellbackend.exception.implementations.InvalidPasswordException;
import pt.ua.deti.codespell.codespellbackend.exception.implementations.InvalidUsernameException;
import pt.ua.deti.codespell.codespellbackend.exception.implementations.UserNotFoundException;
import pt.ua.deti.codespell.codespellbackend.model.User;
import pt.ua.deti.codespell.codespellbackend.repository.UserRepository;
Expand Down Expand Up @@ -37,11 +42,28 @@ public User findByEmail(String email) {
}

public void registerUser(User user) {
String emailRegex = "^[\\w!#$%&'*+/=?`{|}~^-]+(?:\\.[\\w!#$%&'*+/=?`{|}~^-]+)*@(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,6}$";
boolean emailChecker = Pattern.matches(emailRegex, user.getEmail());

if (userRepository.existsByUsername(user.getUsername()))
throw new ExistentUserException("The provided username is already taken.");
else if (userRepository.existsByEmail(user.getEmail()))
throw new ExistentUserException("The provided email is already taken.");
else if (!emailChecker)
throw new InvalidEmailException("The provided email is invalid.");
else if (user.getPassword().length() < 6 || user.getPassword() == null)
throw new InvalidPasswordException("The provided password is invalid.");
else if (user.getUsername().length() < 3 || user.getUsername() == null)
throw new InvalidUsernameException("The provided username is invalid.");
userRepository.save(user);

}

public void updateUser(User user) {

if (!userRepository.existsByUsername(user.getUsername()))
throw new UserNotFoundException(String.format("The user %s could not be found.", user.getUsername()));
userRepository.save(user);

}
}