decomissioned bookmark repo to combine with Scan history repo

This commit is contained in:
heyethereum
2024-07-24 21:26:40 +08:00
parent 7cb68e2ec0
commit d29dddd133
4 changed files with 43 additions and 21 deletions

View File

@@ -68,6 +68,11 @@
<artifactId>hypersistence-utils-hibernate-63</artifactId> <artifactId>hypersistence-utils-hibernate-63</artifactId>
<version>3.8.1</version> <version>3.8.1</version>
</dependency> </dependency>
<dependency>
<groupId>com.google.apis</groupId>
<artifactId>google-api-services-gmail</artifactId>
<version>v1-rev20240520-2.0.0</version>
</dependency>
</dependencies> </dependencies>
<build> <build>

View File

@@ -1,5 +1,7 @@
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.ScanBookmarkEntity;
import com.safeqr.app.qrcode.entity.ScanHistoryEntity; import com.safeqr.app.qrcode.entity.ScanHistoryEntity;
import com.safeqr.app.user.dto.ScannedHistoriesDto; import com.safeqr.app.user.dto.ScannedHistoriesDto;
import org.springframework.data.jpa.repository.JpaRepository; 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.jpa.repository.Query;
import org.springframework.data.repository.query.Param; import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import java.util.List; import java.util.List;
import java.util.Optional;
import java.util.UUID; import java.util.UUID;
@Repository @Repository
public interface ScanHistoryRepository extends JpaRepository<ScanHistoryEntity, Long> { public interface ScanHistoryRepository extends JpaRepository<ScanHistoryEntity, Long> {
@Query("SELECT new com.safeqr.app.user.dto.ScannedHistoriesDto(sh.qrCodeEntity, sh.bookmarked) " + @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")
"FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.scanStatus = 'ACTIVE' ORDER BY sh.dateCreated DESC")
List<ScannedHistoriesDto> findAllQRCodesByUserId(@Param("userId") String userId); List<ScannedHistoriesDto> findAllQRCodesByUserId(@Param("userId") String userId);
@Modifying @Modifying
@@ -24,4 +27,25 @@ public interface ScanHistoryRepository extends JpaRepository<ScanHistoryEntity,
@Modifying @Modifying
@Query("UPDATE ScanHistoryEntity sh SET sh.scanStatus = com.safeqr.app.qrcode.entity.ScanHistoryEntity$ScanStatus.INACTIVE, sh.dateUpdated = CURRENT_TIMESTAMP WHERE sh.userId = :userId AND sh.scanStatus = com.safeqr.app.qrcode.entity.ScanHistoryEntity$ScanStatus.ACTIVE") @Query("UPDATE ScanHistoryEntity sh SET sh.scanStatus = com.safeqr.app.qrcode.entity.ScanHistoryEntity$ScanStatus.INACTIVE, sh.dateUpdated = CURRENT_TIMESTAMP WHERE sh.userId = :userId AND sh.scanStatus = com.safeqr.app.qrcode.entity.ScanHistoryEntity$ScanStatus.ACTIVE")
int updateScannedHistoriesToInactiveByUserId(String userId); int updateScannedHistoriesToInactiveByUserId(String userId);
@Query("SELECT sh FROM ScanHistoryEntity sh WHERE sh.userId = :userId AND sh.qrCodeId = :qrCodeId AND sh.bookmarked = true AND sh.scanStatus = 'ACTIVE'")
Optional<ScanHistoryEntity> 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<ScannedHistoriesDto> 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);
} }

View File

