diff --git a/src/main/java/com/example/beginnerfitbe/friend/service/FriendService.java b/src/main/java/com/example/beginnerfitbe/friend/service/FriendService.java index 774b01d..b1a5fee 100644 --- a/src/main/java/com/example/beginnerfitbe/friend/service/FriendService.java +++ b/src/main/java/com/example/beginnerfitbe/friend/service/FriendService.java @@ -74,11 +74,15 @@ public List getPendingFriendRequests(Long userId) { sender.getId(), sender.getEmail(), sender.getName(), - sender.getExercisePurpose(), - sender.getExercisePart(), + sender.getHeight(), + sender.getWeight(), + sender.getTargetWeight(), + sender.getDate(), + sender.getTargetDate(), sender.getExerciseTime(), - sender.getExerciseIntensity(), - sender.getProfilePictureUrl() + sender.getExerciseGoals(), + sender.getConcernedAreas(), + sender.getExerciseIntensity() ); }) .collect(Collectors.toList()); @@ -94,11 +98,15 @@ public List getFriendWaitingService(Long userId) { receiver.getId(), receiver.getEmail(), receiver.getName(), - receiver.getExercisePurpose(), - receiver.getExercisePart(), + receiver.getHeight(), + receiver.getWeight(), + receiver.getTargetWeight(), + receiver.getDate(), + receiver.getTargetDate(), receiver.getExerciseTime(), - receiver.getExerciseIntensity(), - receiver.getProfilePictureUrl() + receiver.getExerciseGoals(), + receiver.getConcernedAreas(), + receiver.getExerciseIntensity() ); }) .collect(Collectors.toList()); @@ -117,11 +125,15 @@ public List getAcceptedFriendRequests(Long userId) { sender.getId(), sender.getEmail(), sender.getName(), - sender.getExercisePurpose(), - sender.getExercisePart(), + sender.getHeight(), + sender.getWeight(), + sender.getTargetWeight(), + sender.getDate(), + sender.getTargetDate(), sender.getExerciseTime(), - sender.getExerciseIntensity(), - sender.getProfilePictureUrl() + sender.getExerciseGoals(), + sender.getConcernedAreas(), + sender.getExerciseIntensity() ); }) .collect(Collectors.toList()); @@ -131,11 +143,15 @@ public List getAcceptedFriendRequests(Long userId) { receiver.getId(), receiver.getEmail(), receiver.getName(), - receiver.getExercisePurpose(), - receiver.getExercisePart(), + receiver.getHeight(), + receiver.getWeight(), + receiver.getTargetWeight(), + receiver.getDate(), + receiver.getTargetDate(), receiver.getExerciseTime(), - receiver.getExerciseIntensity(), - receiver.getProfilePictureUrl() + receiver.getExerciseGoals(), + receiver.getConcernedAreas(), + receiver.getExerciseIntensity() )); } @@ -175,11 +191,15 @@ public OtherUserDto getFriendInfo(Long senderId, String receiverEmail) { friend.getId(), friend.getEmail(), friend.getName(), - friend.getExercisePurpose(), - friend.getExercisePart(), + friend.getHeight(), + friend.getWeight(), + friend.getTargetWeight(), + friend.getDate(), + friend.getTargetDate(), friend.getExerciseTime(), - friend.getExerciseIntensity(), - friend.getProfilePictureUrl() + friend.getExerciseGoals(), + friend.getConcernedAreas(), + friend.getExerciseIntensity() ); } diff --git a/src/main/java/com/example/beginnerfitbe/jwt/config/SecurityConfig.java b/src/main/java/com/example/beginnerfitbe/jwt/config/SecurityConfig.java index 690b628..4764040 100644 --- a/src/main/java/com/example/beginnerfitbe/jwt/config/SecurityConfig.java +++ b/src/main/java/com/example/beginnerfitbe/jwt/config/SecurityConfig.java @@ -27,6 +27,7 @@ public class SecurityConfig { "/auth/sign-in", "/auth/sign-up", "/users/emailcheck", + "/users/health-info", "/swagger-ui.html", "/swagger-ui/**", "/v3/api-docs/**", diff --git a/src/main/java/com/example/beginnerfitbe/playlist/service/PlaylistService.java b/src/main/java/com/example/beginnerfitbe/playlist/service/PlaylistService.java index 29ecf8d..e5e1509 100644 --- a/src/main/java/com/example/beginnerfitbe/playlist/service/PlaylistService.java +++ b/src/main/java/com/example/beginnerfitbe/playlist/service/PlaylistService.java @@ -69,16 +69,16 @@ public void createPlaylistDaily() { private String searchKeyword(User user) { - String query= null; - if(user.getExerciseIntensity()<=3){ - query = user.getExercisePart() + " " + user.getExercisePurpose() +" 쉬운 운동"; - } - else if(user.getExerciseIntensity()>=7){ - query = user.getExercisePart() + " " + user.getExercisePurpose() +" 매운맛 운동"; - } - else{ - query = user.getExercisePart() + " " + user.getExercisePurpose()+" 운동"; - } + String query= "운동"; +// if(user.getExerciseIntensity()<=3){ +// query = user.getExercisePart() + " " + user.getExercisePurpose() +" 쉬운 운동"; +// } +// else if(user.getExerciseIntensity()>=7){ +// query = user.getExercisePart() + " " + user.getExercisePurpose() +" 매운맛 운동"; +// } +// else{ +// query = user.getExercisePart() + " " + user.getExercisePurpose()+" 운동"; +// } return query; } diff --git a/src/main/java/com/example/beginnerfitbe/user/controller/UserController.java b/src/main/java/com/example/beginnerfitbe/user/controller/UserController.java index 7e28f5d..2582644 100644 --- a/src/main/java/com/example/beginnerfitbe/user/controller/UserController.java +++ b/src/main/java/com/example/beginnerfitbe/user/controller/UserController.java @@ -2,6 +2,7 @@ import com.example.beginnerfitbe.error.StateResponse; import com.example.beginnerfitbe.jwt.util.JwtUtil; +import com.example.beginnerfitbe.user.dto.HealthInfoReqDto; import com.example.beginnerfitbe.user.dto.UserUpdateDto; import com.example.beginnerfitbe.user.service.UserService; import io.swagger.v3.oas.annotations.Operation; @@ -12,6 +13,8 @@ import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; +import java.io.IOException; + @RestController @RequiredArgsConstructor @RequestMapping("/users") @@ -43,12 +46,20 @@ ResponseEntity me(HttpServletRequest request){ Long userId = jwtUtil.getUserId(jwtUtil.resolveToken(request).substring(7)); return ResponseEntity.ok(userService.me(userId)); } + @PutMapping("") - @Operation(summary = "사용자 정보 업데이트 메서드", description = "사용자의 수정된 정보를 받아 업데이트 합니다.") - public ResponseEntity update(HttpServletRequest request, @RequestPart("updateDto") UserUpdateDto requestDto, @RequestPart(value = "profilePicture", required = false) MultipartFile profilePicture) { + @Operation(summary = "사용자 정보 업데이트 메서드", description = "사용자의 이름을 수정합니다.") + public ResponseEntity update(HttpServletRequest request, @RequestBody UserUpdateDto requestDto) { Long userId = jwtUtil.getUserId(jwtUtil.resolveToken(request).substring(7)); - return userService.update(userId,requestDto,profilePicture); + return ResponseEntity.ok(userService.update(userId,requestDto)); } + + @PutMapping("/health-info") + @Operation(summary = "사용자 건강 정보 업데이트 메서드", description = "사용자의 건강 정보를 업데이트합니다.") + public ResponseEntity updateHealthInfo(@RequestBody HealthInfoReqDto reqDto) throws IOException { + return ResponseEntity.ok(userService.updateHealthInfo(reqDto)); + } + @DeleteMapping("/withdrawal") @Operation(summary = "사용자 탈퇴 메서드", description = "사용자가 탈퇴하는 메서드입니다. ") public ResponseEntity withdrawal(HttpServletRequest request) { diff --git a/src/main/java/com/example/beginnerfitbe/user/domain/User.java b/src/main/java/com/example/beginnerfitbe/user/domain/User.java index b465268..40f3e6b 100644 --- a/src/main/java/com/example/beginnerfitbe/user/domain/User.java +++ b/src/main/java/com/example/beginnerfitbe/user/domain/User.java @@ -1,11 +1,14 @@ package com.example.beginnerfitbe.user.domain; +import com.example.beginnerfitbe.weight.domain.WeightRecord; import jakarta.persistence.*; import lombok.AccessLevel; import lombok.Builder; import lombok.Getter; import lombok.NoArgsConstructor; +import java.util.List; + @Entity @Getter @NoArgsConstructor(access = AccessLevel.PROTECTED) @@ -24,42 +27,68 @@ public class User { private String password; @Column - private String profilePictureUrl; + private String profileUrl; @Column - private String exercisePurpose; + private double height; @Column - private String exercisePart; + private double weight; @Column - private int exerciseTime; + private double targetWeight; + + @Column + private String date; @Column - private int exerciseIntensity; + private String targetDate; + + @Column + private int exerciseTime; + + @ElementCollection + private List exerciseIntensity; + + @ElementCollection + private List exerciseGoals; + + @ElementCollection + private List concernedAreas; + + + @OneToMany(mappedBy = "user", cascade = CascadeType.REMOVE, orphanRemoval = true) + private List weightRecords; @Builder - public User(String email, String name, String password, String profilePictureUrl, String exercisePurpose, String exercisePart, int exerciseTime, int exerciseIntensity) { - this.email=email; + public User(String email, String name, String password, String profileUrl, double height, double weight, double targetWeight, String date, String targetDate, int exerciseTime, List exerciseIntensity, List exerciseGoals, List concernedAreas) { + this.email = email; this.name = name; this.password = password; - this.profilePictureUrl = profilePictureUrl; - this.exercisePurpose=exercisePurpose; - this.exercisePart =exercisePart; - this.exerciseTime=exerciseTime; + this.profileUrl=profileUrl; + this.height = height; + this.weight = weight; + this.date= date; + this.targetWeight = targetWeight; + this.targetDate = targetDate; + this.exerciseTime = exerciseTime; this.exerciseIntensity = exerciseIntensity; + this.exerciseGoals = exerciseGoals; + this.concernedAreas = concernedAreas; } - public void update(String name, String exercisePurpose, String exercisePart, int exerciseTime, int exerciseIntensity) { - this.name=name; - this.exercisePurpose = exercisePurpose; - this.exercisePart= exercisePart; - this.exerciseTime=exerciseTime; + public void updateHealthInfo(double height, double weight, double targetWeight, String date, String targetDate, int exerciseTime, List exerciseIntensity, List exerciseGoals, List concernedAreas) { + this.height = height; + this.weight = weight; + this.targetWeight = targetWeight; + this.date = date; + this.targetDate = targetDate; + this.exerciseTime = exerciseTime; this.exerciseIntensity = exerciseIntensity; + this.exerciseGoals = exerciseGoals; + this.concernedAreas = concernedAreas; } - - public void updatePicture(String newPictureUrl){ - this.profilePictureUrl = newPictureUrl; + public void updateName(String newName){ + this.name= newName; } - } diff --git a/src/main/java/com/example/beginnerfitbe/user/dto/HealthInfoReqDto.java b/src/main/java/com/example/beginnerfitbe/user/dto/HealthInfoReqDto.java new file mode 100644 index 0000000..54923d3 --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/user/dto/HealthInfoReqDto.java @@ -0,0 +1,22 @@ +package com.example.beginnerfitbe.user.dto; + +import lombok.AllArgsConstructor; +import lombok.Getter; + +import java.util.List; + +@Getter +@AllArgsConstructor + +public class HealthInfoReqDto { + private String email; + private double height; + private double weight; + private double targetWeight; + private String date; + private String targetDate; + private int exerciseTime; + private List exerciseIntensity; + private List exerciseGoals; + private List concernedAreas; +} diff --git a/src/main/java/com/example/beginnerfitbe/user/dto/OtherUserDto.java b/src/main/java/com/example/beginnerfitbe/user/dto/OtherUserDto.java index cb5ca46..bfe216f 100644 --- a/src/main/java/com/example/beginnerfitbe/user/dto/OtherUserDto.java +++ b/src/main/java/com/example/beginnerfitbe/user/dto/OtherUserDto.java @@ -4,6 +4,8 @@ import lombok.AllArgsConstructor; import lombok.Getter; +import java.util.List; + @Getter @AllArgsConstructor public class OtherUserDto { @@ -11,22 +13,29 @@ public class OtherUserDto { private Long id; private String email; private String name; - private String exercisePurpose; - private String exercisePart; + private double height; + private double weight; + private double targetWeight; + private String date; + private String targetDate; private int exerciseTime; - private int exerciseIntensity; - private String profilePictureUrl; + private List exercisePurpose; + private List exercisePart; + private List exerciseIntensity; public User toEntity() { return User.builder() - .email(email) .name(name) - .exercisePurpose(exercisePurpose) - .exercisePart(exercisePart) + .height(height) + .weight(weight) + .targetWeight(targetWeight) + .date(date) + .targetDate(targetDate) .exerciseTime(exerciseTime) + .exerciseGoals(exercisePurpose) + .concernedAreas(exercisePart) .exerciseIntensity(exerciseIntensity) - .profilePictureUrl(profilePictureUrl) .build(); } } diff --git a/src/main/java/com/example/beginnerfitbe/user/dto/SignUpReqDto.java b/src/main/java/com/example/beginnerfitbe/user/dto/SignUpReqDto.java index 4c1e85a..9bb8de6 100644 --- a/src/main/java/com/example/beginnerfitbe/user/dto/SignUpReqDto.java +++ b/src/main/java/com/example/beginnerfitbe/user/dto/SignUpReqDto.java @@ -1,6 +1,5 @@ package com.example.beginnerfitbe.user.dto; -import com.example.beginnerfitbe.user.domain.User; import lombok.AllArgsConstructor; import lombok.Getter; @@ -10,21 +9,4 @@ public class SignUpReqDto { private String email; private String name; private String password; - private String exercisePurpose; - private String exercisePart; - private int exerciseTime; - private int exerciseIntensity; - - public User toEntity() { - return User.builder() - .email(email) - .name(name) - .password(password) - .profilePictureUrl(null) - .exercisePurpose(exercisePurpose) - .exercisePart(exercisePart) - .exerciseTime(exerciseTime) - .exerciseIntensity(exerciseIntensity) - .build(); - } } diff --git a/src/main/java/com/example/beginnerfitbe/user/dto/UserDto.java b/src/main/java/com/example/beginnerfitbe/user/dto/UserDto.java index 1965667..40907b7 100644 --- a/src/main/java/com/example/beginnerfitbe/user/dto/UserDto.java +++ b/src/main/java/com/example/beginnerfitbe/user/dto/UserDto.java @@ -3,27 +3,37 @@ import com.example.beginnerfitbe.user.domain.User; import lombok.Data; +import java.util.List; + @Data public class UserDto { private Long id; private String email; private String name; private String password; - private String profilePictureUrl; - private String exercisePurpose; - private String exercisePart; + private double height; + private double weight; + private double targetWeight; + private String date; + private String targetDate; private int exerciseTime; - private int exerciseIntensity; + private List exerciseGoals; + private List concernedAreas; + private List exerciseIntensity; - public UserDto(Long id, String email, String name, String password, String profilePictureUrl, String exercisePurpose, String exercisePart, int exerciseTime, int exerciseIntensity) { + public UserDto(Long id, String email, String name, String password, double height, double weight, double targetWeight, String date, String targetDate, int exerciseTime, List exerciseGoals, List concernedAreas, List exerciseIntensity) { this.id = id; this.email = email; this.name = name; this.password = password; - this.profilePictureUrl = profilePictureUrl; - this.exercisePurpose = exercisePurpose; - this.exercisePart = exercisePart; + this.height = height; + this.weight = weight; + this.targetWeight = targetWeight; + this.date = date; + this.targetDate = targetDate; this.exerciseTime = exerciseTime; + this.exerciseGoals = exerciseGoals; + this.concernedAreas = concernedAreas; this.exerciseIntensity = exerciseIntensity; } @@ -33,10 +43,14 @@ public static UserDto fromEntity(User user) { user.getEmail(), user.getName(), user.getPassword(), - user.getProfilePictureUrl(), - user.getExercisePurpose(), - user.getExercisePart(), + user.getHeight(), + user.getWeight(), + user.getTargetWeight(), + user.getDate(), + user.getTargetDate(), user.getExerciseTime(), + user.getExerciseGoals(), + user.getConcernedAreas(), user.getExerciseIntensity() ); } diff --git a/src/main/java/com/example/beginnerfitbe/user/dto/UserUpdateDto.java b/src/main/java/com/example/beginnerfitbe/user/dto/UserUpdateDto.java index 6d0cc71..cd322ef 100644 --- a/src/main/java/com/example/beginnerfitbe/user/dto/UserUpdateDto.java +++ b/src/main/java/com/example/beginnerfitbe/user/dto/UserUpdateDto.java @@ -6,10 +6,4 @@ @Data public class UserUpdateDto { private String name; - private String exercisePurpose; - private String exercisePart; - private int exerciseTime; - private int exerciseIntensity; - - } diff --git a/src/main/java/com/example/beginnerfitbe/user/service/AuthService.java b/src/main/java/com/example/beginnerfitbe/user/service/AuthService.java index 8279614..5920640 100644 --- a/src/main/java/com/example/beginnerfitbe/user/service/AuthService.java +++ b/src/main/java/com/example/beginnerfitbe/user/service/AuthService.java @@ -10,6 +10,8 @@ import org.springframework.security.crypto.password.PasswordEncoder; import org.springframework.stereotype.Service; +import java.util.ArrayList; + @Service @RequiredArgsConstructor public class AuthService { @@ -21,27 +23,28 @@ public User signUp (SignUpReqDto dto){ String email=dto.getEmail(); String name=dto.getName(); String password=passwordEncoder.encode(dto.getPassword()); - String exercisePurpose = dto.getExercisePurpose(); - String exercisePart =dto.getExercisePart(); - int exerciseTime = dto.getExerciseTime(); - int exerciseIntensity = dto.getExerciseIntensity(); //중복 가입 확인 if(userService.emailCheck(email)){ throw new IllegalArgumentException("이미 등록된 사용자입니다."); } - User user = User.builder() + //회원 기본 정보만 입력 + return User.builder() .email(email) .name(name) .password(password) - .profilePictureUrl(null) - .exercisePurpose(exercisePurpose) - .exercisePart(exercisePart) - .exerciseTime(exerciseTime) - .exerciseIntensity(exerciseIntensity) + .profileUrl(null) + .height(0) + .weight(0) + .targetWeight(0) + .date(null) + .targetDate(null) + .exerciseTime(0) + .exerciseIntensity(new ArrayList<>()) + .concernedAreas(new ArrayList<>()) + .exerciseGoals(new ArrayList<>()) .build(); - return user; } public SignInResDto signIn(SignInReqDto dto) { UserDto userDto = userService.readByEmail(dto.getEmail()); diff --git a/src/main/java/com/example/beginnerfitbe/user/service/UserService.java b/src/main/java/com/example/beginnerfitbe/user/service/UserService.java index 22c284c..46764cf 100644 --- a/src/main/java/com/example/beginnerfitbe/user/service/UserService.java +++ b/src/main/java/com/example/beginnerfitbe/user/service/UserService.java @@ -3,16 +3,15 @@ import com.example.beginnerfitbe.error.StateResponse; import com.example.beginnerfitbe.playlist.service.PlaylistService; -import com.example.beginnerfitbe.s3.util.S3Uploader; import com.example.beginnerfitbe.user.domain.User; +import com.example.beginnerfitbe.user.dto.HealthInfoReqDto; import com.example.beginnerfitbe.user.dto.UserDto; import com.example.beginnerfitbe.user.dto.UserUpdateDto; import com.example.beginnerfitbe.user.repository.UserRepository; +import com.example.beginnerfitbe.weight.service.WeightRecordService; import lombok.RequiredArgsConstructor; -import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; -import org.springframework.web.multipart.MultipartFile; import java.io.IOException; import java.util.List; @@ -24,8 +23,8 @@ public class UserService { private final UserRepository userRepository; - private final S3Uploader s3Uploader; private final PlaylistService playlistService; + private final WeightRecordService weightRecordService; public List list(){ return userRepository.findAll().stream() @@ -35,8 +34,6 @@ public List list(){ public void create(User user) throws IOException { userRepository.save(user); - //플레이리스트 생성 - playlistService.create(user); } public UserDto read(Long id) { @@ -52,63 +49,53 @@ public List me(Long id){ .map(UserDto::fromEntity) .collect(Collectors.toList()); } - //회원정보 수정 - public ResponseEntity update(Long id, UserUpdateDto requestDto, MultipartFile profilePicture) { - try { - User user = userRepository.findById(id).orElseThrow(() -> new IllegalArgumentException("User not found")); - String previousPictureUrl = user.getProfilePictureUrl(); - - boolean createSignal = true; - //정보 업데이트 - if (requestDto.getName() != null && requestDto.getExercisePurpose()!=null && requestDto.getExercisePart()!=null - && requestDto.getExerciseTime()!=0 && requestDto.getExerciseIntensity()!=0 ) { - - //건강정보 안바뀜 -> 플레이리스트 그대로 - if(requestDto.getExercisePurpose().equals(user.getExercisePurpose()) - && requestDto.getExercisePart().equals(user.getExercisePart()) - && requestDto.getExerciseIntensity()==user.getExerciseIntensity() - && requestDto.getExerciseTime()==user.getExerciseTime()){ - createSignal=false; - } - - user.update(requestDto.getName(), requestDto.getExercisePurpose(), requestDto.getExercisePart(), requestDto.getExerciseTime(), requestDto.getExerciseIntensity()); - - } - if (previousPictureUrl != null) { - s3Uploader.delete("User",previousPictureUrl); - } - //사진 업로드 or 변경 - String pictureUrl = null; - if (profilePicture != null && !profilePicture.isEmpty()) { - if (previousPictureUrl != null) { - s3Uploader.delete("User",previousPictureUrl); - } - pictureUrl = s3Uploader.upload(profilePicture, "User"); - } - user.updatePicture(pictureUrl); - userRepository.save(user); - - //플레이리스트 생성 - if(createSignal){ - playlistService.create(user); - } - - return ResponseEntity.ok(StateResponse.builder().code("SUCCESS").message("정보를 성공적으로 업데이트했습니다.").build()); - } catch (Exception e){ - return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(StateResponse.builder().code("ERROR").message("오류가 발생했습니다: " + e.getMessage()).build()); - } + + //건강정보 업데이트 + public StateResponse updateHealthInfo(HealthInfoReqDto dto) throws IOException { + User user = userRepository.findByEmail(dto.getEmail()).orElseThrow(() -> new IllegalArgumentException("User not found")); + + user.updateHealthInfo( + dto.getHeight(), + dto.getWeight(), + dto.getTargetWeight(), + dto.getDate(), + dto.getTargetDate(), + dto.getExerciseTime(), + dto.getExerciseIntensity(), + dto.getExerciseGoals(), + dto.getConcernedAreas() + ); + + userRepository.save(user); + + //플레이리스트 생성 +// playlistService.create(user); + + //몸무게 기록 + weightRecordService.create(user.getId(), user.getWeight()); + + return StateResponse.builder() + .code("SUCCESS") + .message("건강정보가 업데이트 되었습니다.") + .build(); } + public StateResponse update(Long userId, UserUpdateDto dto){ + User user = userRepository.findById(userId).orElseThrow(() -> new IllegalArgumentException("User not found")); + user.updateName(dto.getName()); + + userRepository.save(user); + + return StateResponse.builder() + .code("SUCCESS") + .message("사용자 이름이 업데이트 되었습니다.") + .build(); + + } //회원 탈퇴 public ResponseEntity withdrawal(Long id) { User user = userRepository.findById(id).orElseThrow(() -> new IllegalArgumentException("User not found")); - //버킷 사진 삭제 - String previousPictureUrl = user.getProfilePictureUrl(); - if(previousPictureUrl!=null){ - s3Uploader.delete("User",previousPictureUrl); - } - userRepository.delete(user); return ResponseEntity.ok(StateResponse.builder().code("SUCCESS").message("성공적으로 회원탈퇴 처리되었습니다.").build()); } diff --git a/src/main/java/com/example/beginnerfitbe/weight/controller/WeightRecordController.java b/src/main/java/com/example/beginnerfitbe/weight/controller/WeightRecordController.java new file mode 100644 index 0000000..b20983e --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/weight/controller/WeightRecordController.java @@ -0,0 +1,36 @@ +package com.example.beginnerfitbe.weight.controller; + +import com.example.beginnerfitbe.jwt.util.JwtUtil; +import com.example.beginnerfitbe.weight.service.WeightRecordService; +import io.swagger.v3.oas.annotations.Operation; +import jakarta.servlet.http.HttpServletRequest; +import lombok.RequiredArgsConstructor; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +@RequiredArgsConstructor +@RequestMapping("/users") +public class WeightRecordController { + + private final WeightRecordService weightRecordService; + private final JwtUtil jwtUtil; + + //전체 기록 조회 + @GetMapping("/weight-records") + @Operation(summary = "몸무게 전체 기록 조회", description = "사용자의 전체 몸무게 기록을 조회합니다.") + public ResponseEntity list(HttpServletRequest request) { + Long userId = jwtUtil.getUserId(jwtUtil.resolveToken(request).substring(7)); + return ResponseEntity.ok(weightRecordService.list(userId)); + } + + //전체 기록 조회 + @GetMapping("/recent-weight-records") + @Operation(summary = "최근 5번 몸무게 현황 조회", description = "사용자의 최근 5개 몸무게 기록을 조회합니다.") + public ResponseEntity getRecentWeightRecords(HttpServletRequest request) { + Long userId = jwtUtil.getUserId(jwtUtil.resolveToken(request).substring(7)); + return ResponseEntity.ok(weightRecordService.getRecentWeightRecords(userId)); + } +} diff --git a/src/main/java/com/example/beginnerfitbe/weight/domain/WeightRecord.java b/src/main/java/com/example/beginnerfitbe/weight/domain/WeightRecord.java new file mode 100644 index 0000000..9e4c95e --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/weight/domain/WeightRecord.java @@ -0,0 +1,38 @@ +package com.example.beginnerfitbe.weight.domain; + +import com.example.beginnerfitbe.user.domain.User; +import jakarta.persistence.*; +import lombok.AccessLevel; +import lombok.Builder; +import lombok.Getter; +import lombok.NoArgsConstructor; +import org.springframework.data.annotation.CreatedDate; + +import java.time.LocalDateTime; + +@Entity +@Getter +@NoArgsConstructor(access = AccessLevel.PROTECTED) +public class WeightRecord { + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + private Long id; + + @ManyToOne + @JoinColumn(name = "user_id", nullable = false) + private User user; + + @Column(nullable = false) + @CreatedDate + private LocalDateTime date; + + @Column(nullable = false) + private double weight; + + @Builder + public WeightRecord(User user, LocalDateTime date, double weight) { + this.user = user; + this.date = date; + this.weight = weight; + } +} diff --git a/src/main/java/com/example/beginnerfitbe/weight/dto/WeightRecordDto.java b/src/main/java/com/example/beginnerfitbe/weight/dto/WeightRecordDto.java new file mode 100644 index 0000000..376bd77 --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/weight/dto/WeightRecordDto.java @@ -0,0 +1,33 @@ +package com.example.beginnerfitbe.weight.dto; + +import com.example.beginnerfitbe.weight.domain.WeightRecord; +import lombok.Data; + +import java.time.LocalDateTime; + +@Data +public class WeightRecordDto { + private Long userId; + private String userName; + private LocalDateTime createdAt; + private double weight; + private double targetWeight; + + public WeightRecordDto(Long userId, String userName, LocalDateTime createdAt, double weight, double targetWeight) { + this.userId = userId; + this.userName = userName; + this.createdAt = createdAt; + this.weight = weight; + this.targetWeight =targetWeight; + } + + public static WeightRecordDto fromEntity(WeightRecord weightRecord){ + return new WeightRecordDto( + weightRecord.getUser().getId(), + weightRecord.getUser().getName(), + weightRecord.getDate(), + weightRecord.getWeight(), + weightRecord.getUser().getTargetWeight() + ); + } +} diff --git a/src/main/java/com/example/beginnerfitbe/weight/repository/WeightRecordRepository.java b/src/main/java/com/example/beginnerfitbe/weight/repository/WeightRecordRepository.java new file mode 100644 index 0000000..ac5590d --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/weight/repository/WeightRecordRepository.java @@ -0,0 +1,14 @@ +package com.example.beginnerfitbe.weight.repository; + +import com.example.beginnerfitbe.user.domain.User; +import com.example.beginnerfitbe.weight.domain.WeightRecord; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +import java.util.List; + +@Repository +public interface WeightRecordRepository extends JpaRepository { + List findByUserOrderByDateAsc(User user); + List findTop5ByUserOrderByDateDesc(User user); +} diff --git a/src/main/java/com/example/beginnerfitbe/weight/service/WeightRecordService.java b/src/main/java/com/example/beginnerfitbe/weight/service/WeightRecordService.java new file mode 100644 index 0000000..5a1ca0f --- /dev/null +++ b/src/main/java/com/example/beginnerfitbe/weight/service/WeightRecordService.java @@ -0,0 +1,64 @@ +package com.example.beginnerfitbe.weight.service; + +import com.example.beginnerfitbe.user.domain.User; +import com.example.beginnerfitbe.user.repository.UserRepository; +import com.example.beginnerfitbe.weight.domain.WeightRecord; +import com.example.beginnerfitbe.weight.dto.WeightRecordDto; +import com.example.beginnerfitbe.weight.repository.WeightRecordRepository; +import lombok.RequiredArgsConstructor; +import org.springframework.stereotype.Service; + +import java.time.LocalDateTime; +import java.util.Comparator; +import java.util.List; +import java.util.stream.Collectors; + +@Service +@RequiredArgsConstructor +public class WeightRecordService { + + private final WeightRecordRepository weightRecordRepository; + private final UserRepository userRepository; + + public WeightRecordDto create (Long userId, double weight){ + User user = userRepository.findById(userId).orElseThrow(() -> new IllegalArgumentException("User not found")); + + WeightRecord weightRecord = WeightRecord.builder() + .user(user) + .date(LocalDateTime.now()) + .weight(weight) + .build(); + + weightRecordRepository.save(weightRecord); + + return WeightRecordDto.fromEntity(weightRecord); + } + + //시간순서대로 + public List list(Long userId) { + User user = userRepository.findById(userId).orElseThrow(() -> new IllegalArgumentException("User not found")); + + if(weightRecordRepository.findByUserOrderByDateAsc(user).isEmpty()){ + return null; + } + return weightRecordRepository.findByUserOrderByDateAsc(user).stream() + .map(WeightRecordDto::fromEntity) + .collect(Collectors.toList()); + } + + public List getRecentWeightRecords(Long userId) { + User user = userRepository.findById(userId).orElseThrow(() -> new IllegalArgumentException("User not found")); + + if(weightRecordRepository.findTop5ByUserOrderByDateDesc(user).isEmpty()){ + return null; + } + + List recentWeightRecords = weightRecordRepository.findTop5ByUserOrderByDateDesc(user); + + recentWeightRecords.sort(Comparator.comparing(WeightRecord::getDate)); + + return recentWeightRecords.stream() + .map(WeightRecordDto::fromEntity) + .collect(Collectors.toList()); + } +}