Springboot-skills-marketplace code-reviewer
Reviews Java 25 and Spring Boot 4 codebases, pull requests, files, and modules for migration risks, architecture boundary violations, JSpecify null-safety issues, security flaws, performance regressions, and Spring Data pitfalls. Use when the task is a concrete Java or Spring code review with code context. Do not use for Kotlin-only code, non-Spring frameworks, or generic review advice without files or diffs.
git clone https://github.com/a-pavithraa/springboot-skills-marketplace
T=$(mktemp -d) && git clone --depth=1 https://github.com/a-pavithraa/springboot-skills-marketplace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/springboot-architecture/skills/code-reviewer" ~/.claude/skills/a-pavithraa-springboot-skills-marketplace-code-reviewer && rm -rf "$T"
plugins/springboot-architecture/skills/code-reviewer/SKILL.mdJava 25 and Spring Boot 4 Reviewer
Purpose
Use this skill to run a structured review of Java 25 and Spring Boot 4 code. Keep findings grounded in the actual codebase and use the reference files only for the focus areas that apply.
Critical rules
- Never review without code context. Ask for files, diffs, or the relevant module if none is provided.
- Always cite file paths and line numbers for findings.
- Treat Java 25 and Spring Boot 4 as the target baseline unless the build files show otherwise.
- Analyze workload before recommending virtual threads, reactive rewrites, or architecture changes.
- Use JSpecify as the preferred null-safety baseline for new Boot 4 code, but confirm whether the codebase is still in transition before flagging every legacy annotation.
- Prefer official Spring and Java guidance when a claim depends on framework behavior.
Workflow
Step 1: Confirm scope
Collect the minimum context required to review accurately:
- Scope: single file, module, PR, or full codebase.
- Target versions: confirm Java and Spring Boot versions from the build files when relevant.
- Focus areas: migration, architecture, data access, security, performance, null-safety, or all.
- Testing context: whether the user expects review findings only or also fix suggestions and test impact.
Step 2: Load only the references that match the review
Load references just in time:
| Focus | Read |
|---|---|
| Spring Boot 4 migration patterns and framework deltas | |
| Java 25 language and concurrency adoption | |
| Security review | |
| Performance review | |
| Architecture boundaries and packaging | |
| Domain model shape | |
| Value-object-heavy designs | |
| Null-safety checks | |
Escalate to another skill when needed:
- Use
for deep repository, query, and relationship work.spring-data-jpa - Use
for phased upgrade planning or upgrade execution.springboot-migration
Step 3: Run the review passes
Run only the passes that match the request. For a full review, use this order.
Pass A: Build and configuration
- Verify Java and Spring Boot versions in
orpom.xml
.build.gradle - Check starter names and migration leftovers.
- Scan for Jackson 3 migration issues, outdated test annotations, and version drift.
Pass B: API correctness
- Check controller and service boundaries.
- Check validation and error handling.
- Check nullability in public APIs and method overrides.
Pass C: Architecture and packaging
- Identify the architecture style in use.
- Verify package structure is consistent with that style.
- Flag boundary leaks such as controller-to-repository shortcuts or infrastructure types in domain code.
Pass D: Data access
- Check repository placement and aggregate boundaries.
- Check for N+1 queries, missing pagination, projection mismatches, and transaction misuse.
Pass E: Security
- Check authentication and authorization.
- Check input validation and unsafe query patterns.
- Check secrets handling and sensitive logging.
Pass F: Performance and resilience
- Check caching strategy, unbounded reads, async usage, and remote call behavior.
- Evaluate virtual-thread usage only when the code and workload justify it.
- Check timeouts, retries, and connection-pool assumptions.
Quick triggers for findings
Use these as review prompts, not as a substitute for code evidence.
Spring Boot 4 and migration
- old starter names
- old Mockito test annotations
- Jackson 2 assumptions in a Boot 4 codebase
usage instead ofTestRestTemplateRestTestClient- manual
boilerplate instead ofHttpServiceProxyFactory@ImportHttpServices - custom API versioning instead of native
spring.mvc.apiversion.*
or native@ConcurrencyLimit
without@Retryable@EnableResilientMethods
Null-safety
- missing
where the project uses JSpecifypackage-info.java - lingering
annotations in code that has already moved to JSpecifyorg.springframework.lang - missing copied nullability annotations on overrides
Architecture
- controllers calling repositories directly
- JPA entities exposed in APIs
- modulith boundary leaks
- business logic concentrated in controllers
Performance
- entity traversal in loops
- missing pagination
- projection opportunities ignored on read-heavy paths
- virtual-thread recommendations with no workload evidence
Security
- missing authorization on privileged actions
- SQL or NoSQL injection risk
- secrets in source or logs
- unsafe error exposure
Report format
Order findings by severity and use this template:
## Critical - **[Category]**: Issue summary - **File**: `path/to/File.java:123` - **Impact**: What can fail, leak, or regress - **Fix**: Specific change to make ## High - ... ## Medium - ... ## Low - ...
If there are no findings, say so explicitly and call out any remaining blind spots such as unreviewed modules, missing tests, or unavailable runtime context.
Common review modes
Quick PR review
- Read the changed files.
- Load
andreferences/spring-boot-4-patterns.md
.references/java-25-features.md - Add
orreferences/security-checklist.md
if the diff touches those areas.references/performance-patterns.md - Report only concrete findings with file and line references.
Security review
- Read
.references/security-checklist.md - Focus on controllers, service entry points, security configuration, and persistence boundaries.
- Report exploitability and affected entry points, not just the violated rule.
Architecture review
- Read
.references/architecture-patterns.md - Add
orreferences/domain-modeling.md
if the code suggests a rich-domain approach.references/value-objects-patterns.md - Report boundary mismatches and coupling problems tied to the current architecture style.
Migration review
- Read
andreferences/spring-boot-4-patterns.md
.references/java-25-features.md - Focus on migration leftovers, outdated APIs, and partial adoption problems.
- Use
if the user wants a phased upgrade plan rather than a review.springboot-migration
When not to use this skill
- Kotlin-first codebases
- Non-Spring Java frameworks such as Micronaut or Quarkus
- Generic review coaching without code context
- Frontend-only changes