전체 글
-
GITHUB API를 활용한 커밋 기록 조회 (4) 커밋 히스토리 로직 구현devRace 2024. 11. 14. 19:52
지난 글에서커밋 카운트를 스케줄러로 6시간마다 업데이트하여전체 기간, 현재 월, 현재 주, 오늘의 커밋 카운트를 증가시키는 로직을 구현하였다. 이 글에서는10월 커밋기록이 11월이 되면 해당 기록은 날아가야하는가?11월 1주차의 커밋기록이 2주차 월요일이 되면 해당 기록은 지워져야하는가?오늘한 커밋기록이 내일이 되면 사라져야하는가?에 대해 고민하다 결정한 커밋 히스토리이다. 또한 이렇게 캘린더에 커밋과 알고리즘, TIL 제출 여부를 체크해야 하고, 시간이 지나서도 볼 수 있어야 하므로히스토리 스케줄러를 통해 매월 1일, 매 주 월요일, 매일 0시가 조금 넘은 시간에 이전 기간에 대한 커밋을 저장하도록 하였다. @Transactional @Scheduled(cron = "0 15 0 1 ..
-
GITHUB API를 활용한 커밋 기록 조회 (3) 커밋카운트 로직 적용devRace 2024. 11. 13. 17:18
private long totalCommits; private long monthlyCommits; private long weeklyCommits; private long dailyCommits; 전체 기간 커밋갯수현재 월간 커밋 갯수현재 주간 커밋 갯수오늘 커밋 갯수를 저장하는 엔티티 컬럼을 작성하였다. 간단히 오늘 커밋 갯수를 저장하는 로직만 표시해보겠다. private long getCommitCountFromGithub(String githubName, ZonedDateTime fromDate, ZonedDateTime toDate) { try { return githubApiClient.getCommitCountInperiod(githubName..
-
GITHUB API를 활용한 커밋 기록 조회 (2) GithubApiClient 작성devRace 2024. 11. 12. 16:25
@Componentpublic class GithubApiClient { private final GitHub github; public GithubApiClient(@Value("${github.oauth.token}") String oauthToken) { try { this.github = new GitHubBuilder().withOAuthToken(oauthToken).build(); github.checkApiUrlValidity(); } catch (Exception e) { throw new CustomException(ErrorCode.FAIL_TO_CONNECT_GITHUB); }..
-
GITHUB API를 활용한 커밋 기록 조회 (1) 깃허브 API 적용devRace 2024. 11. 11. 15:32
개요프로젝트에서 개인 깃허브를 연동하여 커밋 갯수를 반환하여커밋 랭킹 및 잔디를 구현하고자 하였다. 진행과정1. 깃허브 API 적용2. GithubApiClient 작성3. 커밋 카운트 로직 구현4. 커밋 히스토리 로직 구현으로 진행하였다. 의존성 추가하기https://mvnrepository.com/artifact/org.kohsuke/github-api 이 곳에서 원하는 버전을 선택한다.최신버전을 사용하기엔 약간 부담되어 누군가 1명이 사용하고 있는 2.0.0-alpha-1을 선택하였다. Gradle을 사용중이었기에 해당 코드를 build.gradle에 입력하였다. 깃허브 토큰 발급이후 깃허브 - Settings - Developer Settings - Personal access toke..
-
데이터베이스 정규화오늘/Today I.. 2024. 4. 7. 22:12
데이터베이스 정규화란? 데이터베이스 설계에서 데이터의 중복을 최소화하고 데이터 무결성을 유지하기 위해 데이터를 구조화하는 과정 이상현상이 있는 릴레이션을 분해하여 이상현상을 제거하여 중복된 데이터를 허용하지 않게 함 결과적으로 데이터 무결성을 유지하고 데이터베이스 저장공간을 확보할 수 있다. 데이터베이스 정규화 절차 일반적으로 제 3 정규형 또는 BCNF까지 진행하면 데이터베이스 설계에 무리가 없다. 제 4, 제 5 정규형까지 가서 중복을 완전히 제거해버릴경우 다른 문제가 발생할 수 있다. 제 1정규형부터 BCNF까지는 기본 정규형 제 4정규형, 제 5정규형은 고급 정규형으로 분류한다. 제 1 정규형 (1NF) 제1 정규형은 모든컬럼의 값이 원자값이어야 한다. 즉, 각 필드는 반드시 하나의 값만을 가져야..