인프런 커뮤니티 질문&답변
Auth Module의 역할
작성
·
463
1
해당 프로젝트에서 jwt를 이용한 로그인을 구현하기 위해서 Auth Module을 추가하였습니다. 그리고, Auth Module 내부에 jwt에 대한 구현 및 전략 수립 후 Auth Service에서 JwtLogin을 구현하였습니다.
저는 Cats Module에서 Login기능을 구현하고 Cats에 대한 데이터 검증 후 JWT Token 발급을 Auth Service에서 제공하는 것이 Module에 역할에 맞는 기능들을 가지게 되어서 더 좋다고 생각이 들었습니다.
Auth Module에 jwt토큰에 대한 발급 및 검증이라는 역할만 부여하는 것이 아니라 Login 기능을 전체(Cats에 대한 데이터 검증을 포함하는)를 구현하는 이유가 무엇인지 궁금합니다!
답변 1
2
윤상석
지식공유자
안녕하세요!
사실 모듈의 책임 분리 설계를 어떻게 하느냐에 따라 다릅니다. AuthModule은 "애플리케이션에서 인증 부분을 담당하는 모듈"이라고 책임을 나누었을때 LogIn 행위는 인증 부분에 해당하는 것이므로 LogIn 행위는 AuthModule에서 구현을 한 것입니다. 하지만 DoJin You 님께서 다른 의미로 책임 분리를 설계하셨으면 그렇게 하는 것이 맞습니다. 어떤 것이 옳은가?에 대한 답은 소프트웨어 제품이 앞으로 어떤 식으로 확장될 것인지, 기존에 레거시 설계, 유지보수 등에 맞게 설계하는 것입니다.





.png?w=112)