velog 글 작성 시, 자동으로 github에 커밋하기

gosu·2024년 1월 18일
59

automation series

목록 보기
2/2
post-thumbnail
post-custom-banner

velog to github

  • https://github.com/rimgosu/velog
  • 다음 레포지토리와 동일하게 셋팅 후, python 파일에서 자기 벨로그 주소를 적고, 권한 설정만 해주면 벨로그에 쓴 글을 자동으로 깃허브에 작성해준다.
  • ✅ (24-01-23) 실제로 테스트 해보면 한국 시간 자정이 아닌, 미국 시간 자정으로 업로드 됩니다. 오전 9시 20분쯤 자동으로 업로드 되네요.

1. github 새 레포지토리 만들기

  • public으로 다음과 같이 폴더를 구성해주고, github action을 위한 준비를 해주자.
your-github-repo/
├── .github/
│   └── workflows/
│       └── update_blog.yml
├── scripts/
│   └── update_blog.py
└── ...

2. github action 작성

  • update_blog.yml
name: Update Blog Posts
  

on:
  push:
      branches:
        - master  # 또는 워크플로우를 트리거하고 싶은 브랜치 이름
  schedule:
    - cron: '0 0 * * *'  # 매일 자정에 실행

jobs:
  update_blog:
    runs-on: ubuntu-latest

    steps:
    - name: Checkout
      uses: actions/checkout@v2

    - name: Push changes
      run: |
        git config --global user.name 'github-actions[bot]'
        git config --global user.email 'github-actions[bot]@users.noreply.github.com'
        git push https://${{ secrets.GH_PAT }}@github.com/rimgosu/velog.git

    - name: Set up Python
      uses: actions/setup-python@v2
      with:
        python-version: '3.x'

    - name: Install dependencies
      run: |
        pip install feedparser gitpython

    - name: Run script
      run: python scripts/update_blog.py
  • 매일 자정 또는 해당 레포지토리가 push 될 때 파이썬 스크립트를 실행하는 코드이다.

3. 파이썬 스크립트 작성

  • update_blog.py
import feedparser
import git
import os

# 벨로그 RSS 피드 URL
# example : rss_url = 'https://api.velog.io/rss/@rimgosu'
rss_url = 'https://api.velog.io/rss/@[벨로그 아이다]'

# 깃허브 레포지토리 경로
repo_path = '.'

# 'velog-posts' 폴더 경로
posts_dir = os.path.join(repo_path, 'velog-posts')

# 'velog-posts' 폴더가 없다면 생성
if not os.path.exists(posts_dir):
    os.makedirs(posts_dir)

# 레포지토리 로드
repo = git.Repo(repo_path)

# RSS 피드 파싱
feed = feedparser.parse(rss_url)

# 각 글을 파일로 저장하고 커밋
for entry in feed.entries:
    # 파일 이름에서 유효하지 않은 문자 제거 또는 대체
    file_name = entry.title
    file_name = file_name.replace('/', '-')  # 슬래시를 대시로 대체
    file_name = file_name.replace('\\', '-')  # 백슬래시를 대시로 대체
    # 필요에 따라 추가 문자 대체
    file_name += '.md'
    file_path = os.path.join(posts_dir, file_name)

    # 파일이 이미 존재하지 않으면 생성
    if not os.path.exists(file_path):
        with open(file_path, 'w', encoding='utf-8') as file:
            file.write(entry.description)  # 글 내용을 파일에 작성

        # 깃허브 커밋
        repo.git.add(file_path)
        repo.git.commit('-m', f'Add post: {entry.title}')

# 변경 사항을 깃허브에 푸시
repo.git.push()

4. PAT 권한 받기

  1. github 계정 - Settings - Developer Settings - Personal access tokens (classic) - Generate New Token - 이름 쓰고 repo, workflow 클릭 - Generate new token
  2. 받은 토큰 복사 (한 번 보여주고 그 뒤로 보여주지 않으므로 꼭 복사해놓자)
  3. 위에서 생성한 레포지토리 - Settings - Actions secrets and variables - Actions - New Repository Secret
  4. Name : GH_PAT, Secret : [2번에서 발급받은 토큰]

5. 커밋 또는 자정까지 기다리기

  • 레포지토리에 push를 진행하면 github action이 발동하여 다음과 같이 velog-posts 폴더에 자동으로 벨로그 최근 포스팅 내용이 .md 파일로 저장되는 것을 볼 수 있다.

profile
개발자 블로그 ^0^
post-custom-banner

6개의 댓글

comment-user-thumbnail
2024년 1월 23일

와 너무 좋네요! 근데 혹시.. 제가 아는 그 하스스톤 림고수님인가요?

2개의 답글
comment-user-thumbnail
2024년 1월 24일

오오 감사합니다

답글 달기
comment-user-thumbnail
2024년 2월 29일

안녕하세요! POST 잘 읽었습니다!!! 혹시 velog에 있는 모든 POST를 가져오는 방법 아시나요?? 같은 것만 일부 가져오는 것 같아서요ㅠㅠ

1개의 답글