package cc.fascinated.bat.service; import cc.fascinated.bat.model.BatUser; import cc.fascinated.bat.repository.UserRepository; import lombok.Getter; import lombok.NonNull; import lombok.extern.log4j.Log4j2; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.DependsOn; import org.springframework.stereotype.Service; import java.util.HashMap; import java.util.Map; import java.util.Optional; /** * @author Fascinated (fascinated7) */ @Service @Log4j2 @Getter @DependsOn("discordService") public class UserService { /** * The cached users */ private final Map users = new HashMap<>(); /** * The user repository to use */ private final UserRepository userRepository; @Autowired public UserService(@NonNull UserRepository userRepository) { this.userRepository = userRepository; } /** * Gets a user by their ID * * @param id The ID of the user * @return The user */ public BatUser getUser(@NonNull String id) { if (users.containsKey(id)) { return users.get(id); } long start = System.currentTimeMillis(); Optional optionalUser = userRepository.findById(id); if (optionalUser.isPresent()) { BatUser user = optionalUser.get(); users.put(id, user); return user; } BatUser user = userRepository.save(new BatUser(id)); log.info("Created user \"{}\" in {}ms", id, System.currentTimeMillis() - start); return user; } /** * Saves a user * * @param user The user to save */ public void saveUser(@NonNull BatUser user) { userRepository.save(user); } }