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
Detailed patterns for integrating Clean Architecture with Spring Boot 3.5+.
// Application configuration
@Configuration
@ComponentScan(basePackages = "com.example.order")
@EnableJpaRepositories(basePackages = "com.example.order.infrastructure.persistence")
@EntityScan(basePackages = "com.example.order.infrastructure.persistence")
public class OrderConfiguration {
@Bean
public OrderService orderService(
OrderRepository orderRepository,
PaymentGateway paymentGateway,
DomainEventPublisher eventPublisher) {
return new OrderService(orderRepository, paymentGateway, eventPublisher);
}
}@Service
@RequiredArgsConstructor
public class OrderService implements CreateOrderUseCase {
private final OrderRepository orderRepository;
private final PaymentGateway paymentGateway;
private final DomainEventPublisher eventPublisher;
}// Port interface
public interface NotificationService {
void sendNotification(String to, String subject, String body);
}
// Primary adapter
@Component
@Primary
public class EmailNotificationService implements NotificationService {
private final JavaMailSender mailSender;
// Implementation
}
// Secondary adapter
@Component
@Qualifier("sms")
public class SmsNotificationService implements NotificationService {
private final SmsClient smsClient;
// Implementation
}
// Usage
@Service
@RequiredArgsConstructor
public class OrderConfirmationService {
private final NotificationService emailNotification; // @Primary injected
private final @Qualifier("sms") NotificationService smsNotification;
}@Component
@ConditionalOnProperty(name = "payment.provider", havingValue = "stripe")
public class StripePaymentAdapter implements PaymentGateway {
// Stripe implementation
}
@Component
@ConditionalOnProperty(name = "payment.provider", havingValue = "paypal")
public class PayPalPaymentAdapter implements PaymentGateway {
// PayPal implementation
}// Domain model (in domain package)
public class Order {
private final OrderId id;
private OrderStatus status;
private List<OrderItem> items;
// Pure business logic, no annotations
}
// JPA entity (in infrastructure package)
@Entity
@Table(name = "orders")
public class OrderJpaEntity {
@Id
private UUID id;
@Enumerated(EnumType.STRING)
private OrderStatus status;
@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true, fetch = FetchType.LAZY)
@JoinColumn(name = "order_id")
private List<OrderItemJpaEntity> items;
@Column(name = "created_at")
private Instant createdAt;
}@Mapper(componentModel = "spring")
public interface OrderJpaMapper {
OrderJpaEntity toEntity(Order order);
Order toDomain(OrderJpaEntity entity);
default UUID map(OrderId id) {
return id != null ? id.value() : null;
}
default OrderId map(UUID id) {
return id != null ? new OrderId(id) : null;
}
default String map(Money money) {
return money != null ? money.amount().toString() : null;
}
default Money map(String amount, String currency) {
return amount != null ? new Money(new BigDecimal(amount), Currency.getInstance(currency)) : null;
}
}@Service
@RequiredArgsConstructor
public class OrderService {
private final OrderRepository orderRepository;
private final InventoryService inventoryService;
private final PaymentGateway paymentGateway;
@Transactional
public Order createOrder(CreateOrderCommand command) {
// All operations within same transaction
Order order = Order.create(command.customerId(), command.items());
inventoryService.reserve(order.getItems()); // Will rollback if fails
PaymentResult payment = paymentGateway.charge(order.getTotal());
if (!payment.successful()) {
throw new PaymentFailedException();
}
return orderRepository.save(order);
}
@Transactional(readOnly = true)
public Optional<Order> findOrder(OrderId id) {
return orderRepository.findById(id);
}
}@Service
@RequiredArgsConstructor
@Transactional(readOnly = true)
public class OrderQueryService {
private final OrderJpaRepository orderJpaRepository;
private final OrderMapper mapper;
public Page<OrderSummary> findOrders(OrderSearchCriteria criteria, Pageable pageable) {
return orderJpaRepository.findByCriteria(criteria, pageable)
.map(mapper::toSummary);
}
}@Component
@RequiredArgsConstructor
public class SpringDomainEventPublisher implements DomainEventPublisher {
private final ApplicationEventPublisher publisher;
@Override
public void publish(DomainEvent event) {
publisher.publishEvent(event);
}
}
// Or with @TransactionalEventListener for after-commit
@Component
@RequiredArgsConstructor
public class OrderEventListener {
private final EmailService emailService;
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void handleOrderCreated(OrderCreatedEvent event) {
emailService.sendOrderConfirmation(event.orderId());
}
@EventListener
public void handleOrderCancelled(OrderCancelledEvent event) {
// Handle synchronously
}
}public record CreateOrderRequest(
@NotNull(message = "Customer ID is required")
UUID customerId,
@NotEmpty(message = "Order must have at least one item")
@Valid
List<@NotNull OrderItemRequest> items,
@Valid
ShippingAddressRequest shippingAddress
) {}
public record OrderItemRequest(
@NotNull
UUID productId,
@Min(value = 1, message = "Quantity must be at least 1")
@Max(value = 100, message = "Maximum quantity is 100")
int quantity
) {}@Target({ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = ValidOrderIdValidator.class)
public @interface ValidOrderId {
String message() default "Invalid order ID";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
@Component
public class ValidOrderIdValidator implements ConstraintValidator<ValidOrderId, String> {
@Override
public boolean isValid(String value, ConstraintValidatorContext context) {
if (value == null) return true;
try {
UUID.fromString(value);
return true;
} catch (IllegalArgumentException e) {
return false;
}
}
}@RestControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(DomainException.class)
public ResponseEntity<ErrorResponse> handleDomainException(DomainException ex) {
ErrorResponse error = new ErrorResponse(
ex.getCode(),
ex.getMessage(),
Instant.now()
);
return ResponseEntity.badRequest().body(error);
}
@ExceptionHandler(MethodArgumentNotValidException.class)
public ResponseEntity<ValidationErrorResponse> handleValidationErrors(
MethodArgumentNotValidException ex) {
List<FieldError> errors = ex.getBindingResult().getFieldErrors().stream()
.map(error -> new FieldError(
error.getField(),
error.getDefaultMessage()
))
.toList();
return ResponseEntity.badRequest()
.body(new ValidationErrorResponse(errors));
}
@ExceptionHandler(EntityNotFoundException.class)
public ResponseEntity<ErrorResponse> handleNotFound(EntityNotFoundException ex) {
return ResponseEntity.status(HttpStatus.NOT_FOUND)
.body(new ErrorResponse("NOT_FOUND", ex.getMessage(), Instant.now()));
}
}@DataJpaTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
@Testcontainers
class OrderRepositoryAdapterTest {
@Container
static PostgreSQLContainer<?> postgres = new PostgreSQLContainer<>("postgres:16");
@DynamicPropertySource
static void configureProperties(DynamicPropertyRegistry registry) {
registry.add("spring.datasource.url", postgres::getJdbcUrl);
registry.add("spring.datasource.username", postgres::getUsername);
registry.add("spring.datasource.password", postgres::getPassword);
}
@Autowired
private OrderJpaRepository jpaRepository;
@Autowired
private OrderJpaMapper mapper;
private OrderRepositoryAdapter adapter;
@BeforeEach
void setUp() {
adapter = new OrderRepositoryAdapter(jpaRepository, mapper);
}
@Test
void shouldSaveAndRetrieveOrder() {
Order order = Order.create(new CustomerId(UUID.randomUUID()), sampleItems());
Order saved = adapter.save(order);
Optional<Order> found = adapter.findById(saved.getId());
assertThat(found).isPresent();
assertThat(found.get().getId()).isEqualTo(saved.getId());
}
}@WebMvcTest(OrderController.class)
@Import({OrderMapperImpl.class, GlobalExceptionHandler.class})
class OrderControllerTest {
@Autowired
private MockMvc mockMvc;
@MockitoBean
private CreateOrderUseCase createOrderUseCase;
@MockitoBean
private GetOrderUseCase getOrderUseCase;
@Test
void shouldCreateOrder() throws Exception {
when(createOrderUseCase.createOrder(any()))
.thenReturn(new OrderResponse(UUID.randomUUID(), OrderStatus.PENDING));
mockMvc.perform(post("/api/orders")
.contentType(MediaType.APPLICATION_JSON)
.content("""
{
"customerId": "550e8400-e29b-41d4-a716-446655440000",
"items": [{"productId": "550e8400-e29b-41d4-a716-446655440001", "quantity": 2}]
}
"""))
.andExpect(status().isCreated())
.andExpect(jsonPath("$.status").value("PENDING"));
}
}@Tag(name = "Orders", description = "Order management endpoints")
@RestController
@RequestMapping("/api/orders")
@RequiredArgsConstructor
public class OrderController {
@Operation(summary = "Create new order")
@ApiResponses({
@ApiResponse(responseCode = "201", description = "Order created successfully"),
@ApiResponse(responseCode = "400", description = "Invalid request"),
@ApiResponse(responseCode = "422", description = "Business rule violation")
})
@PostMapping
public ResponseEntity<OrderResponse> createOrder(
@Valid @RequestBody @Parameter(description = "Order creation request") CreateOrderRequest request) {
// Implementation
}
}@Component
@Profile("!test")
public class SmtpEmailService implements EmailService {
// Real SMTP implementation
}
@Component
@Profile("test")
public class InMemoryEmailService implements EmailService {
private final List<EmailMessage> sentEmails = new ArrayList<>();
@Override
public void send(String to, String subject, String body) {
sentEmails.add(new EmailMessage(to, subject, body));
}
public List<EmailMessage> getSentEmails() {
return List.copyOf(sentEmails);
}
}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