@@ -60,7 +60,7 @@ public class UserController {
} }
@GetMapping(value = API_URL_USER_GET_BOOKMARKS, produces = MediaType.APPLICATION_JSON_VALUE) @GetMapping(value = API_URL_USER_GET_BOOKMARKS, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<List<QRCodeEntity>> getUserBookmarks(@RequestHeader(name = HEADER_USER_ID) String userId) { public ResponseEntity<List<ScannedHistoriesDto>> getUserBookmarks(@RequestHeader(name = HEADER_USER_ID) String userId) {
logger.info("Invoking GET User bookmarks endpoint"); logger.info("Invoking GET User bookmarks endpoint");
return ResponseEntity.ok(userService.getUserBookmarks(userId)); return ResponseEntity.ok(userService.getUserBookmarks(userId));
} }

View File

@@ -2,8 +2,8 @@ package com.safeqr.app.user.service;
import com.safeqr.app.exceptions.ResourceAlreadyExists; import com.safeqr.app.exceptions.ResourceAlreadyExists;
import com.safeqr.app.exceptions.ResourceNotFoundExceptions; 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.ScanBookmarkEntity;
import com.safeqr.app.qrcode.entity.ScanHistoryEntity;
import com.safeqr.app.qrcode.repository.ScanBookmarkRepository; import com.safeqr.app.qrcode.repository.ScanBookmarkRepository;
import com.safeqr.app.qrcode.repository.ScanHistoryRepository; import com.safeqr.app.qrcode.repository.ScanHistoryRepository;
import com.safeqr.app.user.dto.BaseResponse; 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("No QR Code not found").build():
BaseResponse.builder().message("All scanned QR Code deleted successfully").build(); BaseResponse.builder().message("All scanned QR Code deleted successfully").build();
} }
public List<QRCodeEntity> getUserBookmarks(String userId) { public List<ScannedHistoriesDto> getUserBookmarks(String userId) {
return scanBookmarkRepository.findAllBookmarksByUserId(userId); return scanHistoryRepository.findAllBookmarksByUserId(userId);
} }
@Transactional @Transactional
public BaseResponse setBookmark(String userId, UUID qrCodeId) { public BaseResponse setBookmark(String userId, UUID qrCodeId) {
// Check if the bookmark already exists // Check if the bookmark already exists
Optional<ScanBookmarkEntity> existingBookmark = scanBookmarkRepository.findByUserIdAndQrCodeId(userId, qrCodeId); Optional<ScanHistoryEntity> existingBookmark = scanHistoryRepository.findByUserIdAndQrCodeId(userId, qrCodeId);
// throw exception if bookmark already exists // throw exception if bookmark already exists
if (existingBookmark.isPresent()) { if (existingBookmark.isPresent()) {
throw new ResourceAlreadyExists("Bookmark already exists!"); 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) { // Save bookmark by updating booked to true
logger.error("Failed to create bookmark: {}", e.getMessage()); int updatedCount = scanHistoryRepository.updateBookmarkStatusToActive(userId, qrCodeId);
// throw exception if bookmark creation fails
if (updatedCount < 1)
throw new ResourceNotFoundExceptions("Unable to create bookmark. The QR code may not exist."); throw new ResourceNotFoundExceptions("Unable to create bookmark. The QR code may not exist.");
}
return BaseResponse.builder().message("Bookmark saved successfully").build(); return BaseResponse.builder().message("Bookmark saved successfully").build();
} }
@Transactional @Transactional
public BaseResponse deleteBookmark(String userId, UUID qrCodeId) { 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 // throw exception if bookmark not found
if (updatedCount < 1) if (updatedCount < 1)
throw new ResourceNotFoundExceptions("Bookmark not found"); throw new ResourceNotFoundExceptions("Bookmark not found");
@@ -117,7 +110,7 @@ public class UserService {
@Transactional @Transactional
public BaseResponse deleteAllBookmarkByUserId(String userId) { public BaseResponse deleteAllBookmarkByUserId(String userId) {
int updatedCount = scanBookmarkRepository.updateBookmarkStatusToInactiveByUserId(userId); int updatedCount = scanHistoryRepository.updateBookmarkStatusToInactiveByUserId(userId);
return (updatedCount < 1) ? return (updatedCount < 1) ?
BaseResponse.builder().message("No Bookmark not found").build(): BaseResponse.builder().message("No Bookmark not found").build():