2016-08-16 7 views
1

DDD를 사용하여 인증 마이크로 서비스/도메인을 구축 중이며 각 서비스가 어디에 속하는지 식별하는 데 여전히 문제가 있습니다. 이 시점에서 인증 서비스가 도메인 서비스 또는 응용 프로그램 서비스에 속하는지 확실하지 않습니다.이 도메인 또는 응용 프로그램 서비스입니까?

도메인 serrvice에서이 동작을 래핑하고 응용 프로그램 서비스를 통해 응답 개체를 노출해야합니까? 아니면 응용 프로그램 서비스로 그대로 두어야합니다.

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 
      }; 
     } 

    } 

답변

7
  • 응용 프로그램 서비스는 응용 프로그램의 흐름과 인프라를 조정하지만, 비즈니스 로직 규칙 또는 불변을 실행하지 않습니다. 리포지토리, 작업 단위에 대한 호출을보고 서비스 계약 개체 또는 요청/응답 개체를 수락하고 반환하는 것이 일반적입니다. 일반적으로 도메인 엔터티 또는 값 개체를 수락하거나 반환하지 않습니다.

  • 도메인 서비스 인프라 또는 애플리케이션의 전체 흐름을 모르고있다 - 그들은 독점적으로 비즈니스 로직 규칙을 캡슐화한다. 도메인 엔터티 또는 값 개체를 수락하고 이러한 엔터티 또는 개체에 조건부 연산을 수행하거나 비즈니스 규칙 계산을 수행 한 다음 프리미티브 또는 도메인 엔터티 또는 값 개체를 반환합니다. 이 작품의 저장소 및 장치와 상호 작용하고, "UserResponse"유형을 반환 이러한 개념을 바탕으로

는, 샘플 서비스가 확실히 응용 프로그램 서비스 (A '응답'유형은 같은 소리하지 않습니다 도메인 엔티티).

응용 프로그램 서비스 AuthenticationServiceUserTokenFactory이라는 서비스에 위임하고 있습니다. UserTokenFactory은 도메인 엔터티 (user)를 받아들이고 도메인 값 개체 (usertoken)를 반환합니다. 아마도 그것은 사용자 토큰 생성과 관련된 비즈니스 규칙을 인프라에 구애받지 않는 방식으로 요약합니다. 따라서 도메인 서비스처럼 보입니다. 엔티티와 값 객체와 같은 도메인 개념을 만드는 책임이있는 팩토리는 도메인 서비스의 특별한 유형 일뿐입니다. (필자의 의견으로는) '도메인 서비스'는 일반적으로 필요한 비즈니스 로직을 수행하는 서비스를 나타냅니다. 여러 유형의 엔티티를 조정합니다.

여기서는 구조가 적절하다고 생각합니다. 비즈니스 논리를 실행하기위한 특별한 서비스를 위임 한 인프라와 흐름을 조정하는 응용 프로그램 서비스가 있습니다.