Discover how to stop repeating security checks and make your app safer with one smart tool!
Why Custom permission evaluator in Spring Boot? - Purpose & Use Cases
Start learning this pattern below
Jump into concepts and practice - no test required
Imagine you have a web app where users can edit posts, but only if they are the author or an admin. You try to check permissions everywhere in your code manually.
Manually checking permissions in every controller or service is repetitive, easy to forget, and leads to inconsistent security. It's hard to maintain and debug.
A custom permission evaluator centralizes your permission logic. Spring Security calls it automatically to decide if a user can access a resource, keeping your code clean and secure.
if(user.isAdmin() || post.authorId == user.id) { allowAccess(); } else { denyAccess(); }
@PreAuthorize("hasPermission(#post, 'edit')") public void editPost(Post post) { ... }It enables flexible, reusable, and centralized permission checks that adapt easily as your app grows.
In a team project app, only project owners or managers can update project details. A custom permission evaluator cleanly enforces this everywhere without repeating code.
Manual permission checks are repetitive and error-prone.
Custom permission evaluators centralize and automate security decisions.
This leads to cleaner, safer, and easier-to-maintain code.
Practice
Custom PermissionEvaluator in Spring Boot security?Solution
Step 1: Understand the role of PermissionEvaluator
The PermissionEvaluator interface allows defining custom logic to check if a user has permission to perform an action.Step 2: Identify the purpose of custom implementation
Implementing a custom PermissionEvaluator lets you write your own rules that can be reused across your application for security checks.Final Answer:
To define custom rules for checking user permissions in a reusable way -> Option CQuick Check:
Custom PermissionEvaluator = Custom reusable permission rules [OK]
- Thinking it replaces Spring Security entirely
- Confusing it with session management
- Assuming it manages database connections
PermissionEvaluator to check permissions based on a target domain object?Solution
Step 1: Recall PermissionEvaluator interface methods
PermissionEvaluator has two methods: one with targetDomainObject and one with targetId and targetType.Step 2: Identify the method for domain object permission check
The methodhasPermission(Authentication authentication, Object targetDomainObject, Object permission)is used to check permissions on a domain object.Final Answer:
hasPermission(Authentication authentication, Object targetDomainObject, Object permission) -> Option BQuick Check:
Domain object permission method = hasPermission with targetDomainObject [OK]
- Choosing methods not in PermissionEvaluator interface
- Confusing method parameters
- Using method names that don't exist
public boolean hasPermission(Authentication auth, Object target, Object perm) {
if (auth == null || target == null || !(perm instanceof String)) {
return false;
}
String permission = (String) perm;
User user = (User) auth.getPrincipal();
return user.getRoles().contains(permission);
}What will be the result if
auth is null?Solution
Step 1: Analyze the null check at method start
The method checks ifauthis null and returns false immediately if so.Step 2: Understand the flow when auth is null
Sinceauth == nulltriggers return false, no further code runs and no exception occurs.Final Answer:
Returns false immediately -> Option AQuick Check:
Null auth returns false immediately [OK]
- Assuming NullPointerException will be thrown
- Thinking it returns true by default
- Ignoring the null check logic
public boolean hasPermission(Authentication auth, Object target, Object perm) {
String permission = (String) perm;
User user = (User) auth.getPrincipal();
return user.getRoles().contains(permission);
}What is the main problem with this code?
Solution
Step 1: Check for missing null validations
The method does not check ifauth,perm, orauth.getPrincipal()are null before casting or calling methods.Step 2: Understand consequences of missing null checks
If any are null, the code will throw NullPointerException at runtime.Final Answer:
It lacks null checks and may throw NullPointerException -> Option DQuick Check:
Missing null checks cause runtime exceptions [OK]
- Ignoring null safety
- Thinking casting is always safe
- Assuming roles check is invalid
Which code snippet correctly implements this logic inside
hasPermission?Solution
Step 1: Check for null authentication and target
Security checks should return false if authentication or target is null to avoid errors.Step 2: Verify user role and document status conditions
The user must have "EDITOR" role and the document status must be exactly "DRAFT" for permission to be granted.Step 3: Confirm correct logical operator usage
Both conditions must be true, so use logical AND (&&), not OR (||).Final Answer:
if (auth == null || target == null) return false; User user = (User) auth.getPrincipal(); Document doc = (Document) target; return user.getRoles().contains("EDITOR") && "DRAFT".equals(doc.getStatus()); -> Option AQuick Check:
Check nulls + role AND status = correct logic [OK]
- Using || instead of && for both conditions
- Not checking for null auth or target
- Comparing strings with == instead of equals()
