-
Notifications
You must be signed in to change notification settings - Fork 51
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #82 from Guhapriya01/feature/secure-member-and-pas…
…sword-update Enhance Member Management with Secure Updates and Password Management
- Loading branch information
Showing
9 changed files
with
277 additions
and
46 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
50 changes: 50 additions & 0 deletions
50
src/main/java/com/libraryman_api/exception/InvalidPasswordException.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
package com.libraryman_api.exception; | ||
|
||
import java.io.Serial; | ||
|
||
/** | ||
* Custom exception class to handle scenarios where an invalid password is provided | ||
* in the Library Management System. This exception is thrown when a password update | ||
* operation fails due to invalid password criteria. | ||
*/ | ||
public class InvalidPasswordException extends RuntimeException { | ||
|
||
/** | ||
* The {@code serialVersionUID} is a unique identifier for each version of a serializable class. | ||
* It is used during the deserialization process to verify that the sender and receiver of a | ||
* serialized object have loaded classes for that object that are compatible with each other. | ||
* | ||
* The {@code serialVersionUID} field is important for ensuring that a serialized class | ||
* (especially when transmitted over a network or saved to disk) can be successfully deserialized, | ||
* even if the class definition changes in later versions. If the {@code serialVersionUID} does not | ||
* match during deserialization, an {@code InvalidClassException} is thrown. | ||
* | ||
* This field is optional, but it is good practice to explicitly declare it to prevent | ||
* automatic generation, which could lead to compatibility issues when the class structure changes. | ||
* | ||
* The {@code @Serial} annotation is used here to indicate that this field is related to | ||
* serialization. This annotation is available starting from Java 14 and helps improve clarity | ||
* regarding the purpose of this field. | ||
*/ | ||
@Serial | ||
private static final long serialVersionUID = 1L; | ||
|
||
/** | ||
* Constructs a new {@code InvalidPasswordException} with the specified detail message. | ||
* | ||
* @param message the detail message explaining the reason for the exception | ||
*/ | ||
public InvalidPasswordException(String message) { | ||
super(message); | ||
} | ||
|
||
/** | ||
* Constructs a new {@code InvalidPasswordException} with the specified detail message and cause. | ||
* | ||
* @param message the detail message explaining the reason for the exception | ||
* @param cause the cause of the exception (which is saved for later retrieval by the {@link #getCause()} method) | ||
*/ | ||
public InvalidPasswordException(String message, Throwable cause) { | ||
super(message, cause); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
4 changes: 3 additions & 1 deletion
4
...com/libraryman_api/member/MembersDto.java → ...libraryman_api/member/dto/MembersDto.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
52 changes: 52 additions & 0 deletions
52
src/main/java/com/libraryman_api/member/dto/UpdateMembersDto.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
package com.libraryman_api.member.dto; | ||
|
||
public class UpdateMembersDto { | ||
|
||
private String name; | ||
|
||
private String username; | ||
|
||
private String email; | ||
|
||
public UpdateMembersDto(String name, String username, String email) { | ||
this.name = name; | ||
this.username = username; | ||
this.email = email; | ||
} | ||
|
||
public UpdateMembersDto() { | ||
} | ||
|
||
public String getName() { | ||
return name; | ||
} | ||
|
||
public String getUsername() { | ||
return username; | ||
} | ||
|
||
public void setName(String name) { | ||
this.name = name; | ||
} | ||
|
||
public void setUsername(String username) { | ||
this.username = username; | ||
} | ||
|
||
public String getEmail() { | ||
return email; | ||
} | ||
|
||
public void setEmail(String email) { | ||
this.email = email; | ||
} | ||
|
||
@Override | ||
public String toString() { | ||
return "UpdateMembersDto{" + | ||
"name='" + name + '\'' + | ||
", username='" + username + '\'' + | ||
", email='" + email + '\'' + | ||
'}'; | ||
} | ||
} |
Oops, something went wrong.