mirror of
https://github.com/ktds-dg0501/kt-event-marketing.git
synced 2025-12-06 23:26:25 +00:00
4.1 KiB
4.1 KiB
API설계가이드
[요청사항]
- <작성원칙>을 준용하여 설계
- <작성순서>에 따라 설계
- [결과파일] 안내에 따라 파일 작성
- 최종 완료 후 API 확인 방법 안내
- https://editor.swagger.io/ 접근
- 생성된 swagger yaml파일을 붙여서 확인 및 테스트
[가이드]
<작성 원칙>
- 각 서비스 API는 독립적으로 완전한 명세를 포함
- 공통 스키마는 각 서비스에서 필요에 따라 직접 정의
- 서비스 간 의존성을 최소화하여 독립 배포 가능
- 중복되는 스키마가 많아질 경우에만 공통 파일 도입 검토 <작성순서>
- 준비:
- 유저스토리, 외부시퀀스설계서, 내부시퀀스설계서 분석 및 이해
- 실행:
- <병렬처리> 안내에 따라 동시 수행
- <API선정원칙>에 따라 API 선정
- <파일작성안내>에 따라 작성
- <검증방법>에 따라 작성된 YAML의 문법 및 구조 검증 수행
- 검토:
- <작성원칙> 준수 검토
- 스쿼드 팀원 리뷰: 누락 및 개선 사항 검토
- 수정 사항 선택 및 반영
<API선정원칙>
- 유저스토리와 매칭 되어야 함. 불필요한 추가 설계 금지
(유저스토리 ID를 x-user-story 확장 필드에 명시) - '외부시퀀스설계서'/'내부시퀀스설계서'와 일관성 있게 선정
<파일작성안내>
- OpenAPI 3.0 스펙 준용
- servers 섹션 필수화
- 모든 OpenAPI 명세에 servers 섹션 포함
- SwaggerHub Mock URL을 첫 번째 옵션으로 배치
- example 데이터 권장
- 스키마에 example을 추가하여 Swagger UI에서 테스트 할 수 있게함
- 테스트 시나리오 포함
- 각 API 엔드포인트별 테스트 케이스 정의
- 성공/실패 케이스 모두 포함
- 작성 형식
- YAML 형식의 OpenAPI 3.0 명세
- 각 API별 필수 항목:
- summary: API 목적 설명
- operationId: 고유 식별자
- x-user-story: 유저스토리 ID
- x-controller: 담당 컨트롤러
- tags: API 그룹 분류
- requestBody/responses: 상세 스키마
- 각 서비스 파일에 필요한 모든 스키마 포함:
- components/schemas: 요청/응답 모델
- components/parameters: 공통 파라미터
- components/responses: 공통 응답
- components/securitySchemes: 인증 방식
<파일 구조>
design/backend/api/
├── {service-name}-api.yaml # 각 마이크로서비스별 API 명세
└── ... # 추가 서비스들
예시:
├── profile-service-api.yaml # 프로파일 서비스 API
├── order-service-api.yaml # 주문 서비스 API
└── payment-service-api.yaml # 결제 서비스 API
- 파일명 규칙
- 서비스명은 kebab-case로 작성
- 파일명 형식: {service-name}-api.yaml
- 서비스명은 유저스토리의 '서비스' 항목을 영문으로 변환하여 사용
<병렬처리>
- 의존성 분석 선행: 병렬 처리 전 반드시 의존성 파악
- 순차 처리 필요시: 무리한 병렬화보다는 안전한 순차 처리
- 검증 단계 필수: 병렬 처리 후 통합 검증
<검증방법>
- swagger-cli를 사용한 자동 검증 수행
- 검증 명령어:
swagger-cli validate {파일명} - swagger-cli가 없을 경우 자동 설치:
# swagger-cli 설치 확인 및 자동 설치 command -v swagger-cli >/dev/null 2>&1 || npm install -g @apidevtools/swagger-cli # 검증 실행 swagger-cli validate design/backend/api/*.yaml - 검증 항목:
- OpenAPI 3.0 스펙 준수
- YAML 구문 오류
- 스키마 참조 유효성
- 필수 필드 존재 여부
[참고자료]
- 유저스토리
- 외부시퀀스설계서
- 내부시퀀스설계서
- OpenAPI 스펙: https://swagger.io/specification/
[예시]
- swagger api yaml: https://raw.githubusercontent.com/cna-bootcamp/clauding-guide/refs/heads/main/samples/sample-swagger-api.yaml
- API설계서: https://raw.githubusercontent.com/cna-bootcamp/clauding-guide/refs/heads/main/samples/sample-API%20설계서.md
[결과파일]
- 각 서비스별로 별도의 YAML 파일 생성
- design/backend/api/*.yaml (OpenAPI 형식)