diff --git a/pom.xml b/pom.xml
index 52082a9..3098a67 100644
--- a/pom.xml
+++ b/pom.xml
@@ -68,6 +68,11 @@
hypersistence-utils-hibernate-63
3.8.1
+
+ com.google.apis
+ google-api-services-gmail
+ v1-rev20240520-2.0.0
+
diff --git a/src/main/java/com/safeqr/app/qrcode/repository/ScanHistoryRepository.java b/src/main/java/com/safeqr/app/qrcode/repository/ScanHistoryRepository.java
index 7e38e89..b564d8d 100644
--- a/src/main/java/com/safeqr/app/qrcode/repository/ScanHistoryRepository.java
+++ b/src/main/java/com/safeqr/app/qrcode/repository/ScanHistoryRepository.java
@@ -1,5 +1,7 @@
package com.safeqr.app.qrcode.repository;
+import com.safeqr.app.qrcode.entity.QRCodeEntity;
+import com.safeqr.app.qrcode.entity.ScanBookmarkEntity;
import com.safeqr.app.qrcode.entity.ScanHistoryEntity;
import com.safeqr.app.user.dto.ScannedHistoriesDto;
import org.springframework.data.jpa.repository.JpaRepository;
@@ -7,14 +9,15 @@ import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
+import org.springframework.transaction.annotation.Transactional;
import java.util.List;
+import java.util.Optional;
import java.util.UUID;
@Repository
public interface ScanHistoryRepository extends JpaRepository {
- @Query("SELECT new com.safeqr.app.user.dto.ScannedHistoriesDto(sh.qrCodeEntity, sh.bookmarked) " +
- "FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.scanStatus = 'ACTIVE' ORDER BY sh.dateCreated DESC")
+ @Query("SELECT new com.safeqr.app.user.dto.ScannedHistoriesDto(sh.qrCodeEntity, sh.bookmarked) FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.scanStatus = 'ACTIVE' ORDER BY sh.dateCreated DESC")
List findAllQRCodesByUserId(@Param("userId") String userId);
@Modifying
@@ -24,4 +27,25 @@ public interface ScanHistoryRepository extends JpaRepository findByUserIdAndQrCodeId(String userId, UUID qrCodeId);
+
+ @Query("SELECT new com.safeqr.app.user.dto.ScannedHistoriesDto(sh.qrCodeEntity, sh.bookmarked) FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.bookmarked = true AND sh.scanStatus = 'ACTIVE' ORDER BY sh.dateCreated DESC")
+ List findAllBookmarksByUserId(@Param("userId") String userId);
+
+ @Modifying
+ @Transactional
+ @Query("UPDATE ScanHistoryEntity sh SET sh.bookmarked = true, sh.dateUpdated = CURRENT_TIMESTAMP " +
+ "WHERE sh.userId = :userId AND sh.bookmarked = false AND sh.qrCodeId = :qrCodeId AND sh.scanStatus = 'ACTIVE'")
+ int updateBookmarkStatusToActive(String userId, UUID qrCodeId);
+ @Modifying
+ @Transactional
+ @Query("UPDATE ScanHistoryEntity sh SET sh.bookmarked = false, sh.dateUpdated = CURRENT_TIMESTAMP " +
+ "WHERE sh.userId = :userId AND sh.bookmarked = true AND sh.qrCodeId = :qrCodeId AND sh.scanStatus = 'ACTIVE'")
+ int updateBookmarkStatusToInactive(String userId, UUID qrCodeId);
+
+ @Modifying
+ @Transactional
+ @Query("UPDATE ScanHistoryEntity sh SET sh.bookmarked = false, sh.dateUpdated = CURRENT_TIMESTAMP WHERE sh.userId = :userId AND sh.bookmarked = true AND sh.scanStatus = 'ACTIVE'")
+ int updateBookmarkStatusToInactiveByUserId(String userId);
}
\ No newline at end of file
diff --git a/src/main/java/com/safeqr/app/user/controller/UserController.java b/src/main/java/com/safeqr/app/user/controller/UserController.java
index f995741..2cf4fae 100644
--- a/src/main/java/com/safeqr/app/user/controller/UserController.java
+++ b/src/main/java/com/safeqr/app/user/controller/UserController.java
@@ -60,7 +60,7 @@ public class UserController {
}
@GetMapping(value = API_URL_USER_GET_BOOKMARKS, produces = MediaType.APPLICATION_JSON_VALUE)
- public ResponseEntity> getUserBookmarks(@RequestHeader(name = HEADER_USER_ID) String userId) {
+ public ResponseEntity> getUserBookmarks(@RequestHeader(name = HEADER_USER_ID) String userId) {
logger.info("Invoking GET User bookmarks endpoint");
return ResponseEntity.ok(userService.getUserBookmarks(userId));
}
diff --git a/src/main/java/com/safeqr/app/user/service/UserService.java b/src/main/java/com/safeqr/app/user/service/UserService.java
index e60e00d..190f7ec 100644
--- a/src/main/java/com/safeqr/app/user/service/UserService.java
+++ b/src/main/java/com/safeqr/app/user/service/UserService.java
@@ -2,8 +2,8 @@ package com.safeqr.app.user.service;
import com.safeqr.app.exceptions.ResourceAlreadyExists;
import com.safeqr.app.exceptions.ResourceNotFoundExceptions;
-import com.safeqr.app.qrcode.entity.QRCodeEntity;
import com.safeqr.app.qrcode.entity.ScanBookmarkEntity;
+import com.safeqr.app.qrcode.entity.ScanHistoryEntity;
import com.safeqr.app.qrcode.repository.ScanBookmarkRepository;
import com.safeqr.app.qrcode.repository.ScanHistoryRepository;
import com.safeqr.app.user.dto.BaseResponse;
@@ -75,39 +75,32 @@ public class UserService {
BaseResponse.builder().message("No QR Code not found").build():
BaseResponse.builder().message("All scanned QR Code deleted successfully").build();
}
- public List getUserBookmarks(String userId) {
- return scanBookmarkRepository.findAllBookmarksByUserId(userId);
+ public List getUserBookmarks(String userId) {
+ return scanHistoryRepository.findAllBookmarksByUserId(userId);
}
@Transactional
public BaseResponse setBookmark(String userId, UUID qrCodeId) {
// Check if the bookmark already exists
- Optional existingBookmark = scanBookmarkRepository.findByUserIdAndQrCodeId(userId, qrCodeId);
+ Optional existingBookmark = scanHistoryRepository.findByUserIdAndQrCodeId(userId, qrCodeId);
// throw exception if bookmark already exists
if (existingBookmark.isPresent()) {
throw new ResourceAlreadyExists("Bookmark already exists!");
}
- try {
- // Save bookmark
- ScanBookmarkEntity bookmarkEntity = ScanBookmarkEntity.builder()
- .userId(userId)
- .qrCodeId(qrCodeId)
- .bookmarkStatus(ScanBookmarkEntity.BookmarkStatus.ACTIVE)
- .build();
- scanBookmarkRepository.save(bookmarkEntity);
- } catch (DataIntegrityViolationException e) {
- logger.error("Failed to create bookmark: {}", e.getMessage());
- // throw exception if bookmark creation fails
+ // Save bookmark by updating booked to true
+ int updatedCount = scanHistoryRepository.updateBookmarkStatusToActive(userId, qrCodeId);
+
+ if (updatedCount < 1)
throw new ResourceNotFoundExceptions("Unable to create bookmark. The QR code may not exist.");
- }
return BaseResponse.builder().message("Bookmark saved successfully").build();
+
}
@Transactional
public BaseResponse deleteBookmark(String userId, UUID qrCodeId) {
- int updatedCount = scanBookmarkRepository.updateBookmarkStatusToInactive(userId, qrCodeId);
+ int updatedCount = scanHistoryRepository.updateBookmarkStatusToInactive(userId, qrCodeId);
// throw exception if bookmark not found
if (updatedCount < 1)
throw new ResourceNotFoundExceptions("Bookmark not found");
@@ -117,7 +110,7 @@ public class UserService {
@Transactional
public BaseResponse deleteAllBookmarkByUserId(String userId) {
- int updatedCount = scanBookmarkRepository.updateBookmarkStatusToInactiveByUserId(userId);
+ int updatedCount = scanHistoryRepository.updateBookmarkStatusToInactiveByUserId(userId);
return (updatedCount < 1) ?
BaseResponse.builder().message("No Bookmark not found").build():