feat: OAuth 2.0 백엔드 시스템 구현 완료

Phase 1 & 2 완료:
- 프로젝트 기본 구조 설정
- Docker Compose 환경 구성 (MongoDB, Redis, Backend, Frontend)
- FastAPI 기반 OAuth 2.0 백엔드 구현

주요 기능:
- JWT 기반 인증 시스템
- 3단계 권한 체계 (System Admin/Group Admin/User)
- 사용자 관리 CRUD API
- 애플리케이션 관리 CRUD API
- OAuth 2.0 Authorization Code Flow
- Refresh Token 관리
- 인증 히스토리 추적

API 엔드포인트:
- /auth/* - 인증 관련 (register, login, logout, refresh)
- /users/* - 사용자 관리
- /applications/* - 애플리케이션 관리
- /oauth/* - OAuth 2.0 플로우

보안 기능:
- bcrypt 비밀번호 해싱
- JWT 토큰 인증
- CORS 설정
- Rate limiting 준비

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
jungwoo choi
2025-09-05 14:56:02 +09:00
parent abdcc31245
commit 6c21809a24
25 changed files with 2012 additions and 45 deletions

59
oauth/backend/Dockerfile Normal file
View File

@ -0,0 +1,59 @@
# Multi-stage Dockerfile for OAuth Backend
# Base stage
FROM python:3.11-slim as base
WORKDIR /app
# Install system dependencies
RUN apt-get update && apt-get install -y \
gcc \
&& rm -rf /var/lib/apt/lists/*
# Copy requirements
COPY requirements.txt .
# Install Python dependencies
RUN pip install --no-cache-dir -r requirements.txt
# Development stage
FROM base as development
# Set environment variables
ENV PYTHONUNBUFFERED=1
ENV ENVIRONMENT=dev
# Copy application code
COPY . .
# Create necessary directories
RUN mkdir -p /var/log/oauth
# Expose port
EXPOSE 8000
# Run with hot reload
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000", "--reload"]
# Production stage
FROM base as production
# Set environment variables
ENV PYTHONUNBUFFERED=1
ENV ENVIRONMENT=prod
# Copy application code
COPY . .
# Create necessary directories
RUN mkdir -p /var/log/oauth
# Create non-root user
RUN useradd -m -u 1000 appuser && chown -R appuser:appuser /app /var/log/oauth
USER appuser
# Expose port
EXPOSE 8000
# Run without reload
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000", "--workers", "4"]