본 포스팅은 패스트캠퍼스 환급 챌린지 참여를 위해 작성하였습니다.
공부 시작 시각 인증
공부 시작 시각 인증
수강 인증 사진
수강 인증 사진
GetPostTableRequestDto.java
package org.fastcampus.admin.ui.dto.posts;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import org.fastcampus.common.domain.*;
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class GetPostTableRequestDto extends Pageable {
private Long postId;
}
GetPostTableResponseDto.java
package org.fastcampus.admin.ui.dto.posts;
import java.time.LocalDateTime;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import org.fastcampus.common.utils.*;
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class GetPostTableResponseDto {
@Getter
private Long postId;
@Getter
private Long userId;
@Getter
private String userName;
private String content;
private LocalDateTime createdAt;
private LocalDateTime updatedAt;
public String getContent() {
if (content.length() > 10) {
return content.substring(0, 10) + "...";
}
return content;
}
public String getCreatedAt() {
return TimeCalculator.getFormattedDate(createdAt);
}
public String getUpdatedAt() {
return TimeCalculator.getFormattedDate(updatedAt);
}
}
AdminTableQueryRepository.java
package org.fastcampus.admin.ui.query;
import org.fastcampus.admin.ui.dto.*;
import org.fastcampus.admin.ui.dto.posts.*;
import org.fastcampus.admin.ui.dto.users.GetUserTableRequestDto;
import org.fastcampus.admin.ui.dto.users.GetUserTableResponseDto;
public interface AdminTableQueryRepository {
GetTableListResponse<GetUserTableResponseDto> getUserTableData(GetUserTableRequestDto dto);
GetTableListResponse<GetPostTableResponseDto> getPostTableData(GetPostTableRequestDto dto);
}
AdminTableQueryRepositoryImpl.java
package org.fastcampus.admin.repository;
import com.querydsl.core.types.Projections;
import com.querydsl.core.types.dsl.BooleanExpression;
import com.querydsl.jpa.impl.JPAQueryFactory;
import java.util.List;
import lombok.RequiredArgsConstructor;
import org.fastcampus.admin.ui.dto.*;
import org.fastcampus.admin.ui.dto.posts.*;
import org.fastcampus.admin.ui.dto.users.GetUserTableRequestDto;
import org.fastcampus.admin.ui.dto.users.GetUserTableResponseDto;
import org.fastcampus.admin.ui.query.AdminTableQueryRepository;
import org.fastcampus.auth.repository.entity.*;
import org.fastcampus.post.repository.entity.post.*;
import org.fastcampus.user.repository.entity.*;
import org.springframework.stereotype.Repository;
@Repository
@RequiredArgsConstructor
public class AdminTableQueryRepositoryImpl implements AdminTableQueryRepository {
private final JPAQueryFactory queryFactory;
private static final QUserAuthEntity userAuthEntity = QUserAuthEntity.userAuthEntity;
private static final QUserEntity userEntity = QUserEntity.userEntity;
private static final QPostEntity postEntity = QPostEntity.postEntity;
@Override
public GetTableListResponse<GetUserTableResponseDto> getUserTableData(
GetUserTableRequestDto dto) {
int total = queryFactory.select(userEntity.id)
.from(userEntity)
.where(likeName(dto.getName()))
.fetch()
.size();
List<Long> ids = queryFactory
.select(userEntity.id)
.from(userEntity)
.where(
likeName(dto.getName())
).orderBy(userEntity.id.desc())
.offset(dto.getOffset())
.limit(dto.getLimit())
.fetch();
List<GetUserTableResponseDto> result = queryFactory
.select(
Projections.fields(
GetUserTableResponseDto.class,
userEntity.id.as("id"),
userAuthEntity.email.as("email"),
userEntity.name.as("name"),
userAuthEntity.role.as("role"),
userEntity.regDt.as("createdAt"),
userEntity.updDt.as("updatedAt"),
userAuthEntity.lastLoginDt.as("lastLoginAt")
)
).from(userEntity)
.join(userAuthEntity).on(userAuthEntity.userId.eq(userEntity.id))
.where(
userEntity.id.in(ids)
).orderBy(userEntity.id.desc())
.fetch();
return new GetTableListResponse<>(total, result);
}
@Override
public GetTableListResponse<GetPostTableResponseDto> getPostTableData(
GetPostTableRequestDto dto) {
int total = queryFactory.select(postEntity.id)
.from(postEntity)
.where(eqPostId(dto.getPostId()))
.fetch()
.size();
List<Long> ids = queryFactory
.select(postEntity.id)
.from(postEntity)
.where(
eqPostId(dto.getPostId())
).orderBy(postEntity.id.desc())
.offset(dto.getOffset())
.limit(dto.getLimit())
.fetch();
List<GetPostTableResponseDto> result = queryFactory
.select(
Projections.fields(
GetPostTableResponseDto.class,
postEntity.id.as("postId"),
userEntity.id.as("userId"),
userEntity.name.as("userName"),
postEntity.content.as("content"),
postEntity.regDt.as("createdAt"),
postEntity.updDt.as("updatedAt")
)
).from(postEntity)
.join(userEntity).on(postEntity.author.id.eq(userEntity.id))
.where(
postEntity.id.in(ids)
).orderBy(postEntity.id.desc())
.fetch();
return new GetTableListResponse<>(total, result);
}
private BooleanExpression likeName(String name) {
if (name == null || name.isEmpty()) {
return null;
}
return userEntity.name.like(name + "%");
}
private BooleanExpression eqPostId(Long id) {
if (id == null) {
return null;
}
return postEntity.id.eq(id);
}
}
AdminController.java
package org.fastcampus.admin.ui;
import lombok.RequiredArgsConstructor;
import org.fastcampus.admin.ui.dto.*;
import org.fastcampus.admin.ui.dto.posts.*;
import org.fastcampus.admin.ui.dto.users.GetUserTableRequestDto;
import org.fastcampus.admin.ui.dto.users.GetUserTableResponseDto;
import org.fastcampus.admin.ui.query.*;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
@RestController
@RequestMapping("/admin")
@RequiredArgsConstructor
public class AdminController {
private final UserStatsQueryRepository userStatsQueryRepository;
private final AdminTableQueryRepository adminTableQueryRepository;
@GetMapping("/index")
public ModelAndView index() {
ModelAndView mav = new ModelAndView("index");
mav.addObject("result", userStatsQueryRepository.getDailyRegisterUserStats(7));
return mav;
}
@GetMapping("/users")
public ModelAndView users(GetUserTableRequestDto dto) {
ModelAndView mav = new ModelAndView("users");
GetTableListResponse<GetUserTableResponseDto> result = adminTableQueryRepository.getUserTableData(dto);
mav.addObject("requestDto", dto);
mav.addObject("result", result.getTableData());
mav.addObject("totalCount", result.getTotalCount());
return mav;
}
@GetMapping("/posts")
public ModelAndView posts(GetPostTableRequestDto dto) {
ModelAndView mav = new ModelAndView("posts");
GetTableListResponse<GetPostTableResponseDto> result = adminTableQueryRepository.getPostTableData(dto);
mav.addObject("requestDto", dto);
mav.addObject("result", result.getTableData());
mav.addObject("totalCount", result.getTotalCount());
return mav;
}
}
학습 인증샷
학습 인증샷
공부 종료 시각 인증
공부 종료 시각 인증
https://bit.ly/4hTSJNB