AgentSkillsCN

acc-ddd-knowledge

DDD 架构知识库。为领域驱动设计的审计提供各类模式、反模式以及专属于 PHP 的最佳实践指南。

SKILL.md
--- frontmatter
name: acc-ddd-knowledge
description: DDD architecture knowledge base. Provides patterns, antipatterns, and PHP-specific guidelines for Domain-Driven Design audits.

DDD Knowledge Base

Quick reference for DDD architecture patterns and PHP implementation guidelines.

Core Principles

Layer Dependencies (Clean Architecture)

code
Presentation → Application → Domain ← Infrastructure
                    ↓
              Domain (center)

Rule: Dependencies point INWARD. Domain has ZERO external dependencies.

Layer Responsibilities

LayerContainsDepends On
DomainEntities, Value Objects, Aggregates, Domain Services, Repository Interfaces, Domain EventsNothing
ApplicationUse Cases, DTOs, Application ServicesDomain
InfrastructureRepository Implementations, External APIs, DB, Cache, QueueDomain, Application
PresentationControllers, Actions, Request/Response, CLIApplication

Quick Checklists

Domain Layer Checklist

  • No framework imports (Doctrine, Eloquent, Symfony)
  • Entities have behavior, not just data
  • Value Objects for domain concepts (Email, Money, Id)
  • Repository INTERFACES defined here
  • Enums for fixed value sets
  • Domain Events for side effects
  • No public function set*() methods

Application Layer Checklist

  • UseCases orchestrate, don't decide
  • DTOs for input/output
  • No business logic (if/switch on domain state)
  • Transaction boundaries here
  • No HTTP/CLI concerns

Infrastructure Layer Checklist

  • Implements Domain interfaces
  • No business logic in repositories
  • External service adapters
  • Caching, queuing implementations

Presentation Layer Checklist

  • Validates input
  • Maps to DTOs
  • Calls UseCase
  • Formats response
  • No business logic

Common Violations Quick Reference

ViolationWhere to LookSeverity
use Doctrine\\ in DomainDomain/*.phpCritical
use Illuminate\\ in DomainDomain/*.phpCritical
use Infrastructure\\ in DomainDomain/*.phpCritical
Only getters/setters in EntityDomain/Entity/*.phpWarning
=== 'pending' magic stringsAny PHP fileWarning
public function set*()Domain/Entity/*.phpWarning
Business logic in ControllerPresentation/*.phpWarning
Business logic in RepositoryInfrastructure/*.phpWarning

PHP 8.5 DDD Patterns

Value Object

php
final readonly class Email
{
    public function __construct(
        public string $value
    ) {
        if (!filter_var($value, FILTER_VALIDATE_EMAIL)) {
            throw new InvalidArgumentException('Invalid email');
        }
    }

    public function equals(self $other): bool
    {
        return $this->value === $other->value;
    }
}

Entity with Behavior

php
final class Order
{
    private OrderStatus $status;

    public function __construct(
        private readonly OrderId $id,
        private readonly CustomerId $customerId
    ) {
        $this->status = OrderStatus::Pending;
    }

    public function confirm(): void
    {
        if (!$this->status->canTransitionTo(OrderStatus::Confirmed)) {
            throw new DomainException('Cannot confirm order');
        }
        $this->status = OrderStatus::Confirmed;
    }
}

Repository Interface

php
// Domain/Repository/OrderRepositoryInterface.php
interface OrderRepositoryInterface
{
    public function findById(OrderId $id): ?Order;
    public function save(Order $order): void;
}

References

For detailed information, load these reference files:

  • references/layer-architecture.md — Detailed layer rules and boundaries
  • references/domain-patterns.md — Entity, VO, Aggregate, Repository patterns
  • references/application-patterns.md — UseCase, DTO, Command/Query patterns
  • references/antipatterns.md — Common violations with detection patterns
  • references/php-specific.md — PHP 8.5 specific implementations

Assets

  • assets/report-template.md — Structured audit report template