1
0
forked from baron/baron-sso
Files
baron-sso/docs/consent_flow_explanation.md

4.8 KiB

Baron SSO Consent(권한 동의) 흐름 설명

이 문서는 Baron SSO 시스템에서 /consent 페이지가 어떻게 구현되어 있으며, 사용자가 어떻게 이 페이지로 이동하게 되는지 설명합니다.

1. 개요

Consent(권한 동의) 흐름은 Ory Hydra가 처리하는 OAuth2/OpenID Connect 프로토콜의 핵심 절차입니다. 클라이언트 앱(Relying Party, RP)이 사용자의 정보에 접근하기 위해 특정 권한(Scope)을 요청할 때, 사용자가 아직 해당 권한을 승인하지 않았다면 Hydra는 사용자를 설정된 Consent URL로 리다이렉트하여 동의를 구합니다.

사용자가 /consent 페이지로 이동하는 것은 Ory Hydra의 환경 설정에 의해 제어됩니다.

  • 설정 파일: compose.ory.yaml (및 docker-compose.yaml)
  • 환경 변수: URLS_CONSENT

compose.ory.yaml 파일 내 hydra 서비스의 설정은 다음과 같습니다:

hydra:
  environment:
    - URLS_CONSENT=${USERFRONT_URL:-http://localhost:5000}/consent

Hydra는 권한 동의가 필요하다고 판단하면, 사용자의 브라우저를 다음 주소로 리다이렉트합니다: {USERFRONT_URL}/consent?consent_challenge={challenge_id}

3. 프론트엔드 구현 (userfront)

userfront 애플리케이션(Flutter)은 권한 동의 화면의 UI와 사용자 상호작용을 처리합니다.

라우트 처리

  • 파일: userfront/lib/main.dart
  • 로직: 라우터 설정에서 /consent 경로를 처리합니다. URL 쿼리 파라미터에서 consent_challenge를 추출하여 ConsentScreen 위젯에 전달합니다.

UI 및 비즈니스 로직

  • 파일: userfront/lib/features/auth/presentation/consent_screen.dart
  • 로직:
    1. 정보 로드: 페이지 로드 시 AuthProxyService.getConsentInfo(widget.consentChallenge)를 호출하여 동의 요청의 상세 정보를 가져옵니다.
    2. 화면 표시: 접근을 요청한 앱의 이름과 요청된 권한 목록(Scope)을 사용자에게 보여줍니다.
    3. 동의 실행: 사용자가 "동의" 버튼을 누르면 AuthProxyService.acceptConsent(widget.consentChallenge)를 호출합니다.
    4. 최종 이동: 백엔드로부터 성공 응답과 함께 redirectTo URL을 받으면, 해당 URL로 브라우저를 이동시켜 로그인/인증 과정을 완료합니다.

API 서비스

  • 파일: userfront/lib/core/services/auth_proxy_service.dart
  • 엔드포인트:
    • 정보 조회: GET /api/v1/auth/consent
    • 동의 수락: POST /api/v1/auth/consent/accept

4. 백엔드 구현 (backend)

백엔드는 프론트엔드와 Ory Hydra Admin API 사이에서 보안 및 통신을 중계합니다.

핸들러

  • 파일: backend/internal/handler/auth_handler.go
  • 주요 함수:
    • GetConsentRequest: 전달받은 challenge를 사용하여 Hydra로부터 권한 동의 요청의 상세 내용(클라이언트 정보, 스코프 등)을 가져옵니다.
    • AcceptConsentRequest: Hydra에 권한 동의 수락을 통보합니다. Hydra가 생성한 최종 리다이렉트 URL(redirect_to)을 응답으로 받아 프론트엔드에 전달합니다.

Hydra Admin 서비스 연동

  • 파일: backend/internal/service/hydra_admin_service.go
  • 로직: Hydra Admin API와 직접 통신합니다.
    • 정보 조회: GET /oauth2/auth/requests/consent (Hydra Admin 인터페이스)
    • 동의 수락: PUT /oauth2/auth/requests/consent/accept (Hydra Admin 인터페이스)

5. 전체 흐름 요약

  1. 사용자: 클라이언트 앱(예: adminfront, devfront 등)에서 로그인을 시도합니다.
  2. Hydra: 사용자의 세션을 확인하고, 해당 앱에 필요한 권한 동의가 있는지 확인합니다. 동의가 필요하면 사용자를 USERFRONT_URL/consent?consent_challenge=...로 보냅니다.
  3. Userfront: /consent 페이지가 로드되고 consent_challenge를 인식합니다.
  4. Userfront -> Backend: GET /api/v1/auth/consent를 호출하여 어떤 권한을 요청 중인지 묻습니다.
  5. Backend -> Hydra: Hydra Admin API에 해당 챌린지의 상세 정보를 조회하여 반환합니다.
  6. 사용자: 화면에서 권한 내용을 확인하고 "동의"를 클릭합니다.
  7. Userfront -> Backend: POST /api/v1/auth/consent/accept를 호출합니다.
  8. Backend -> Hydra: Hydra Admin API에 동의 수락을 요청합니다.
  9. Hydra -> Backend: 인증을 완료할 수 있는 최종 리다이렉트 URL(클라이언트 앱의 callback 주소)을 반환합니다.
  10. Backend -> Userfront: 해당 URL을 전달합니다.
  11. Userfront: 사용자를 클라이언트 앱으로 이동시키며 프로세스가 종료됩니다.