added new endpoints, getUser, getUserHistories, getBookmarks

This commit is contained in:
heyethereum
2024-07-20 01:10:28 +08:00
parent f7e592f8ec
commit ee3180dbea
33 changed files with 261 additions and 55 deletions

View File

@@ -13,4 +13,9 @@ public class APIConstants {
public static final String API_URL_QRCODE_REDIRECT_COUNT = "/qrcodetypes/redirectcount"; public static final String API_URL_QRCODE_REDIRECT_COUNT = "/qrcodetypes/redirectcount";
public static final String API_URL_QRCODE_GET_QR_DETAILS = "/qrcodetypes/getQRDetails"; public static final String API_URL_QRCODE_GET_QR_DETAILS = "/qrcodetypes/getQRDetails";
public static final String API_URL_USER_GET = "/user/getUser";
public static final String API_URL_USER_GET_SCANNED_HISTORIES = "/user/getScannedHistories";
public static final String API_URL_USER_GET_BOOKMARKS = "/user/getBookmarks";
} }

View File

@@ -0,0 +1,7 @@
package com.safeqr.app.exceptions;
public class CustomNotFoundExceptions extends RuntimeException {
public CustomNotFoundExceptions(String message){
super(message);
}
}

View File

@@ -8,8 +8,8 @@ import org.springframework.web.bind.annotation.ExceptionHandler;
@ControllerAdvice @ControllerAdvice
public class GlobalExceptionHandler { public class GlobalExceptionHandler {
@ExceptionHandler(QRCodeExceptions.class) @ExceptionHandler(CustomNotFoundExceptions.class)
public ResponseEntity<ErrorResponse> handleQRCodeNotFoundException(QRCodeExceptions e) { public ResponseEntity<ErrorResponse> handleResourceNotFoundException(CustomNotFoundExceptions e) {
return new ResponseEntity<>(new ErrorResponse(e.getMessage(), HttpStatus.NOT_FOUND.value()), HttpStatus.NOT_FOUND); return new ResponseEntity<>(new ErrorResponse(e.getMessage(), HttpStatus.NOT_FOUND.value()), HttpStatus.NOT_FOUND);
} }
} }

View File

@@ -1,7 +0,0 @@
package com.safeqr.app.exceptions;
public class QRCodeExceptions extends RuntimeException {
public QRCodeExceptions(String message){
super(message);
}
}

View File

@@ -0,0 +1,39 @@
package com.safeqr.app.qrcode.entity;
import jakarta.persistence.*;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.NoArgsConstructor;
import java.util.UUID;
@Entity
@Builder
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "scan_bookmark", schema = "safeqr")
public class ScanBookmarkEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "qr_code_id", nullable = false)
private UUID qrCodeId;
@Column(name = "user_id", nullable = false)
private String userId;
@Enumerated(EnumType.STRING)
@Column(name = "status", nullable = false)
private BookmarkStatus scanStatus;
public enum BookmarkStatus {
ACTIVE,
INACTIVE
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "qr_code_id", referencedColumnName = "id", insertable = false, updatable = false)
private QRCodeEntity qrCodeEntity;
}

View File

@@ -32,4 +32,7 @@ public class ScanHistoryEntity {
ACTIVE, ACTIVE,
INACTIVE INACTIVE
} }
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "qr_code_id", referencedColumnName = "id", insertable = false, updatable = false)
private QRCodeEntity qrCodeEntity;
} }

View File

