Skip to content

f-lab-edu/sendzy

Repository files navigation

sendzy

프로젝트 기획

필수 기능

회원 가입

  • OAuth는 현재로써 고려하지 않음
  • 회원 데이터는 암호화에 대한 이해를 위해 id, password를 입력하는 형태로 구현
  • id는 이메일 형태로 입력 받고, 중복 검사를 진행
  • 패스워드는 SHA-256과 같은 단방향 해시를 검토

로그인

  • id, password를 입력받아 로그인
  • 로그인 상태 관리는 세션 방식과 토큰 방식을 고려하며, 인증 방식에 대한 학습 후 확정 예정
  • 패스워드가 네트워크를 통해 전송될 때 통신 안전을 위해 SSL 레이어 도입 예정(HTTPS)

송금

  • 송금할 대상의 이메일(혹은 계좌번호)을 입력하고, 송금할 금액을 입력
  • 이메일 입력 시 회원 가입 여부 확인. 가입된 회원에게만 송금 가능하도록 구현
  • 송금 요청 시 거래 내역에 송금 이력을 추가
  • 송금 요청 시 수취인이 수락할 때까지 출금에 대한 아래 2가지 방식 고려
    1. 중간 계좌를 만들어 중간 계좌에 돈을 예치해 두는 방식
    2. 계좌의 총액은 그대로인 채 마이너스 이력을 남기는 방식

송금 취소

  • 수취인은 송금을 수락할 수도, 수락하지 않을 수도 있음
  • 수취인이 수락하지 않았을 경우 송금 취소 가능
  • 수취인이 3일 동안 수락하지 않을 경우 자동으로 송금 취소

수취

  • 수취 요청을 수락하면 거래 내역에 수취 이력을 추가
  • 수취인이 송금을 거절할 수 있음. 거절된 경우 거래가 취소되고 거래 내역에 반영

거래 내역 및 잔액 조회

  • 인증된 사용자는 거래 내역을 조회할 수 있음. 이 때 거래 내역은 사용자가 송금하거나 수취한 내역만 보여야함
  • 인증된 사용자는 본인 계좌의 잔액을 조회할 수 있음. 잔액은 송금, 수취 내역과 불일치가 발생하지 않아야 하며, 데이터의 일관성에 유의해야 함

추가 기능

예약 송금

  • 지정한 날짜, 시간에 지정한 금액을 송금
  • 매일, 매주, 매달 등 자동 이체 형태로 기능 확장 가능

와이어 프레임

image

시퀀스 다이어그램

sequenceDiagram
    actor User as 사용자
    participant Client as 클라이언트
    participant Auth as 인증 서비스
    participant API as API 서버
    participant DB as 데이터베이스

    %% 회원가입 프로세스
    rect rgb(240, 248, 255)
        Note over User, DB: 회원가입 프로세스
        User->>Client: 이메일/비밀번호 입력
        Client->>API: 이메일 중복 확인
        API->>DB: 이메일 조회
        DB-->>API: 조회 결과
        
        Note right of API: 비밀번호 암호화 방식<br/>추후 결정 (SHA-256 등)
        
        API->>DB: 회원 정보 저장
        DB-->>API: 저장 완료
        API-->>Client: 가입 완료 응답
        Client-->>User: 완료 화면 표시
    end

    %% 로그인 프로세스
    rect rgb(255, 245, 238)
        Note over User, DB: 로그인 프로세스
        User->>Client: 로그인 정보 입력
        Client->>Auth: 인증 요청
        Auth->>DB: 사용자 검증
        DB-->>Auth: 사용자 정보
        
        Note right of Auth: 인증 방식<br/>(세션/토큰) 추후 결정
        
        Auth-->>Client: 인증 응답
        Client->>Client: 인증 정보 저장
        Client-->>User: 로그인 완료
    end

    %% 송금 프로세스
    rect rgb(240, 255, 240)
        Note over User, DB: 송금 프로세스
        User->>Client: 송금 정보 입력
        Client->>Auth: 인증 확인
        Auth-->>Client: 인증 확인 완료
        Client->>API: 송금 요청
        API->>DB: 잔액 확인
        DB-->>API: 잔액 정보
        
        Note right of API: 송금액 처리 방식<br/>(임시 계좌/마이너스 처리)<br/>추후 결정
        
        API->>DB: 거래 기록 생성
        DB-->>API: 처리 완료
        API-->>Client: 송금 요청 완료
        Client-->>User: 결과 표시
    end

    %% 송금 승인/거절 프로세스
    rect rgb(255, 240, 245)
        Note over User, DB: 송금 승인/거절 프로세스
        User->>Client: 승인/거절 선택
        Client->>Auth: 인증 확인
        Auth-->>Client: 인증 확인 완료
        Client->>API: 승인/거절 요청
        
        Note right of API: 거래 처리 방식<br/>추후 결정
        
        API->>DB: 거래 상태 업데이트
        DB-->>API: 처리 완료
        API-->>Client: 처리 결과
        Client-->>User: 결과 표시
    end

    %% 거래 내역 조회
    rect rgb(245, 245, 255)
        Note over User, DB: 거래 내역 조회
        User->>Client: 거래 내역 요청
        Client->>Auth: 인증 확인
        Auth-->>Client: 인증 확인 완료
        Client->>API: 거래 내역 조회
        API->>DB: 내역 조회
        DB-->>API: 조회 결과
        API-->>Client: 거래 내역
        Client-->>User: 내역 표시
    end
Loading

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages