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.springframework.context.event.EventListener;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
import org.springframework.transaction.event.TransactionPhase;
import org.springframework.transaction.event.TransactionalEventListener;
import lombok.RequiredArgsConstructor;
@Component
@RequiredArgsConstructor
public class ProductEventHandler {
private final NotificationService notificationService;
private final AuditService auditService;
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void onProductCreated(ProductCreatedEvent event) {
auditService.logProductCreation(
event.getProductId().getValue(),
event.getName(),
event.getPrice(),
event.getCorrelationId()
);
notificationService.sendProductCreatedNotification(event.getName());
}
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void onProductStockDecreased(ProductStockDecreasedEvent event) {
notificationService.sendStockUpdateNotification(
event.getProductId().getValue(),
event.getQuantity()
);
}
@TransactionalEventListener(phase = TransactionPhase.AFTER_ROLLBACK)
public void onTransactionRollback(DomainEvent event) {
log.error("Transaction rolled back for event: {}", event.getEventId());
}
}@Component
@RequiredArgsConstructor
public class AsyncEventHandler {
private final EmailService emailService;
@Async
@EventListener
public void handleOrderCreatedEvent(OrderCreatedEvent event) {
// Executes asynchronously in a separate thread
emailService.sendOrderConfirmationEmail(
event.getCustomerId().getValue(),
event.getOrderId().getValue()
);
}
}import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Component;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@Component
@RequiredArgsConstructor
@Slf4j
public class ProductEventConsumer {
private final OrderService orderService;
@KafkaListener(
topics = "product-events",
groupId = "order-service",
properties = {
"spring.json.value.default.type=com.example.events.ProductCreatedEventDto"
}
)
public void handleProductCreated(ProductCreatedEventDto event) {
log.info("Received ProductCreatedEvent: {}", event.getProductId());
try {
orderService.onProductCreated(event);
} catch (Exception e) {
log.error("Failed to handle ProductCreatedEvent", e);
throw e; // Re-throw to trigger retry
}
}
@KafkaListener(
topics = "product-events",
groupId = "order-service",
properties = {
"spring.json.value.default.type=com.example.events.ProductStockDecreasedEventDto"
}
)
public void handleProductStockDecreased(ProductStockDecreasedEventDto event) {
log.info("Received ProductStockDecreasedEvent: {}", event.getProductId());
orderService.onProductStockDecreased(event);
}
}import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.kafka.support.Acknowledgment;
import org.springframework.kafka.support.KafkaHeaders;
import org.springframework.messaging.handler.annotation.Header;
import org.springframework.messaging.handler.annotation.Payload;
@Component
@Slf4j
public class ManualAckConsumer {
@KafkaListener(
topics = "product-events",
groupId = "order-service",
containerFactory = "kafkaListenerContainerFactory"
)
public void handleWithManualAck(
@Payload ProductCreatedEventDto event,
@Header(KafkaHeaders.ACKNOWLEDGMENT) Acknowledgment acknowledgment
) {
try {
// Process event
orderService.onProductCreated(event);
// Manually acknowledge
acknowledgment.acknowledge();
} catch (Exception e) {
log.error("Failed to process event", e);
// Don't acknowledge - message will be redelivered
}
}
}import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.kafka.annotation.RetryableTopic;
import org.springframework.retry.annotation.Backoff;
@Component
@Slf4j
public class ResilientEventConsumer {
@RetryableTopic(
attempts = "3",
backoff = @Backoff(delay = 1000, multiplier = 2),
autoCreateTopics = "false",
topicSuffixingStrategy = TopicSuffixingStrategy.SUFFIX_WITH_INDEX_VALUE
)
@KafkaListener(
topics = "product-events",
groupId = "order-service"
)
public void handleProductEvent(ProductCreatedEventDto event) {
log.info("Processing product event: {}", event.getProductId());
// Process event
orderService.onProductCreated(event);
}
@KafkaListener(
topics = "product-events-dlt",
groupId = "order-service-dlt"
)
public void handleDeadLetterEvent(ProductCreatedEventDto event) {
log.error("Event moved to DLT: {}", event.getProductId());
// Log to monitoring system
monitoringService.alertDeadLetterEvent(event);
// Store for manual inspection
deadLetterRepository.save(event);
}
}import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import java.util.function.Consumer;
@Component
@RequiredArgsConstructor
public class ProductEventStreamConsumer {
private final OrderService orderService;
@Bean
public Consumer<ProductCreatedEventDto> productCreated() {
return event -> {
log.info("Received ProductCreatedEvent: {}", event.getProductId());
orderService.onProductCreated(event);
};
}
@Bean
public Consumer<ProductStockDecreasedEventDto> productStockDecreased() {
return event -> {
log.info("Received ProductStockDecreasedEvent: {}", event.getProductId());
orderService.onProductStockDecreased(event);
};
}
}import org.springframework.context.annotation.Bean;
import org.springframework.messaging.Message;
import org.springframework.messaging.support.MessageBuilder;
import org.springframework.stereotype.Component;
@Component
public class ErrorHandlingConsumer {
@Bean
public Consumer<Message<ProductCreatedEventDto>> productCreatedWithRetry() {
return message -> {
try {
ProductCreatedEventDto event = message.getPayload();
orderService.onProductCreated(event);
} catch (Exception e) {
log.error("Failed to process event", e);
// Send to dead letter topic
throw new RuntimeException("Failed to process event", e);
}
};
}
}@Component
@RequiredArgsConstructor
public class IdempotentEventHandler {
private final ProcessedEventRepository processedEventRepository;
public void handleProductCreated(ProductCreatedEventDto event) {
// Check if event was already processed
if (processedEventRepository.existsByEventId(event.getEventId())) {
log.info("Event already processed: {}", event.getEventId());
return;
}
// Process event
orderService.onProductCreated(event);
// Mark as processed
processedEventRepository.save(new ProcessedEvent(event.getEventId()));
}
}@Component
public class ValidatingEventHandler {
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void handleOrderCreated(OrderCreatedEvent event) {
// Validate event
if (event.getItems().isEmpty()) {
throw new InvalidEventException("Order items cannot be empty");
}
if (event.getTotalAmount().compareTo(BigDecimal.ZERO) <= 0) {
throw new InvalidEventException("Total amount must be positive");
}
// Process valid event
inventoryService.reserveItems(event.getItems());
paymentService.charge(event.getTotalAmount());
}
}import io.github.resilience4j.circuitbreaker.annotation.CircuitBreaker;
@Component
@RequiredArgsConstructor
public class ResilientEventHandler {
private final ExternalServiceClient externalServiceClient;
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
@CircuitBreaker(
name = "externalService",
fallbackMethod = "handleExternalServiceFailure"
)
public void handleOrderCreated(OrderCreatedEvent event) {
externalServiceClient.notifyOrderCreated(event);
}
private void handleExternalServiceFailure(OrderCreatedEvent event, Exception ex) {
log.error("External service unavailable for event: {}", event.getOrderId(), ex);
// Store event for later retry
outboxRepository.save(OutboxEvent.from(event));
}
}import org.springframework.transaction.annotation.Transactional;
import java.util.concurrent.TimeUnit;
@Component
public class TimeoutEventHandler {
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void handleOrderCreated(OrderCreatedEvent event) {
ExecutorService executor = Executors.newSingleThreadExecutor();
try {
Future<?> future = executor.submit(() -> {
notificationService.sendOrderConfirmation(event);
});
future.get(5, TimeUnit.SECONDS); // Timeout after 5 seconds
} catch (TimeoutException e) {
log.error("Notification timed out for order: {}", event.getOrderId());
// Handle timeout appropriately
} catch (Exception e) {
log.error("Failed to send notification", e);
throw new EventHandlingException("Failed to handle event", e);
} finally {
executor.shutdown();
}
}
}import org.springframework.scheduling.annotation.Scheduled;
import java.util.List;
@Component
public class BatchEventHandler {
private final List<DomainEvent> eventBuffer = new ArrayList<>();
@TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
public void bufferEvent(DomainEvent event) {
synchronized (eventBuffer) {
eventBuffer.add(event);
if (eventBuffer.size() >= 100) {
processBatch();
}
}
}
@Scheduled(fixedDelay = 5000)
public synchronized void processBatch() {
if (eventBuffer.isEmpty()) {
return;
}
List<DomainEvent> batch = new ArrayList<>(eventBuffer);
eventBuffer.clear();
// Process batch
batchProcessor.process(batch);
}
}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