@@ -19,20 +19,20 @@ public final class EmailModel extends QRCodeModel<EmailEntity> {
private final EmailVerificationService emailVerificationService; private final EmailVerificationService emailVerificationService;
public EmailModel(QRCodeEntity scannedQRCodeEntity, EmailVerificationService emailVerificationService) { public EmailModel(QRCodeEntity scannedQRCodeEntity, EmailVerificationService emailVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.emailVerificationService = emailVerificationService; this.emailVerificationService = emailVerificationService;
this.details = null; this.details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
details = EmailEntity.builder().qrCodeId(scannedQRCode.getId()).build(); details = EmailEntity.builder().qrCodeId(data.getId()).build();
// Insert into email table // Insert into email table
emailVerificationService.insertDB(details); emailVerificationService.insertDB(details);
} }
@Override @Override
public EmailEntity getDetails () { public EmailEntity getDetails () {
return new EmailEntity(); return emailVerificationService.getEmailEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -19,19 +19,19 @@ public final class PhoneModel extends QRCodeModel<PhoneEntity> {
private final PhoneVerificationService phoneVerificationService; private final PhoneVerificationService phoneVerificationService;
public PhoneModel(QRCodeEntity scannedQRCodeEntity, PhoneVerificationService phoneVerificationService) { public PhoneModel(QRCodeEntity scannedQRCodeEntity, PhoneVerificationService phoneVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.phoneVerificationService = phoneVerificationService; this.phoneVerificationService = phoneVerificationService;
this.details = null; this.details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
details = PhoneEntity.builder().qrCodeId(scannedQRCode.getId()).build(); details = PhoneEntity.builder().qrCodeId(data.getId()).build();
// Insert into phone table // Insert into phone table
phoneVerificationService.insertDB(details); phoneVerificationService.insertDB(details);
} }
@Override @Override
public PhoneEntity getDetails () { public PhoneEntity getDetails () {
return new PhoneEntity(); return phoneVerificationService.getPhoneEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -5,7 +5,7 @@ import lombok.Data;
@Data @Data
public abstract class QRCodeModel<T>{ public abstract class QRCodeModel<T>{
QRCodeEntity scannedQRCode; QRCodeEntity data;
T details; T details;
public abstract void setDetails(); public abstract void setDetails();

View File

@@ -19,19 +19,19 @@ public final class SMSModel extends QRCodeModel<SMSEntity> {
private final SMSVerificationService smsVerificationService; private final SMSVerificationService smsVerificationService;
public SMSModel(QRCodeEntity scannedQRCodeEntity, SMSVerificationService smsVerificationService) { public SMSModel(QRCodeEntity scannedQRCodeEntity, SMSVerificationService smsVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.smsVerificationService = smsVerificationService; this.smsVerificationService = smsVerificationService;
this.details = null; this.details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
details = SMSEntity.builder().qrCodeId(scannedQRCode.getId()).build(); details = SMSEntity.builder().qrCodeId(data.getId()).build();
// Insert into sms table // Insert into sms table
smsVerificationService.insertDB(details); smsVerificationService.insertDB(details);
} }
@Override @Override
public SMSEntity getDetails () { public SMSEntity getDetails () {
return new SMSEntity(); return smsVerificationService.getSMSEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -19,19 +19,19 @@ public final class TextModel extends QRCodeModel<TextEntity> {
private final TextVerificationService textVerificationService; private final TextVerificationService textVerificationService;
public TextModel(QRCodeEntity scannedQRCodeEntity, TextVerificationService textVerificationService) { public TextModel(QRCodeEntity scannedQRCodeEntity, TextVerificationService textVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.textVerificationService = textVerificationService; this.textVerificationService = textVerificationService;
this.details = null; this.details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
details = TextEntity.builder().qrCodeId(scannedQRCode.getId()).text(scannedQRCode.getContents()).build(); details = TextEntity.builder().qrCodeId(data.getId()).text(data.getContents()).build();
// Insert into text table // Insert into text table
textVerificationService.insertDB(details); textVerificationService.insertDB(details);
} }
@Override @Override
public TextEntity getDetails () { public TextEntity getDetails () {
return new TextEntity(); return textVerificationService.getTextEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -22,19 +22,19 @@ public final class URLModel extends QRCodeModel<URLEntity> {
@Autowired @Autowired
public URLModel(QRCodeEntity scannedQRCodeEntity, URLVerificationService urlVerificationService) { public URLModel(QRCodeEntity scannedQRCodeEntity, URLVerificationService urlVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.urlVerificationService = urlVerificationService; this.urlVerificationService = urlVerificationService;
details = null; details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
String url = scannedQRCode.getContents(); String url = data.getContents();
try { try {
details = urlVerificationService.breakdownURL(url); details = urlVerificationService.breakdownURL(url);
urlVerificationService.countAndTrackRedirects(url, details); urlVerificationService.countAndTrackRedirects(url, details);
// set qrCode Identifier // set qrCode Identifier
details.setQrCodeId(scannedQRCode.getId()); details.setQrCodeId(data.getId());
// Insert into URL table // Insert into URL table
urlVerificationService.insertDB(details); urlVerificationService.insertDB(details);
@@ -45,6 +45,6 @@ public final class URLModel extends QRCodeModel<URLEntity> {
} }
@Override @Override
public URLEntity getDetails () { public URLEntity getDetails () {
return urlVerificationService.getURLEntityByQRCodeId(scannedQRCode.getId()); return urlVerificationService.getURLEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -1,7 +1,6 @@
package com.safeqr.app.qrcode.model; package com.safeqr.app.qrcode.model;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
import com.safeqr.app.qrcode.entity.EmailEntity;
import com.safeqr.app.qrcode.entity.QRCodeEntity; import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.qrcode.entity.WifiEntity; import com.safeqr.app.qrcode.entity.WifiEntity;
import com.safeqr.app.qrcode.service.WifiVerificationService; import com.safeqr.app.qrcode.service.WifiVerificationService;
@@ -19,19 +18,19 @@ public final class WifiModel extends QRCodeModel<WifiEntity> {
private final WifiVerificationService wifiVerificationService; private final WifiVerificationService wifiVerificationService;
public WifiModel(QRCodeEntity scannedQRCodeEntity, WifiVerificationService wifiVerificationService) { public WifiModel(QRCodeEntity scannedQRCodeEntity, WifiVerificationService wifiVerificationService) {
this.scannedQRCode = scannedQRCodeEntity; this.data = scannedQRCodeEntity;
this.wifiVerificationService = wifiVerificationService; this.wifiVerificationService = wifiVerificationService;
this.details = null; this.details = null;
} }
@Override @Override
public void setDetails() { public void setDetails() {
details = WifiEntity.builder().qrCodeId(scannedQRCode.getId()).build(); details = WifiEntity.builder().qrCodeId(data.getId()).build();
// Insert into wifi table // Insert into wifi table
wifiVerificationService.insertDB(details); wifiVerificationService.insertDB(details);
} }
@Override @Override
public WifiEntity getDetails () { public WifiEntity getDetails () {
return new WifiEntity(); return wifiVerificationService.getWifiEntityByQRCodeId(data.getId());
} }
} }

View File

@@ -2,5 +2,9 @@ package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.EmailEntity; import com.safeqr.app.qrcode.entity.EmailEntity;
import java.util.Optional;
import java.util.UUID;
public interface EmailRepository extends GenericRepository<EmailEntity> { public interface EmailRepository extends GenericRepository<EmailEntity> {
Optional<EmailEntity> findByQrCodeId(UUID qrCodeId);
} }

View File

@@ -2,5 +2,9 @@ package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.PhoneEntity; import com.safeqr.app.qrcode.entity.PhoneEntity;
import java.util.Optional;
import java.util.UUID;
public interface PhoneRepository extends GenericRepository<PhoneEntity> { public interface PhoneRepository extends GenericRepository<PhoneEntity> {
Optional<PhoneEntity> findByQrCodeId(UUID qrCodeId);
} }

View File

@@ -2,5 +2,9 @@ package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.SMSEntity; import com.safeqr.app.qrcode.entity.SMSEntity;
import java.util.Optional;
import java.util.UUID;
public interface SMSRepository extends GenericRepository<SMSEntity> { public interface SMSRepository extends GenericRepository<SMSEntity> {
Optional<SMSEntity> findByQrCodeId(UUID qrCodeId);
} }

View File

@@ -0,0 +1,13 @@
package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.qrcode.entity.ScanBookmarkEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import java.util.List;
public interface ScanBookmarkRepository extends JpaRepository<ScanBookmarkEntity, Long> {
@Query("SELECT sb.qrCodeEntity FROM ScanBookmarkEntity sb WHERE sb.userId = :userId AND sb.scanStatus = 'ACTIVE'")
List<QRCodeEntity> findAllBookmarksByUserId(String userId);
}

View File

@@ -1,9 +1,15 @@
package com.safeqr.app.qrcode.repository; package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.qrcode.entity.ScanHistoryEntity; import com.safeqr.app.qrcode.entity.ScanHistoryEntity;
import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import java.util.List;
@Repository @Repository
public interface ScanHistoryRepository extends JpaRepository<ScanHistoryEntity, Long> { public interface ScanHistoryRepository extends JpaRepository<ScanHistoryEntity, Long> {
@Query("SELECT sh.qrCodeEntity FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.scanStatus = 'ACTIVE'")
List<QRCodeEntity> findAllQRCodesByUserId(String userId);
} }

View File

@@ -2,5 +2,9 @@ package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.TextEntity; import com.safeqr.app.qrcode.entity.TextEntity;
import java.util.Optional;
import java.util.UUID;
public interface TextRepository extends GenericRepository<TextEntity> { public interface TextRepository extends GenericRepository<TextEntity> {
Optional<TextEntity> findByQrCodeId(UUID qrCodeId);
} }

View File

@@ -2,5 +2,9 @@ package com.safeqr.app.qrcode.repository;
import com.safeqr.app.qrcode.entity.WifiEntity; import com.safeqr.app.qrcode.entity.WifiEntity;
import java.util.Optional;
import java.util.UUID;
public interface WifiRepository extends GenericRepository<WifiEntity> { public interface WifiRepository extends GenericRepository<WifiEntity> {
Optional<WifiEntity> findByQrCodeId(UUID qrCodeId);
} }

View File

@@ -1,5 +1,6 @@
package com.safeqr.app.qrcode.service; package com.safeqr.app.qrcode.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.EmailEntity; import com.safeqr.app.qrcode.entity.EmailEntity;
import com.safeqr.app.qrcode.repository.EmailRepository; import com.safeqr.app.qrcode.repository.EmailRepository;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -7,6 +8,8 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.UUID;
@Service @Service
public class EmailVerificationService { public class EmailVerificationService {
private final EmailRepository emailRepository; private final EmailRepository emailRepository;
@@ -16,6 +19,11 @@ public class EmailVerificationService {
public EmailVerificationService(EmailRepository emailRepository) { public EmailVerificationService(EmailRepository emailRepository) {
this.emailRepository = emailRepository; this.emailRepository = emailRepository;
} }
public EmailEntity getEmailEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId);
return emailRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new CustomNotFoundExceptions("Email not found for QR Code id: " + qrCodeId));
}
public void insertDB(EmailEntity emailEntity) { public void insertDB(EmailEntity emailEntity) {
emailRepository.save(emailEntity); emailRepository.save(emailEntity);
} }

View File

@@ -1,5 +1,6 @@
package com.safeqr.app.qrcode.service; package com.safeqr.app.qrcode.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.PhoneEntity; import com.safeqr.app.qrcode.entity.PhoneEntity;
import com.safeqr.app.qrcode.repository.PhoneRepository; import com.safeqr.app.qrcode.repository.PhoneRepository;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -7,6 +8,8 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.UUID;
@Service @Service
public class PhoneVerificationService { public class PhoneVerificationService {
private final PhoneRepository phoneRepository; private final PhoneRepository phoneRepository;
@@ -16,6 +19,11 @@ public class PhoneVerificationService {
public PhoneVerificationService(PhoneRepository phoneRepository) { public PhoneVerificationService(PhoneRepository phoneRepository) {
this.phoneRepository = phoneRepository; this.phoneRepository = phoneRepository;
} }
public PhoneEntity getPhoneEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId);
return phoneRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new CustomNotFoundExceptions("Phone not found for QR Code id: " + qrCodeId));
}
public void insertDB(PhoneEntity phoneEntity) { public void insertDB(PhoneEntity phoneEntity) {
phoneRepository.save(phoneEntity); phoneRepository.save(phoneEntity);
} }

View File

@@ -3,7 +3,7 @@ package com.safeqr.app.qrcode.service;
import static com.safeqr.app.constants.CommonConstants.*; import static com.safeqr.app.constants.CommonConstants.*;
import com.safeqr.app.exceptions.QRCodeExceptions; import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.dto.request.QRCodePayload; import com.safeqr.app.qrcode.dto.request.QRCodePayload;
import com.safeqr.app.qrcode.dto.response.BaseScanResponse; import com.safeqr.app.qrcode.dto.response.BaseScanResponse;
import com.safeqr.app.qrcode.entity.QRCodeEntity; import com.safeqr.app.qrcode.entity.QRCodeEntity;
@@ -24,11 +24,7 @@ import reactor.core.publisher.Mono;
import java.security.NoSuchAlgorithmException; import java.security.NoSuchAlgorithmException;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.UUID; import java.util.UUID;
import java.util.function.Function;
import java.util.stream.Collectors;
@Service @Service
public class QRCodeTypeService { public class QRCodeTypeService {
@@ -73,7 +69,7 @@ public class QRCodeTypeService {
public BaseScanResponse getScannedQRCodeDetails(UUID qrCodeId){ public BaseScanResponse getScannedQRCodeDetails(UUID qrCodeId){
// Find scanned qr code in qr code table // Find scanned qr code in qr code table
QRCodeEntity qrCodeEntity = qrCodeRepository.findById(qrCodeId) QRCodeEntity qrCodeEntity = qrCodeRepository.findById(qrCodeId)
.orElseThrow(() -> new QRCodeExceptions("QR Code not found with id: " + qrCodeId)); .orElseThrow(() -> new CustomNotFoundExceptions("QR Code not found with id: " + qrCodeId));
logger.info("qrCodeEntity: {}", qrCodeEntity); logger.info("qrCodeEntity: {}", qrCodeEntity);
QRCodeModel<?> qrCodeModel = qrCodeFactoryProvider.createQRCodeInstance(qrCodeEntity); QRCodeModel<?> qrCodeModel = qrCodeFactoryProvider.createQRCodeInstance(qrCodeEntity);
logger.info("Retrieved details: {}", qrCodeModel.getDetails()); logger.info("Retrieved details: {}", qrCodeModel.getDetails());

View File

@@ -1,5 +1,6 @@
package com.safeqr.app.qrcode.service; package com.safeqr.app.qrcode.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.SMSEntity; import com.safeqr.app.qrcode.entity.SMSEntity;
import com.safeqr.app.qrcode.repository.SMSRepository; import com.safeqr.app.qrcode.repository.SMSRepository;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -7,6 +8,8 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.UUID;
@Service @Service
public class SMSVerificationService { public class SMSVerificationService {
private final SMSRepository smsRepository; private final SMSRepository smsRepository;
@@ -16,6 +19,12 @@ public class SMSVerificationService {
public SMSVerificationService(SMSRepository smsRepository) { public SMSVerificationService(SMSRepository smsRepository) {
this.smsRepository = smsRepository; this.smsRepository = smsRepository;
} }
public SMSEntity getSMSEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId);
return smsRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new CustomNotFoundExceptions("SMS not found for QR Code id: " + qrCodeId));
}
public void insertDB(SMSEntity smsEntity) { public void insertDB(SMSEntity smsEntity) {
smsRepository.save(smsEntity); smsRepository.save(smsEntity);
} }

View File

@@ -1,5 +1,6 @@
package com.safeqr.app.qrcode.service; package com.safeqr.app.qrcode.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.TextEntity; import com.safeqr.app.qrcode.entity.TextEntity;
import com.safeqr.app.qrcode.repository.TextRepository; import com.safeqr.app.qrcode.repository.TextRepository;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -7,6 +8,8 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.UUID;
@Service @Service
public class TextVerificationService { public class TextVerificationService {
private final TextRepository textRepository; private final TextRepository textRepository;
@@ -15,6 +18,12 @@ public class TextVerificationService {
public TextVerificationService(TextRepository textRepository) { public TextVerificationService(TextRepository textRepository) {
this.textRepository = textRepository; this.textRepository = textRepository;
} }
public TextEntity getTextEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId);
return textRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new CustomNotFoundExceptions("Text not found for QR Code id: " + qrCodeId));
}
public void insertDB(TextEntity textEntity) { public void insertDB(TextEntity textEntity) {
textRepository.save(textEntity); textRepository.save(textEntity);
} }

View File

@@ -2,7 +2,7 @@ package com.safeqr.app.qrcode.service;
import static com.safeqr.app.constants.CommonConstants.*; import static com.safeqr.app.constants.CommonConstants.*;
import com.safeqr.app.exceptions.QRCodeExceptions; import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.dto.request.QRCodePayload; import com.safeqr.app.qrcode.dto.request.QRCodePayload;
import com.safeqr.app.qrcode.dto.URLVerificationResponse; import com.safeqr.app.qrcode.dto.URLVerificationResponse;
import com.safeqr.app.qrcode.entity.URLEntity; import com.safeqr.app.qrcode.entity.URLEntity;
@@ -30,7 +30,7 @@ public class URLVerificationService {
public URLEntity getURLEntityByQRCodeId(UUID qrCodeId) { public URLEntity getURLEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId); logger.info("qrCodeId retrieving: {}", qrCodeId);
return urlRepository.findByQrCodeId(qrCodeId) return urlRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new QRCodeExceptions("URL not found for QR Code id: " + qrCodeId)); .orElseThrow(() -> new CustomNotFoundExceptions("URL not found for QR Code id: " + qrCodeId));
} }
public void insertDB(URLEntity urlEntity) { public void insertDB(URLEntity urlEntity) {

View File

@@ -1,5 +1,6 @@
package com.safeqr.app.qrcode.service; package com.safeqr.app.qrcode.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.WifiEntity; import com.safeqr.app.qrcode.entity.WifiEntity;
import com.safeqr.app.qrcode.repository.WifiRepository; import com.safeqr.app.qrcode.repository.WifiRepository;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -7,6 +8,8 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.UUID;
@Service @Service
public class WifiVerificationService { public class WifiVerificationService {
private final WifiRepository wifiRepository; private final WifiRepository wifiRepository;
@@ -16,6 +19,11 @@ public class WifiVerificationService {
public WifiVerificationService(WifiRepository wifiRepository) { public WifiVerificationService(WifiRepository wifiRepository) {
this.wifiRepository = wifiRepository; this.wifiRepository = wifiRepository;
} }
public WifiEntity getWifiEntityByQRCodeId(UUID qrCodeId) {
logger.info("qrCodeId retrieving: {}", qrCodeId);
return wifiRepository.findByQrCodeId(qrCodeId)
.orElseThrow(() -> new CustomNotFoundExceptions("Wifi not found for QR Code id: " + qrCodeId));
}
public void insertDB(WifiEntity wifiEntity) { public void insertDB(WifiEntity wifiEntity) {
wifiRepository.save(wifiEntity); wifiRepository.save(wifiEntity);
} }

View File

@@ -1,25 +1,55 @@
package com.safeqr.app.user.controller; package com.safeqr.app.user.controller;
import static com.safeqr.app.constants.APIConstants.*;
import static com.safeqr.app.constants.CommonConstants.HEADER_USER_ID;
import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.user.dto.UserResponseDto;
import com.safeqr.app.user.service.UserService; import com.safeqr.app.user.service.UserService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity; import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import java.util.List;
import java.util.Map; import java.util.Map;
@RestController @RestController
@RequestMapping("/v1") @RequestMapping(API_VERSION)
public class UserController { public class UserController {
@Autowired private static final Logger logger = LoggerFactory.getLogger(UserController.class);
UserService userService; UserService userService;
@Autowired
public UserController(UserService userService) {
this.userService = userService;
}
@GetMapping(value = "/version", produces = MediaType.APPLICATION_JSON_VALUE) @GetMapping(value = "/version", produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<Map<String, String>> version() { public ResponseEntity<Map<String, String>> version() {
// System.out.println(userService.getUserByEmail()); logger.info("Health Check");
System.out.println("Health Check");
return ResponseEntity.ok(Map.of("version","SafeQR v1.0.2")); return ResponseEntity.ok(Map.of("version","SafeQR v1.0.2"));
} }
@GetMapping(value = API_URL_USER_GET, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<UserResponseDto> getUser(@RequestHeader(name = HEADER_USER_ID) String userId) {
logger.info("Invoking GET User endpoint");
return ResponseEntity.ok(userService.getUserById(userId));
}
@GetMapping(value = API_URL_USER_GET_SCANNED_HISTORIES, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<List<QRCodeEntity>> getUserScannedHistories(@RequestHeader(name = HEADER_USER_ID) String userId) {
logger.info("Invoking GET User Scanned Histories endpoint");
return ResponseEntity.ok(userService.getUserScannedHistories(userId));
}
@GetMapping(value = API_URL_USER_GET_BOOKMARKS, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<List<QRCodeEntity>> getUserBookmarks(@RequestHeader(name = HEADER_USER_ID) String userId) {
logger.info("Invoking GET User bookmarks endpoint");
return ResponseEntity.ok(userService.getUserBookmarks(userId));
}
} }

View File

@@ -0,0 +1,4 @@
package com.safeqr.app.user.dto;
public class ScannedHistoriesResponse {
}

View File

@@ -0,0 +1,19 @@
package com.safeqr.app.user.dto;
import lombok.Builder;
import lombok.Data;
import java.time.OffsetDateTime;
import java.util.List;
@Data
@Builder
public class UserResponseDto {
private String id;
private String name;
private String email;
private OffsetDateTime dateJoined;
private OffsetDateTime dateUpdated;
private List<String> roles;
private String status;
}

View File

@@ -1,19 +1,19 @@
package com.safeqr.app.user.entity; package com.safeqr.app.user.entity;
import io.hypersistence.utils.hibernate.type.array.ListArrayType;
import jakarta.persistence.Column; import jakarta.persistence.Column;
import jakarta.persistence.Entity; import jakarta.persistence.Entity;
import jakarta.persistence.Id; import jakarta.persistence.Id;
import jakarta.persistence.Table; import jakarta.persistence.Table;
import lombok.*; import lombok.*;
import org.hibernate.annotations.Type;
import java.util.List;
import java.time.OffsetDateTime; import java.time.OffsetDateTime;
import java.util.List;
@Builder @Builder
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
@Getter
@Setter
@Entity @Entity
@Data @Data
@Table(name="user", schema = "safeqr") @Table(name="user", schema = "safeqr")
@@ -29,6 +29,8 @@ public class UserEntity {
@Column(name = "date_updated") @Column(name = "date_updated")
private OffsetDateTime dateUpdated; private OffsetDateTime dateUpdated;
private String source; @Type(ListArrayType.class)
@Column(name = "roles", columnDefinition = "text[]")
private List<String> roles;
private String status; private String status;
} }

View File

@@ -6,5 +6,4 @@ import org.springframework.stereotype.Repository;
@Repository @Repository
public interface UserRepository extends JpaRepository<UserEntity, String> { public interface UserRepository extends JpaRepository<UserEntity, String> {
UserEntity findByEmail(String email);
} }

View File

@@ -1,23 +1,52 @@
package com.safeqr.app.user.service; package com.safeqr.app.user.service;
import com.safeqr.app.exceptions.CustomNotFoundExceptions;
import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.qrcode.repository.ScanBookmarkRepository;
import com.safeqr.app.qrcode.repository.ScanHistoryRepository;
import com.safeqr.app.user.dto.UserResponseDto;
import com.safeqr.app.user.entity.UserEntity; import com.safeqr.app.user.entity.UserEntity;
import com.safeqr.app.user.repository.UserRepository; import com.safeqr.app.user.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.List;
@Service @Service
public class UserService { public class UserService {
@Autowired @Autowired
private UserRepository userRepository; public UserService(UserRepository userRepository,
ScanHistoryRepository scanHistoryRepository,
ScanBookmarkRepository scanBookmarkRepository) {
this.userRepository = userRepository;
this.scanHistoryRepository = scanHistoryRepository;
this.scanBookmarkRepository = scanBookmarkRepository;
}
private final UserRepository userRepository;
private final ScanHistoryRepository scanHistoryRepository;
private final ScanBookmarkRepository scanBookmarkRepository;
public String getUserByEmail() { public UserResponseDto getUserById(String userId) {
// Find user by id
UserEntity userEntity = userRepository.findById(userId)
.orElseThrow(() -> new CustomNotFoundExceptions("User id not found: " + userId));
// Retrieve the user by email // Map to DTO before returning to controller
UserEntity retrievedUser = userRepository.findByEmail("piggyinu@gmail.com"); return UserResponseDto.builder()
if (retrievedUser != null) { .id(userEntity.getId())
return "User found: " + retrievedUser.getName(); .email(userEntity.getEmail())
} .name(userEntity.getName())
return "User not found"; .dateJoined(userEntity.getDateCreated())
.dateUpdated(userEntity.getDateUpdated())
.roles(userEntity.getRoles())
.status(userEntity.getStatus())
.build();
}
public List<QRCodeEntity> getUserScannedHistories(String userId) {
return scanHistoryRepository.findAllQRCodesByUserId(userId);
}
public List<QRCodeEntity> getUserBookmarks(String userId) {
return scanBookmarkRepository.findAllBookmarksByUserId(userId);
} }
} }