Comprehensive developer toolkit providing reusable skills for Java/Spring Boot, TypeScript/NestJS/React/Next.js, Python, PHP, AWS CloudFormation, AI/RAG, DevOps, and more.
90
90%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Risky
Do not use without reviewing
import org.springdoc.core.annotations.ParameterObject;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
@Operation(summary = "Get paginated list of books")
@GetMapping("/paginated")
public Page<Book> findAllPaginated(
@ParameterObject Pageable pageable
) {
return repository.findAll(pageable);
}This generates parameters:
page: Page number (0-based)size: Page sizesort: Sort criteria (field,direction)@Operation(summary = "Get paginated books with custom defaults")
@GetMapping("/paginated")
public Page<Book> getBooksPaginated(
@ParameterObject
@Parameter(
description = "Pagination parameters (default: page=0, size=20, sort=id,asc)",
example = "page=0&size=20&sort=title,asc"
)
Pageable pageable
) {
return repository.findAll(pageable);
}@ParameterObject@GetMapping("/search")
public Page<Book> searchBooks(
@Parameter(description = "Search query")
@RequestParam String query,
@ParameterObject
Pageable pageable
) {
return repository.searchByTitle(query, pageable);
}import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageImpl;
import org.springframework.data.domain.PageRequest;
@Schema(description = "Paginated response wrapper")
public record PagedResponse<T>(
@Schema(description = "List of items")
List<T> content,
@Schema(description = "Current page number (0-based)", example = "0")
int currentPage,
@Schema(description = "Total number of pages", example = "5")
int totalPages,
@Schema(description = "Total number of items", example = "100")
long totalItems,
@Schema(description = "Number of items per page", example = "20")
int pageSize,
@Schema(description = "Whether this is the first page", example = "true")
boolean isFirst,
@Schema(description = "Whether this is the last page", example = "false")
boolean isLast
) {
public static <T> PagedResponse<T> from(Page<T> page) {
return new PagedResponse<>(
page.getContent(),
page.getNumber(),
page.getTotalPages(),
page.getTotalElements(),
page.getSize(),
page.isFirst(),
page.isLast()
);
}
}
@Operation(summary = "Get books with custom pagination")
@GetMapping("/paged")
public PagedResponse<Book> getPagedBooks(
@ParameterObject Pageable pageable
) {
Page<Book> page = repository.findAll(pageable);
return PagedResponse.from(page);
}import org.springframework.data.domain.Slice;
@Operation(summary = "Get books as slice (no count query)")
@GetMapping("/sliced")
public Slice<Book> getBookSlice(
@Parameter(description = "Page number (0-based)", example = "0")
@RequestParam(defaultValue = "0") int page,
@Parameter(description = "Page size", example = "20")
@RequestParam(defaultValue = "20") int size
) {
return repository.findAll(PageRequest.of(page, size));
}@Schema(description = "Pagination request")
public record PaginationRequest(
@Schema(description = "Page number (0-based)", example = "0", minValue = "0")
@Min(0)
int page,
@Schema(description = "Page size", example = "20", minValue = "1", maxValue = "100")
@Min(1)
@Max(100)
int size,
@Schema(description = "Sort field", example = "title")
String sortField,
@Schema(description = "Sort direction", example = "asc", allowableValues = {"asc", "desc"})
String sortDirection
) {
public Pageable toPageable() {
Sort.Direction direction = Sort.Direction.fromString(sortDirection);
return PageRequest.of(page, size, Sort.by(direction, sortField));
}
}
@Operation(summary = "Get books with custom pagination")
@PostMapping("/paginated-custom")
public Page<Book> getBooksCustomPagination(
@RequestBody PaginationRequest request
) {
return repository.findAll(request.toPageable());
}@Operation(summary = "Search books with pagination and filters")
@GetMapping("/search")
public Page<Book> searchBooks(
@Parameter(description = "Title filter")
@RequestParam(required = false) String title,
@Parameter(description = "Author filter")
@RequestParam(required = false) String author,
@Parameter(description = "Minimum price")
@RequestParam(required = false) BigDecimal minPrice,
@Parameter(description = "Maximum price")
@RequestParam(required = false) BigDecimal maxPrice,
@ParameterObject
Pageable pageable
) {
return repository.searchBooks(title, author, minPrice, maxPrice, pageable);
}@Operation(
summary = "Get paginated books",
description = """
Returns paginated list of books.
**Parameters:**
- `page`: Page number (0-based, default: 0)
- `size`: Items per page (1-100, default: 20)
- `sort`: Sort field and direction (e.g., `title,asc` or `price,desc`)
**Sortable fields:** id, title, author, price, publicationDate
"""
)
@GetMapping("/paginated")
public Page<Book> getPaginatedBooks(
@ParameterObject
@Parameter(description = "Pagination and sorting parameters")
Pageable pageable
) {
return repository.findAll(pageable);
}docs
plugins
developer-kit-ai
developer-kit-aws
agents
docs
skills
aws
aws-cli-beast
aws-cost-optimization
aws-drawio-architecture-diagrams
aws-sam-bootstrap
aws-cloudformation
aws-cloudformation-auto-scaling
aws-cloudformation-bedrock
aws-cloudformation-cloudfront
aws-cloudformation-cloudwatch
aws-cloudformation-dynamodb
aws-cloudformation-ec2
aws-cloudformation-ecs
aws-cloudformation-elasticache
references
aws-cloudformation-iam
references
aws-cloudformation-lambda
aws-cloudformation-rds
aws-cloudformation-s3
aws-cloudformation-security
aws-cloudformation-task-ecs-deploy-gh
aws-cloudformation-vpc
references
developer-kit-core
agents
commands
skills
developer-kit-devops
developer-kit-java
agents
commands
docs
skills
aws-lambda-java-integration
aws-rds-spring-boot-integration
aws-sdk-java-v2-bedrock
aws-sdk-java-v2-core
aws-sdk-java-v2-dynamodb
aws-sdk-java-v2-kms
aws-sdk-java-v2-lambda
aws-sdk-java-v2-messaging
aws-sdk-java-v2-rds
aws-sdk-java-v2-s3
aws-sdk-java-v2-secrets-manager
clean-architecture
graalvm-native-image
langchain4j-ai-services-patterns
references
langchain4j-mcp-server-patterns
references
langchain4j-rag-implementation-patterns
references
langchain4j-spring-boot-integration
langchain4j-testing-strategies
langchain4j-tool-function-calling-patterns
langchain4j-vector-stores-configuration
references
qdrant
references
spring-ai-mcp-server-patterns
spring-boot-actuator
spring-boot-cache
spring-boot-crud-patterns
spring-boot-dependency-injection
spring-boot-event-driven-patterns
spring-boot-openapi-documentation
spring-boot-project-creator
spring-boot-resilience4j
spring-boot-rest-api-standards
spring-boot-saga-pattern
spring-boot-security-jwt
assets
references
scripts
spring-boot-test-patterns
spring-data-jpa
references
spring-data-neo4j
references
unit-test-application-events
unit-test-bean-validation
unit-test-boundary-conditions
unit-test-caching
unit-test-config-properties
references
unit-test-controller-layer
unit-test-exception-handler
references
unit-test-json-serialization
unit-test-mapper-converter
references
unit-test-parameterized
unit-test-scheduled-async
references
unit-test-service-layer
references
unit-test-utility-methods
unit-test-wiremock-rest-api
references
developer-kit-php
developer-kit-project-management
developer-kit-python
developer-kit-specs
commands
docs
hooks
test-templates
tests
skills
developer-kit-tools
developer-kit-typescript
agents
docs
hooks
rules
skills
aws-cdk
aws-lambda-typescript-integration
better-auth
clean-architecture
drizzle-orm-patterns
dynamodb-toolbox-patterns
references
nestjs
nestjs-best-practices
nestjs-code-review
nestjs-drizzle-crud-generator
nextjs-app-router
nextjs-authentication
nextjs-code-review
nextjs-data-fetching
nextjs-deployment
nextjs-performance
nx-monorepo
react-code-review
react-patterns
shadcn-ui
tailwind-css-patterns
tailwind-design-system
references
turborepo-monorepo
typescript-docs
typescript-security-review
zod-validation-utilities
references
github-spec-kit