Skip to content

Commit

Permalink
Merge pull request #292 from techeer-sv/BE/#291
Browse files Browse the repository at this point in the history
BE/#291 더미 데이터 저장 기능 구현
  • Loading branch information
youKeon authored Nov 9, 2023
2 parents 2327e10 + 555a01b commit e652e2d
Show file tree
Hide file tree
Showing 7 changed files with 140 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@

import javax.persistence.*;

/**
* TODO
* imageUrl 추가
*/
@Entity
@Getter
@Builder
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,16 @@
package com.graphy.backend.domain.project.domain;

import com.graphy.backend.global.common.BaseEntity;
import lombok.*;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;

import javax.persistence.*;

/**
* 삭제
*/
@Entity
@Getter
@Builder
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,10 @@ public class GetProjectDetailResponse implements Serializable {
private String thumbNail;

private List<GetCommentWithMaskingResponse> commentsList;
/**
* TODO
* viewCount 추가
*/

@JsonSerialize(using = LocalDateTimeSerializer.class)
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@
import com.graphy.backend.domain.project.dto.request.UpdateProjectRequest;
import com.graphy.backend.domain.project.dto.response.*;
import com.graphy.backend.domain.project.repository.ProjectRepository;
import com.graphy.backend.domain.project.repository.TagRepository;
import com.graphy.backend.global.chatgpt.dto.GptCompletionDto.GptCompletionRequest;
import com.graphy.backend.global.chatgpt.dto.GptCompletionDto.GptCompletionResponse;
import com.graphy.backend.global.chatgpt.service.GPTChatRestService;
Expand Down Expand Up @@ -56,7 +55,6 @@ public class ProjectService {
private final CommentService commentService;
private final TagService tagService;
private final GPTChatRestService gptChatRestService;
private final TagRepository tagRepository;
private final RedisTemplate<String, Long> redisTemplate;
private final RedisTemplate<String, GetProjectDetailResponse> redisRankingTemplate;
private final String RANKING_KEY = "ranking";
Expand All @@ -65,22 +63,6 @@ public class ProjectService {
private final int END_RANKING = 9;
private int NEXT_RANKING = END_RANKING;


// @PostConstruct
// public void initTag() throws IOException {
// if (tagRepository.existsById(1L))
// return;
// ClassPathResource resource = new ClassPathResource("tag.txt");
// BufferedReader br = new BufferedReader(new InputStreamReader(resource.getInputStream()));
// String s;
//
// while ((s = br.readLine()) != null) {
// Tag tag = Tag.builder().tech(s).build();
// tagRepository.save(tag);
// }
// br.close();
// }

@Transactional
public CreateProjectResponse addProject(CreateProjectRequest dto, Member loginUser) {
Project entity = dto.toEntity(loginUser);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
package com.graphy.backend.domain.project.util;

import com.graphy.backend.domain.comment.repository.CommentRepository;
import com.graphy.backend.domain.member.domain.Member;
import com.graphy.backend.domain.member.repository.MemberRepository;
import com.graphy.backend.domain.project.domain.Project;
import com.graphy.backend.domain.project.domain.ProjectTags;
import com.graphy.backend.domain.project.domain.Tag;
import com.graphy.backend.domain.project.domain.Tags;
import com.graphy.backend.domain.project.repository.ProjectRepository;
import com.graphy.backend.domain.project.repository.TagRepository;
import com.graphy.backend.domain.project.service.ProjectService;
import com.graphy.backend.domain.project.service.TagService;
import lombok.RequiredArgsConstructor;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.core.io.ClassPathResource;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.stereotype.Component;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

@Component
@RequiredArgsConstructor
public class ProjectInitializer implements ApplicationRunner {
private final MemberRepository memberRepository;
private final PasswordEncoder encoder;

private final ProjectRepository projectRepository;
private final ProjectService projectService;

private final CommentRepository commentRepository;

private final TagRepository tagRepository;
private final TagService tagService;

private final RedisTemplate<String, Long> redisTemplate;

@Override
public void run(ApplicationArguments args) throws Exception {
if (tagRepository.existsById(1L)) return;

ClassPathResource resource = new ClassPathResource("tag.txt");
BufferedReader br = new BufferedReader(new InputStreamReader(resource.getInputStream()));

String s;
List<String> tagList = new ArrayList<>();
while ((s = br.readLine()) != null) {
Tag tag = Tag.builder().tech(s).build();
tagList.add(tag.getTech());
tagRepository.save(tag);
}
br.close();

String[] team = new String[]{"Yujin-Baek", "baekhangyeol", "kimhalin", "youKeon", "Mayreeel"};
memberRepository.save(Member.builder()
.email("[email protected]")
.nickname("ADMIN")
.password(encoder.encode("12345"))
.build());

for (int i = 0; i < 5; i++) {
memberRepository.save(Member.builder()
.email(team[i] + "@graphy.com")
.nickname(team[i])
.password(encoder.encode("12345"))
.build());
}

int randomNumber = (int) (Math.random() * 4) + 3;
List<Member> members = memberRepository.findAll();
for (int i = 1; i <= 100; i++) {
Tags tags = null;
for (int j = 0; j < randomNumber; j++) {
Collections.shuffle(tagList);
tags = tagService.findTagListByName(tagList.subList(0, 3 + (int) (Math.random() * 4)));
}

Project project = Project.builder()
.member(members.get((int) (Math.random() * 5) + 1))
.projectName("Project" + i)
.description("Description" + i)
.viewCount(30 + (int) (Math.random() * (900 - 30 + 1)))
.content("Content" + i)
.thumbNail("ThumbNail" + i)
.projectTags(new ProjectTags())
.build();
project.addTag(tags);
projectRepository.save(project);
// for (int j = 0; j < 10; j++) {
// for (int k = 0; k < (Math.random() * 5) + 1; k++) {
//
// }
// commentRepository.save(Comment.builder()
// .parent(null)
// .project(project)
// .member(members.get((int) (Math.random() * 5) + 1))
// .childList()
// .content("comment" + j)
// .build());
// }
}

// Redis Sorted Set에 데이터 저장
List<Project> projects = projectRepository.findAll();
for (Project p : projects) {
redisTemplate.opsForZSet().incrementScore("ranking", p.getId(), p.getViewCount());
}

// Redis에 상위 10개 프로젝트 저장
projectService.initializeProjectRanking();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,10 @@ public ResponseEntity<ResultResponse> recruitmentDetails(@PathVariable Long recr
return ResponseEntity.ok(ResultResponse.of(ResultCode.RECRUITMENT_GET_SUCCESS, result));
}

/**
* 모집 여부 필터링
* 모집 중 필터링
*/
@Operation(summary = "findRecruitmentList", description = "구인 게시글 조회")
@GetMapping
public ResponseEntity<ResultResponse> recruitmentList(@RequestParam(required = false) List<Position> positions,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
import java.time.LocalDateTime;
import java.util.List;

/**
* 조회수 속성 추가
*/
@Entity
@Getter
@Builder
Expand Down

0 comments on commit e652e2d

Please sign in to comment.