这是域还是应用程序服务
Is this domain or application service
我正在使用 DDD 构建身份验证 micro-service/domain,但我仍然无法确定每个服务的所属位置。此时我不确定身份验证服务属于域服务还是应用程序服务。
我应该将此行为包装在域服务中,并通过应用程序服务公开响应对象,还是应该保持原样 - 作为应用程序服务。
public class AuthenticationService : IAuthenticationService
{
IAuthUnitOfWork _uow;
IUserRepository _userRepository;
IUserTokenFactory _userTokenFactory;
public AuthenticationService(IUserTokenFactory userTokenFactory, IUserRepository userRepository,
IAuthUnitOfWork uow)
{
_userTokenFactory = userTokenFactory;
_userRepository = userRepository;
_uow = uow;
}
public async Task<UserTokenResponse> AuthenticateAsync(string email, string password)
{
var user = await _userRepository.GetByEmailAndPasswordAsync(email, password);
//TODO: Add null check for user
var userToken = await _userTokenFactory.CreateWithAsync(user);
await _uow.SaveChangesAsync();
return new UserTokenResponse
{
ExpiressOn = userToken.ExpiressOn,
Token = userToken.Token
};
}
}
应用程序服务 协调应用程序流和基础设施,但不执行业务逻辑规则或不变量。经常看到对存储库、工作单元的调用,以及接受和 return 服务合同对象或 request/response 对象。他们通常不接受或 return 域实体或值对象。
域服务 不了解基础架构或整个应用程序流程 - 它们专门封装业务逻辑规则。它们接受域实体或值对象,对这些实体或对象执行条件操作,或执行业务规则计算,然后 return 原语或域实体或值对象。
基于这些概念,您的示例服务绝对是一个应用程序服务,因为它与您的存储库和工作单元交互,并且 returning 一个 "UserResponse" 类型(一个 'response' 类型听起来不像域实体)。
您的应用程序服务 AuthenticationService
正在委托给名为 UserTokenFactory
的服务。 UserTokenFactory
接受域实体(用户)和 returns 域值对象(用户令牌)。据推测,它以一种与基础设施无关的方式封装了与创建用户令牌相关的业务规则。因此,这看起来更像是一个域服务。负责创建领域概念(例如实体和值对象)的工厂只是一种特殊类型的领域服务(在我看来),尽管您最常看到 'domain services' 指的是执行某些业务逻辑的服务需要在多种类型的实体之间进行协调。
所以 - 我认为你的结构是合适的 - 你有一个应用程序服务协调基础设施和流程,它委托一个特殊的服务来执行业务逻辑。
我正在使用 DDD 构建身份验证 micro-service/domain,但我仍然无法确定每个服务的所属位置。此时我不确定身份验证服务属于域服务还是应用程序服务。
我应该将此行为包装在域服务中,并通过应用程序服务公开响应对象,还是应该保持原样 - 作为应用程序服务。
public class AuthenticationService : IAuthenticationService
{
IAuthUnitOfWork _uow;
IUserRepository _userRepository;
IUserTokenFactory _userTokenFactory;
public AuthenticationService(IUserTokenFactory userTokenFactory, IUserRepository userRepository,
IAuthUnitOfWork uow)
{
_userTokenFactory = userTokenFactory;
_userRepository = userRepository;
_uow = uow;
}
public async Task<UserTokenResponse> AuthenticateAsync(string email, string password)
{
var user = await _userRepository.GetByEmailAndPasswordAsync(email, password);
//TODO: Add null check for user
var userToken = await _userTokenFactory.CreateWithAsync(user);
await _uow.SaveChangesAsync();
return new UserTokenResponse
{
ExpiressOn = userToken.ExpiressOn,
Token = userToken.Token
};
}
}
应用程序服务 协调应用程序流和基础设施,但不执行业务逻辑规则或不变量。经常看到对存储库、工作单元的调用,以及接受和 return 服务合同对象或 request/response 对象。他们通常不接受或 return 域实体或值对象。
域服务 不了解基础架构或整个应用程序流程 - 它们专门封装业务逻辑规则。它们接受域实体或值对象,对这些实体或对象执行条件操作,或执行业务规则计算,然后 return 原语或域实体或值对象。
基于这些概念,您的示例服务绝对是一个应用程序服务,因为它与您的存储库和工作单元交互,并且 returning 一个 "UserResponse" 类型(一个 'response' 类型听起来不像域实体)。
您的应用程序服务 AuthenticationService
正在委托给名为 UserTokenFactory
的服务。 UserTokenFactory
接受域实体(用户)和 returns 域值对象(用户令牌)。据推测,它以一种与基础设施无关的方式封装了与创建用户令牌相关的业务规则。因此,这看起来更像是一个域服务。负责创建领域概念(例如实体和值对象)的工厂只是一种特殊类型的领域服务(在我看来),尽管您最常看到 'domain services' 指的是执行某些业务逻辑的服务需要在多种类型的实体之间进行协调。
所以 - 我认为你的结构是合适的 - 你有一个应用程序服务协调基础设施和流程,它委托一个特殊的服务来执行业务逻辑。