-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'develop' of https://github.com/Wedit-project/Server int…
…o feat/#15-이미지-저장
- Loading branch information
Showing
12 changed files
with
427 additions
and
35 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
84 changes: 84 additions & 0 deletions
84
src/main/java/com/wedit/weditapp/domain/member/controller/MemberController.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
package com.wedit.weditapp.domain.member.controller; | ||
|
||
import com.wedit.weditapp.domain.member.domain.Member; | ||
import com.wedit.weditapp.domain.member.dto.LoginRequestDto; | ||
import com.wedit.weditapp.domain.member.dto.MemberRequestDto; | ||
import com.wedit.weditapp.domain.member.dto.MemberResponseDto; | ||
import com.wedit.weditapp.domain.member.service.MemberService; | ||
import com.wedit.weditapp.global.response.GlobalResponseDto; | ||
import io.swagger.v3.oas.annotations.Operation; | ||
import io.swagger.v3.oas.annotations.responses.ApiResponse; | ||
import io.swagger.v3.oas.annotations.responses.ApiResponses; | ||
import jakarta.validation.Valid; | ||
import lombok.RequiredArgsConstructor; | ||
import org.springframework.http.HttpStatus; | ||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.*; | ||
|
||
import java.util.List; | ||
|
||
@RestController | ||
@RequestMapping("/api/members") | ||
@RequiredArgsConstructor | ||
public class MemberController { | ||
|
||
private final MemberService memberService; | ||
|
||
// 회원 가입 API | ||
@Operation(summary = "회원가입", description = "새로운 유저를 등록합니다.") | ||
@ApiResponses(value = { | ||
@ApiResponse(responseCode = "201", description = "회원 가입 성공"), | ||
@ApiResponse(responseCode = "409", description = "이미 가입된 이메일입니다."), | ||
@ApiResponse(responseCode = "500", description = "서버 에러") | ||
}) | ||
@PostMapping("/signup") | ||
public ResponseEntity<GlobalResponseDto<MemberResponseDto>> createMember( | ||
@Valid @RequestBody MemberRequestDto requestDto) { | ||
memberService.createMember(requestDto); // 반환값 사용 X -> 추후 OAuth2 구현하면서 변동 가능성 O | ||
return ResponseEntity.status(HttpStatus.OK).body(GlobalResponseDto.success()); | ||
} | ||
|
||
// 임시 로그인 API | ||
@Operation(summary = "임시 로그인", description = "해당 서비스에 로그인합니다.") | ||
@ApiResponses(value = { | ||
@ApiResponse(responseCode = "201", description = "로그인 성공"), | ||
@ApiResponse(responseCode = "401", description = "로그인에 실패하였습니다."), | ||
@ApiResponse(responseCode = "404", description = "유저를 찾을 수 없습니다."), | ||
@ApiResponse(responseCode = "500", description = "서버 에러") | ||
}) | ||
@PostMapping("/login") | ||
public ResponseEntity<GlobalResponseDto<String>> login( | ||
@RequestBody LoginRequestDto loginRequest) { | ||
// 로그인 로직 → 토큰 발급 | ||
String token = memberService.login(loginRequest); | ||
|
||
// 토큰을 응답 바디로 전달 | ||
return ResponseEntity.ok(GlobalResponseDto.success(token)); | ||
} | ||
|
||
// 모든 회원 조회 API | ||
@Operation(summary = "모든 회원 조회", description = "등록된 모든 회원의 정보를 조회합니다.") | ||
@ApiResponses(value = { | ||
@ApiResponse(responseCode = "201", description = "조회 성공"), | ||
@ApiResponse(responseCode = "404", description = "유저를 찾을 수 없습니다."), | ||
@ApiResponse(responseCode = "500", description = "서버 에러") | ||
}) | ||
@GetMapping | ||
public ResponseEntity<GlobalResponseDto<List<MemberResponseDto>>> findAllMembers() { | ||
List<MemberResponseDto> memberResponses = memberService.findAllMembers(); | ||
return ResponseEntity.ok(GlobalResponseDto.success(memberResponses)); | ||
} | ||
|
||
// 단일 회원 조회 API | ||
@Operation(summary = "단일 회원 조회", description = "해당 id를 가진 회원의 정보를 조회합니다.") | ||
@ApiResponses(value = { | ||
@ApiResponse(responseCode = "201", description = "조회 성공"), | ||
@ApiResponse(responseCode = "404", description = "유저를 찾을 수 없습니다."), | ||
@ApiResponse(responseCode = "500", description = "서버 에러") | ||
}) | ||
@GetMapping("/{userId}") | ||
public ResponseEntity<GlobalResponseDto<MemberResponseDto>> findMember( | ||
@PathVariable Long userId) { | ||
return ResponseEntity.ok(GlobalResponseDto.success(memberService.findMember(userId))); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
11 changes: 11 additions & 0 deletions
11
src/main/java/com/wedit/weditapp/domain/member/domain/repository/MemberRepository.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package com.wedit.weditapp.domain.member.domain.repository; | ||
|
||
import com.wedit.weditapp.domain.member.domain.Member; | ||
import org.springframework.data.jpa.repository.JpaRepository; | ||
|
||
import java.util.Optional; | ||
|
||
public interface MemberRepository extends JpaRepository<Member, Long> { | ||
// 임시 로그인용 : 이메일로 회원 찾기 | ||
Optional<Member> findByEmail(String email); | ||
} |
12 changes: 12 additions & 0 deletions
12
src/main/java/com/wedit/weditapp/domain/member/dto/LoginRequestDto.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
package com.wedit.weditapp.domain.member.dto; | ||
|
||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
|
||
@Getter | ||
@NoArgsConstructor | ||
public class LoginRequestDto { | ||
private String email; | ||
|
||
} |
19 changes: 19 additions & 0 deletions
19
src/main/java/com/wedit/weditapp/domain/member/dto/MemberRequestDto.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.wedit.weditapp.domain.member.dto; | ||
|
||
import jakarta.validation.constraints.Email; | ||
import jakarta.validation.constraints.NotBlank; | ||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
|
||
|
||
@Getter | ||
@NoArgsConstructor | ||
public class MemberRequestDto { | ||
@Email(message = "이메일 형식을 지켜야 합니다.") | ||
@NotBlank(message = "이메일을 반드시 입력해야 합니다.") | ||
private String email; | ||
|
||
@NotBlank(message = "이름을 반드시 입력해야 합니다.") | ||
private String name; | ||
} |
38 changes: 38 additions & 0 deletions
38
src/main/java/com/wedit/weditapp/domain/member/dto/MemberResponseDto.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package com.wedit.weditapp.domain.member.dto; | ||
|
||
import com.wedit.weditapp.domain.member.domain.Member; | ||
import com.wedit.weditapp.domain.shared.MemberRole; | ||
import com.wedit.weditapp.domain.shared.MemberStatus; | ||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
|
||
@Getter | ||
@NoArgsConstructor | ||
public class MemberResponseDto { | ||
private Long id; | ||
private String email; | ||
private String name; | ||
private MemberRole role; | ||
private MemberStatus status; | ||
|
||
@Builder | ||
private MemberResponseDto(Long id, String email, String name, MemberRole role, MemberStatus status) { | ||
this.id = id; | ||
this.email = email; | ||
this.name = name; | ||
this.role = role; | ||
this.status = status; | ||
} | ||
|
||
public static MemberResponseDto from(Member member) { | ||
return MemberResponseDto.builder() | ||
.id(member.getId()) | ||
.email(member.getEmail()) | ||
.name(member.getName()) | ||
.role(member.getRole()) | ||
.status(member.getStatus()) | ||
.build(); | ||
} | ||
} | ||
|
62 changes: 62 additions & 0 deletions
62
src/main/java/com/wedit/weditapp/domain/member/service/MemberService.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
package com.wedit.weditapp.domain.member.service; | ||
|
||
import com.wedit.weditapp.domain.member.domain.Member; | ||
import com.wedit.weditapp.domain.member.domain.repository.MemberRepository; | ||
import com.wedit.weditapp.domain.member.dto.LoginRequestDto; | ||
import com.wedit.weditapp.domain.member.dto.MemberRequestDto; | ||
import com.wedit.weditapp.domain.member.dto.MemberResponseDto; | ||
import com.wedit.weditapp.global.error.ErrorCode; | ||
import com.wedit.weditapp.global.error.exception.CommonException; | ||
import com.wedit.weditapp.global.security.jwt.JwtProvider; | ||
import lombok.RequiredArgsConstructor; | ||
import org.springframework.stereotype.Service; | ||
import org.springframework.transaction.annotation.Transactional; | ||
|
||
import java.util.List; | ||
import java.util.stream.Collectors; | ||
|
||
@Service | ||
@RequiredArgsConstructor | ||
@Transactional | ||
public class MemberService { | ||
private final MemberRepository memberRepository; | ||
private final JwtProvider jwtProvider; // JWT 발급을 위해 | ||
|
||
// [회원가입 관련] - 이미 존재하는 이메일인지 검사 + Member 엔티티 생성 + DB저장 및 반환 | ||
public Member createMember(MemberRequestDto requestDto) { | ||
if (memberRepository.findByEmail(requestDto.getEmail()).isPresent()) { | ||
throw new CommonException(ErrorCode.EMAIL_ALREADY_EXISTS); | ||
} | ||
|
||
Member member = Member.createUser( | ||
requestDto.getEmail(), | ||
requestDto.getName() | ||
); | ||
|
||
return memberRepository.save(member); | ||
} | ||
|
||
public String login(LoginRequestDto loginRequest) { | ||
// 이메일로 회원 조회 | ||
Member member = memberRepository.findByEmail(loginRequest.getEmail()) | ||
.orElseThrow(() -> new CommonException(ErrorCode.USER_NOT_FOUND)); | ||
|
||
// JWT Access Token 생성 | ||
return jwtProvider.createAccessToken(member.getEmail()); | ||
} | ||
|
||
// [모든 회원 조회] | ||
public List<MemberResponseDto> findAllMembers() { | ||
return memberRepository.findAll() | ||
.stream() | ||
.map(MemberResponseDto::from) | ||
.collect(Collectors.toList()); | ||
} | ||
|
||
// [단일 회원 조회] | ||
public MemberResponseDto findMember(Long userId) { | ||
Member member = memberRepository.findById(userId) | ||
.orElseThrow(() -> new CommonException(ErrorCode.USER_NOT_FOUND)); | ||
return MemberResponseDto.from(member); | ||
} | ||
} |
Oops, something went wrong.