Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/#12 #13

Merged
merged 3 commits into from
Apr 6, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RequiredArgsConstructor
@RequestMapping("/board")
@RestController
Expand All @@ -14,15 +16,26 @@ public class BoardController {
private final BoardService boardService;

@GetMapping("/{boardId}")
public String getBoard(@PathVariable("boardId") Long boardId) {
return "단일 쑰회 정보 " + boardId;
public AddBoardResponseDto getBoard(@PathVariable("boardId") Long boardId) {
return boardService.getBoard(boardId);
}

@GetMapping("/boards")
public String getBoards() {
return "λͺ©λ‘ 쑰회 정보";
public List<AddBoardResponseDto> getMyBoards() {
// μ‚¬μš©μžκ°€ μž‘μ„±ν•œ 일지 λͺ©λ‘ 쑰회
Long memberId = 1L; // TODO 인증
return boardService.getMyBoards(memberId);
}

// TODO μ‚¬μš©μžκ°€ 보지 μ•Šμ€ κΈ€ μ€‘μ—μ„œ 랜덀 3개 골라 μ£ΌκΈ°
@GetMapping("/random")
public List<AddBoardResponseDto> getRandomBoards() {
// μ‚¬μš©μžκ°€ μž‘μ„±ν•œ 일지 λͺ©λ‘ 쑰회
// TODO api 호좜 μ‹œμ λ§ˆλ‹€ 랜덀x. 12μ‹œμ— μ‚¬μš©μžκ°€ 읽지 μ•Šμ€ 글을 today_user_table에 μ €μž₯ν•œλ‹€. μ „λ‚  건 μ‚­μ œ
// todo apiλŠ” today_user_table 에 μžˆλŠ” 정보λ₯Ό read. 계산 x
Long memberId = 1L; // TODO 인증
return boardService.getRandomBoards(memberId);
}

@PostMapping
public AddBoardResponseDto addBoard(@RequestBody AddBoardRequestDto addBoardRequestDto) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
package com.unit.daybook.domain.board.dto.request;


public record AddBoardRequestDto(String content, Long respectBoardId) {
public record AddBoardRequestDto(String content, Long respectBoardId, String category, Long hearts) {
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,15 @@
public record AddBoardResponseDto(
Long boardId,
String content,
Long respectBoardId
Long respectBoardId,
Long authorId,
String category,
Long hearts

) {

public static AddBoardResponseDto from(Board board) {
return new AddBoardResponseDto(board.getBoardId(), board.getContent(), board.getRespectBoardId());
return new AddBoardResponseDto(board.getBoardId(), board.getContent(), board.getRespectBoardId(), board.getMemeber().getId(), board.getCategory(), board.getHearts());
}

}
24 changes: 22 additions & 2 deletions src/main/java/com/unit/daybook/domain/board/entity/Board.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import com.unit.daybook.domain.board.dto.request.AddBoardRequestDto;
import com.unit.daybook.domain.common.model.BaseTimeEntity;
import com.unit.daybook.domain.member.domain.Member;
import jakarta.persistence.*;
import lombok.*;

Expand All @@ -20,22 +21,41 @@ public class Board extends BaseTimeEntity {
@Column
private String content;

@Column
private String category;

@Column(name = "respect_board_id")
private Long respectBoardId;

@ManyToOne
@JoinColumn(name = "member_id")
private Member memeber;

@Column
private Long hearts;

@Builder(access = AccessLevel.PRIVATE)
public Board(Long boardId, String content, Long respectBoardId) {
public Board(Long boardId, String content, Long respectBoardId, Member member, String category, Long hearts) {
this.boardId = boardId;
this.content = content;
this.respectBoardId = respectBoardId;
this.memeber = member;
this.category = category;
this.hearts = hearts;
}

public static Board createBoard(AddBoardRequestDto addBoardRequestDto) {
public static Board createBoard(AddBoardRequestDto addBoardRequestDto, Member member) {
return Board.builder()
.content(addBoardRequestDto.content())
.respectBoardId(addBoardRequestDto.respectBoardId())
.member(member)
.category(addBoardRequestDto.category())
.hearts(0L) // todo
.build();
}

public void plusRespect() {
this.hearts += 1;
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package com.unit.daybook.domain.board.entity;

import com.unit.daybook.domain.common.model.BaseTimeEntity;
import com.unit.daybook.domain.member.domain.Member;
import jakarta.persistence.*;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.NoArgsConstructor;

@Getter
@Entity
@Table(name = "read_board")
@NoArgsConstructor(access = AccessLevel.PROTECTED)
class ReadBoard extends BaseTimeEntity {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "read_board_id")
private Long readBoardId;

@ManyToOne
@JoinColumn(name = "member_id")
private Member member;

@ManyToOne
@JoinColumn(name = "board_id")
private Board board;

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package com.unit.daybook.domain.board.repository;


public interface BoardRepositoryCustom {
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package com.unit.daybook.domain.board.repository;

import com.querydsl.jpa.impl.JPAQueryFactory;
import com.unit.daybook.domain.board.entity.Board;
import com.unit.daybook.domain.board.entity.QBoard;
import com.unit.daybook.domain.member.domain.QMember;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Repository;

import java.util.List;

import static com.unit.daybook.domain.board.entity.QBoard.board;
import static com.unit.daybook.domain.member.domain.QMember.member;

@Repository
@RequiredArgsConstructor
public class BoardRepositoryImpl implements BoardRepositoryCustom {
private final JPAQueryFactory queryFactory;

public List<Board> findBoardsByMemberId(Long memberId) {

List<Board> boards = queryFactory
.select(board)
.from(board)
.join(board.memeber, member).fetchJoin()
.where(
member.id.eq(memberId)
)
.fetch();

return boards;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,52 @@
import com.unit.daybook.domain.board.entity.Board;
import com.unit.daybook.domain.board.repository.BoardRepository;

import com.unit.daybook.domain.board.repository.BoardRepositoryImpl;
import com.unit.daybook.domain.member.domain.Member;
import com.unit.daybook.domain.member.repository.MemberRepository;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;
import java.util.stream.Collectors;

@Transactional
@Service
@RequiredArgsConstructor
public class BoardService {

private final BoardRepository boardRepository;
private final BoardRepositoryImpl boardRepositoryImpl;
private final MemberRepository memberRepository;

public AddBoardResponseDto addBoard(AddBoardRequestDto addBoardRequestDto, Long memberId) {
return AddBoardResponseDto.from(boardRepository.save(Board.createBoard(addBoardRequestDto)));
Member member = memberRepository.findById(memberId).orElseThrow(() -> new RuntimeException(memberId + "not found"));
if (addBoardRequestDto.respectBoardId() != null) {
Board respectBoard = boardRepository.findById(addBoardRequestDto.respectBoardId()).orElseThrow(() -> new RuntimeException(addBoardRequestDto.respectBoardId() + "not found"));
respectBoard.plusRespect();
boardRepository.save(respectBoard);
}
// κΈ€μ˜ 카운트 올리기.. redis..?

return AddBoardResponseDto.from(boardRepository.save(Board.createBoard(addBoardRequestDto, member)));
}


public AddBoardResponseDto getBoard(Long boardId) {
return AddBoardResponseDto.from(
boardRepository.findById(boardId).orElseThrow(() -> new RuntimeException(boardId + "not found")));
}

public List<AddBoardResponseDto> getMyBoards(Long memberId) {
// TODO νŽ˜μ΄μ§€λ„€μ΄μ…˜ - μŠ€μ™€μ΄ν”„ 방식?
return boardRepositoryImpl.findBoardsByMemberId(memberId)
.stream()
.map(AddBoardResponseDto::from)
.toList();
}

public List<AddBoardResponseDto> getRandomBoards(Long memberId) {
return null;
}
}
Original file line number Diff line number Diff line change
@@ -1,17 +1,13 @@
package com.unit.daybook.domain.member.domain;

import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;

import com.unit.daybook.domain.board.entity.Board;
import com.unit.daybook.domain.common.model.BaseTimeEntity;

import jakarta.persistence.Column;
import jakarta.persistence.Embedded;
import jakarta.persistence.Entity;
import jakarta.persistence.EnumType;
import jakarta.persistence.Enumerated;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.*;
import lombok.AccessLevel;
import lombok.Builder;
import lombok.Getter;
Expand Down Expand Up @@ -40,6 +36,8 @@ public class Member extends BaseTimeEntity {

private LocalDateTime lastLoginAt;

@OneToMany(fetch = FetchType.LAZY)
private List<Board> boards = new ArrayList<>();

@Builder(access = AccessLevel.PRIVATE)
private Member(
Expand All @@ -64,6 +62,7 @@ public static Member createNormalMember(OauthInfo oauthInfo, String nickname) {
.build();
}


public void updateLastLoginAt() {
this.lastLoginAt = LocalDateTime.now();
}
Expand Down
Loading