From d1b016b66f7f978d0254278c3526ca9f63fbe474 Mon Sep 17 00:00:00 2001 From: Shreya Date: Wed, 2 Oct 2024 03:06:25 +0530 Subject: [PATCH] Fixed a bug for null values while borrowing a book --- pom.xml | 9 +++-- .../LibrarymanApiApplication.java | 2 ++ .../borrowing/BorrowingService.java | 18 +++++++--- .../application-development.properties | 33 +++++++++++++------ .../application-production.properties | 2 +- src/main/resources/application.properties | 2 +- 6 files changed, 47 insertions(+), 19 deletions(-) diff --git a/pom.xml b/pom.xml index 95e4f3f..8e2fe06 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ org.springframework.boot spring-boot-starter-parent - 3.3.3 + 3.3.2 com @@ -27,7 +27,7 @@ - 17 + 21 @@ -57,7 +57,10 @@ mysql-connector-j runtime - + + org.apache.tomcat.embed + tomcat-embed-jasper + org.springframework.boot diff --git a/src/main/java/com/libraryman_api/LibrarymanApiApplication.java b/src/main/java/com/libraryman_api/LibrarymanApiApplication.java index df9a8cf..e95b811 100644 --- a/src/main/java/com/libraryman_api/LibrarymanApiApplication.java +++ b/src/main/java/com/libraryman_api/LibrarymanApiApplication.java @@ -2,9 +2,11 @@ import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.context.annotation.ComponentScan; import org.springframework.scheduling.annotation.EnableAsync; @SpringBootApplication +@ComponentScan(basePackages = {"com.libraryman_api"}) @EnableAsync public class LibrarymanApiApplication { diff --git a/src/main/java/com/libraryman_api/borrowing/BorrowingService.java b/src/main/java/com/libraryman_api/borrowing/BorrowingService.java index 668d0cc..c5e427c 100644 --- a/src/main/java/com/libraryman_api/borrowing/BorrowingService.java +++ b/src/main/java/com/libraryman_api/borrowing/BorrowingService.java @@ -5,6 +5,8 @@ import com.libraryman_api.fine.Fines; import com.libraryman_api.exception.ResourceNotFoundException; import com.libraryman_api.fine.FineRepository; +import com.libraryman_api.member.MemberService; +import com.libraryman_api.member.Members; import com.libraryman_api.notification.NotificationService; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -39,6 +41,7 @@ public class BorrowingService { private final FineRepository fineRepository; private final NotificationService notificationService; private final BookService bookService; + private final MemberService memberService; /** * Constructs a new {@code BorrowingService} with the specified repositories and services. @@ -48,11 +51,12 @@ public class BorrowingService { * @param notificationService the service for sending notifications * @param bookService the service for managing book records */ - public BorrowingService(BorrowingRepository borrowingRepository, FineRepository fineRepository, NotificationService notificationService, BookService bookService) { + public BorrowingService(BorrowingRepository borrowingRepository, FineRepository fineRepository, NotificationService notificationService, BookService bookService, MemberService memberService) { this.borrowingRepository = borrowingRepository; this.fineRepository = fineRepository; this.notificationService = notificationService; this.bookService = bookService; + this.memberService=memberService; } /** @@ -89,13 +93,16 @@ public Optional getBorrowingById(int borrowingId) { @Transactional public synchronized Borrowings borrowBook(Borrowings borrowing) { Optional book = bookService.getBookById(borrowing.getBook().getBookId()); - - if (book.isPresent()) { + Optional member = memberService.getMemberById(borrowing.getMember().getMemberId()); + if (book.isPresent() && member.isPresent()) { Book bookEntity = book.get(); + Members memberEntity = member.get(); if (bookEntity.getCopiesAvailable() > 0) { updateBookCopies(borrowing.getBook().getBookId(), "REMOVE", 1); borrowing.setBorrowDate(new Date()); + borrowing.setBook(bookEntity); + borrowing.setMember(memberEntity); borrowing.setDueDate(calculateDueDate()); Borrowings savedBorrowing = borrowingRepository.save(borrowing); @@ -107,7 +114,10 @@ public synchronized Borrowings borrowBook(Borrowings borrowing) { throw new ResourceNotFoundException("Not enough copies available"); } } else { - throw new ResourceNotFoundException("Book not found"); + if (book.isEmpty()) { + throw new ResourceNotFoundException("Book not found"); + } + throw new ResourceNotFoundException("Member not found"); } } diff --git a/src/main/resources/application-development.properties b/src/main/resources/application-development.properties index e16234d..c7763d4 100644 --- a/src/main/resources/application-development.properties +++ b/src/main/resources/application-development.properties @@ -1,23 +1,36 @@ ## Database Setup First -## Create a Database and add database name where "Add_Your_Database_Name" is below -## Make this file as it was earlier before commiting code - -# Change this connection string to this format: jdbc:mysql://{ip_address}:{port}/{database_name} -spring.datasource.url=jdbc:mysql://localhost:3306/Add_Your_Database_Name +# MySQL Database Connection +spring.datasource.url=jdbc:mysql://localhost:3306/library +spring.datasource.username=root +spring.datasource.password= +spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver -## Add your Database Username and Password -spring.datasource.username= Add_Your_UserName -spring.datasource.password= Add_Your_Password +# Hibernate Dialect for MySQL 8 +spring.jpa.database-platform=org.hibernate.dialect.MySQLDialect -spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver +# Prevent early database interaction +spring.jpa.properties.hibernate.boot.allow_jdbc_metadata_access=false spring.jpa.hibernate.ddl-auto=update +spring.sql.init.mode=never + +# Format SQL spring.jpa.properties.hibernate.format_sql=true +# Logging for Spring Security +logging.level.org.springframework.security=TRACE +# Error Handling server.error.include-binding-errors=always server.error.include-message=always server.error.include-stacktrace=never server.error.include-exception=true -logging.level.org.springframework.security = TRACE \ No newline at end of file +spring.mail.host=smtp.gmail.com +spring.mail.port=587 +spring.mail.username= +spring.mail.password= +spring.mail.properties.mail.smtp.auth=true +spring.mail.properties.mail.smtp.starttls.enable=true +spring.mail.properties.domain_name=gmail.com + diff --git a/src/main/resources/application-production.properties b/src/main/resources/application-production.properties index 6b8edc4..4d50b9f 100644 --- a/src/main/resources/application-production.properties +++ b/src/main/resources/application-production.properties @@ -14,4 +14,4 @@ spring.mail.username=${MAIL_SERVICE_USERNAME} spring.mail.password=${MAIL_SERVICE_PASSWORD} spring.mail.properties.mail.smtp.auth=${MAIL_SERVICE_SMTP} spring.mail.properties.mail.starttls.enable=${MAIL_SERVICE_STARTTLS} -spring.mail.properties.domain_name=${MAIL_SERVICE_DOMAIN_NAME} \ No newline at end of file +spring.mail.properties.domain_name=${MAIL_SERVICE_DOMAIN_NAME} diff --git a/src/main/resources/application.properties b/src/main/resources/application.properties index eeefb5c..53718a7 100644 --- a/src/main/resources/application.properties +++ b/src/main/resources/application.properties @@ -1,2 +1,2 @@ spring.application.name=libraryman-api -spring.profiles.active=${ENV:dev} \ No newline at end of file +spring.profiles.active=${ENV:development} \ No newline at end of file