Files
BaronSSO/baron-sso/docs/superpowers/plans/2026-03-30-headless-password-login-backend-api.md

3.1 KiB

Headless Password Login Backend API Implementation Plan

For agentic workers: REQUIRED: Use superpowers:subagent-driven-development (if subagents available) or superpowers:executing-plans to implement this plan. Steps use checkbox (- [ ]) syntax for tracking.

Goal: Trusted RP에 한해 login_challenge + loginId + password를 받아 OIDC 로그인 흐름을 계속할 수 있는 백엔드 API를 추가합니다.

Architecture: 기존 AuthHandler.PasswordLogin의 IDP sign-in, identity resolve, Hydra login accept 흐름을 재사용 가능한 helper로 정리하고, 신규 endpoint에서는 Hydra client의 trusted/headless 상태를 추가 검증합니다. 성공 응답은 sessionJwt를 숨기고 redirectTo만 반환해 RP 브라우저가 기존 OIDC 흐름을 이어가도록 합니다.

Tech Stack: Go, Fiber, Ory Hydra Admin API, Kratos/Ory provider, testify


Task 1: Failing Test 추가

Files:

  • Modify: backend/internal/handler/auth_handler_login_test.go

  • Step 1: headless trusted RP 성공 케이스 테스트 추가

POST /api/v1/auth/headless/password/login 호출 시 trusted + headless enabled client면 redirectTo만 반환하는 테스트를 추가합니다.

  • Step 2: headless 미허용/불일치 케이스 테스트 추가

아래 케이스를 각각 추가합니다.

  • headless flag 없음

  • trusted RP 조건 미충족

  • request body client_id와 Hydra login request client 불일치

  • inactive client

  • Step 3: 테스트 단독 실행으로 실패 확인

Run: go test ./backend/internal/handler -run 'TestHeadlessPasswordLogin'

Expected: 신규 route 또는 handler 부재로 FAIL

Task 2: 신규 API 최소 구현

Files:

  • Modify: backend/cmd/server/main.go

  • Modify: backend/internal/handler/auth_handler.go

  • Step 1: route 추가

/api/v1/auth/headless/password/login route를 등록합니다.

  • Step 2: request body 및 검증 helper 추가

client_id, login_challenge, loginId, password를 받는 handler를 추가하고, Hydra login request의 client 일치 여부와 trusted/headless/inactive 상태를 검증합니다.

  • Step 3: 공통 로그인 처리 helper로 기존 로직 재사용

기존 PasswordLogin의 sign-in, identity resolve, Hydra accept 흐름을 helper로 분리하거나 최소 중복으로 재사용합니다.

  • Step 4: 성공 응답을 headless 정책에 맞게 고정

성공 시 redirectTo, status, provider만 응답하고 sessionJwt는 반환하지 않도록 합니다.

Task 3: 검증 및 회귀 확인

Files:

  • Modify: backend/internal/handler/auth_handler_login_test.go

  • Step 1: 신규 테스트 재실행

Run: go test ./backend/internal/handler -run 'TestHeadlessPasswordLogin'

Expected: PASS

  • Step 2: 기존 password login 관련 회귀 테스트 실행

Run: go test ./backend/internal/handler -run 'TestPasswordLogin'

Expected: PASS

  • Step 3: 이슈 업데이트

#480에 테스트 결과와 남은 후속 범위(전화번호 링크 승인형 분리)를 코멘트로 남깁니다.