본 모듈은 소스코드 백업 기능은 제공하지 않으며, 소스 코드만 로컬PC로 다운 받으실 분은 아래 [소스 코드 로컬 백업 방법](#소스 코드 로컬 백업 방법) 가이드를 따르시길 바랍니다.
네이버 오픈 프로젝트 이슈/게시판 백업 및 마이그레이션을 위한 Python 모듈입니다. 본 모듈은 네이버 개발자센터의 오픈 프로젝트 의 마이그레이션을 위해 2가지 기능을 제공합니다.
- 네이버 오픈프로젝트 이슈/게시판 백업: 로컬PC에 개인의 오픈 프로젝트 데이터 (이슈/게시판/첨부 파일 포함)를 백업
- Github로 마이그레이션: 로컬PC에 백업한 데이터를 GitHub의 프로젝트로 마이그레이션
소스코드만 저장하실 분은 본 모듈 설치할 필요 없이 아래의 스텝을 따라해주시길 바랍니다.
-
저장소가 git을 사용할 경우에는 http://dev.naver.com/projects/프로젝트이름/src 에 들어가면 보이는
git clone
명령어를 터미널에 입력하시면 됩니다. -
저장소가 svn을 사용할 경우에는 현재 svn이 설치되어 있을 경우 http://dev.naver.com/projects/프로젝트이름/src 에서 설명하는 것처럼
svn checkout
해주시면 되고 svn이 설치되어 있지 않을 경우git svn clone
명령어를 사용해주세요.$ git svn clone --username 네이버아이디 https://dev.naver.com/svn/프로젝트이름 # 이후 프롬프트에서 비밀번호는 http://dev.naver.com/account/ 에 설정한 `코드저장소 비밀번호`를 입력하면 됩니다.
- 코드 저장소를 마이그레이션하는 과정입니다.
- GitHub 저장소 import
- 다음 링크로 이동 https://github.com/new/import/
- GitHub 저장소 import 폼값 입력
Your old repository’s clone URL
에는오픈 프로젝트->코드
탭에서 확인할 수 있는git clone
URL 혹은svn
의 URL을 입력하세요.Your new repository details
아래에Name
에 생성될 저장소 이름을 입력하세요.
- Import를 시작하게 되면 몇 초후 GitHub 화면에 아이디와 비밀번호를 입력하는 폼이 보입니다.
- 오픈 프로젝트가 공개 설정일 경우: 아이디/비밀번호 모두
anonsvn
입력 - 오픈 프로젝트가 비공개 설정일 경우: 네이버 아이디와 비밀번호
- 오픈 프로젝트가 공개 설정일 경우: 아이디/비밀번호 모두
- 코드 저장소 마이그레이션이 끝나면 아래와 같은 메시지가 출력되고, GitHub에 등록하신 메일로 완료 안내가 갑니다.
Importing complete! Your new repository your-id/your-project-name is ready.
본 모듈은 CLI(Comamnd Line Interface) 형태의 모듈로서 Windows, Mac, Linux OS를 모두 지원합니다.
- Python 2.7 이상 ( 커맨드 라인에서 Python 버전확인 방법:
$ python --version
) - Git 1.7.10 이상 ( 커맨드 라인에서 Git 버전확인 방법:
$ git --version
)- 이슈/게시판 첨부파일 업로드에 사용됩니다.
- 1.7.10 미만일 경우 GitHub에 push가 불가능해서 첨부파일 업로드가 불가능합니다.
- pip (pip 설치 유무 확인 방법:
$ pip --version
)
위 3가지 프로그램이 없을 경우는 아래의 가이드를 따라 설치해주시길 바랍니다.
- Windows에서 Python 설치법
- 3.5 이상 버전을 권장합니다.
- 위 링크대로 설치해주시면 됩니다. (pip 포함 설치 및
Add Python 3.5 to PATH
옵션 필수 체크)
- Mac, Linux: 기본적으로 Python이 제공됩니다. 다만
python --version
혹시 2.7 버전 이상이 아니시면 업그레이드 하셔야 합니다.
- Git 공식 홈페이지의 설치 자료를 참고하셔서 설치를 진행하시면 됩니다.
- 설치 완료 후 반드시 최초 설정을 해주셔야 첨부파일 업로드가 가능합니다.
- 간혹 CentOS 6를 이용하시는 분은 기본 yum 저장소에 있는 Git 버전이 낮아 GitHub에 Push가 안 되는 오류가 일어날 수 있습니다. 이 자료를 참고하셔서 Git 버전을 업그레이드 해주세요.
-
위의 설치법을 따라하셨다면 pip가 자동으로 설치되있을 것입니다. 그러나
pip --version
을 실행하셨을 때 오류가 발생하신다면 아래 과정을 따라해주세요.- https://bootstrap.pypa.io/get-pip.py 파일을 다운로드하세요.
cmd
를 켜고get-pip.py
를 다운로드한 곳에서$ python get-pip.py
를 실행하세요.- pip 설치 버전 확인:
$ pip --version
-
간혹 위 과정을 따라하셨는데도
pip
를 실행할 수 없는 경우는 시스템 속성의 환경변수 편집하는 곳에서 시스템 변수의PATH
에 파이썬 설치 경로를 추가해주세요.
- pip 설치 스크립트 다운로드:
$ curl https://bootstrap.pypa.io/get-pip.py > get-pip.py
- pip 설치:
$ sudo python get-pip.py
- pip 설치 버전 확인:
$ pip --version
- Python 및 pip 설치가 확인되셨다면 사용중인 운영체제에 따라 아래 안내를 따라해 주세요.
- 먼저 작업을 수행할 폴더를 만들어주시고 해당 폴더에서 작업을 수행해주세요. (예:
mkdir backup
)
virtualenv
설치 :$ sudo pip install virtualenv
virtualenv
를 통한 가상환경 폴더 생성 :$ virtualenv venv
- 가상환경 활성화
- Windows :
$ venv\Scripts\activate
- Linux, Mac OS:
$ . venv/bin/activate
- 가상환경이 활성화(activate)되고 나면 프롬프트 왼쪽에
(venv)
가 생기게 됩니다.- 예:
(venv) $ ...
(Linux, Mac OS),(venv) C:\Users\maxto>
(WIndows)
- 예:
- Windows :
- 가상환경이 활성화 된 후 운영체제에 따라 아래 안내를 따라주세요.
-
Lxml (XML 파서) 설치파일 다운로드
- http://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml 이 곳에서 운영체제와 파이썬 버전에 맞는 파일을 위에서 생성하신 작업 폴더에 다운로드해주세요.
- 32bit 이신 경우 아래 링크에서 다운로드하시면 됩니다.
-
Lxml (XML 파서) 설치
- 가상환경이 활성화된 상태에서
pip install 다운로드된파일명
실행.
- 가상환경이 활성화된 상태에서
-
마이그레이션 모듈 설치
- 가상환경이 활성화된 상태에서
pip install nforge-migration
실행.
- 가상환경이 활성화된 상태에서
- 가상환경이 활성화 된 상태에서
pip install nforge-migration
실행
-
npa --help
명령어를 입력하셨을 때 터미널에 아래와 같은 화면이 보이면 설치가 완료된 것 입니다.Usage: npa [OPTIONS] Command line interface for parsing Nforge project. Options: --name TEXT 오픈 프로젝트 이름 --private 오픈 프로젝트 비공개 저장소 여부 --dev_code DevCode 프로젝트인지 --help Show this message and exit.
본 모듈은 아래 2가지 기능을 제공합니다.
- 네이버 오픈프로젝트 백업: 로컬PC에 개인의 오픈 프로젝트 데이터 (이슈/게시판/첨부 파일 포함)를 백업
- Github로 마이그레이션: 로컬PC에 백업한 데이터를 GitHub의 프로젝트로 마이그레이션
주의 !! 비공개 프로젝트의 경우는 아래 안내를 필독하세요.
- 네이버 오픈프로젝트가
비공개
상태이면공개
로 전환 후 진행하시거나, 프로젝트 관련 인증키값 데이터를 추출해 저장하신 다음 진행해야 합니다. - 비공개 프로젝트 관련 인증 키값 추출 방법
- 오픈 프로젝트에 로그인 해주세요.
- 웹브라우저 주소창에 직접
javascript:document.cookie
라고 입력하세요. ( Ctrl C / V 하시면 안됩니다.) - 웹브라우저에 보이는 값들 중
NID_SES
와NID_AUT
값을 복사해주세요. - 작업 폴더에
cookies.txt
라는 파일을 만들어주세요. - 아래와 같은 형식으로
cookies.txt
파일을 채워주시고 저장하세요. (쿠키 값의 맨마지막 세미콜론은 지울 것)
NID_SES=키값 NID_AUT=키값
- 터미널에서 설치 과정에서 만든 작업 폴더로 이동하셔서 아래 안내를 따라주세요.
npa
명령어를 아래의 안내와 같이 터미널에 입력해주세요.- 공개 프로젝트:
$ npa --name 프로젝트이름
- 비공개 프로젝트:
$ npa --name 프로젝트이름 --private
- 공개 프로젝트:
중요!!
프로젝트이름
은 만약 프로젝트의 URL이http://dev.naver.com/projects/d2coding/
이라면d2coding
이라고 입력해주시면 됩니다.
-
자동으로 프로젝트들이 다운로드되고 아무 메시지 없이 끝났다면 성공한 것입니다.
-
npa
명령어 동작 화면
Now making 7267.xml and 7267.json of download: 100%|███| 2/2 [00:01<00:00, 1.04s/it]
Now making 98439.xml and 98439.json of issue: 100%|███| 21/21 [00:09<00:00, 2.78it/s]
Now making 98483.xml and 98483.json of forum: 100%|███| 11/11 [00:02<00:00, 3.17it/s]
-
작업 폴더/Nforge/open_project/프로젝트 이름
에 프로젝트들이 다운로드 됩니다. 폴더는 아래와 같은 구조로 구성되어 있습니다. (예:backup/Nforge/open_project/d2coding
)Nforge └── open_project └── 프로젝트 이름 ├── code_info.json # 소스 코드 저장소 정보가 담긴 파일 ├── developers.txt # 개발자들의 네이버 아이디 ├── downloads # 다운로드 저장 폴더 │ ├── json │ ├── raw # 첨부파일 │ └── xml ├── issues # 이슈/게시판 저장 폴더 │ ├── json │ ├── raw # 첨부파일 │ └── xml │ ├── forum # 게시판 XML │ └── issue # 이슈 XML └── milestones # 마일스톤 XML
작업 폴더에서 아래 안내를 차례대로 따라해주세요. GitHub 회원가입을 먼저 해주셔야 합니다.
주의!! 코드 저장소가 없거나 아무 커밋도 하지 않은 프로젝트는 import를 수행하지 마시고 아래 안내를 참고하세요.
- https://github.com/new 로 이동합니다.
Repository name
에 저장소 이름을 입력하고Initialize this repository with a README
체크박스에 체크합니다.Create Repository
를 만들어서 저장소를 생성합니다.- 아래 안내를 참고하셔서 저장소 Wiki 및 엑세스 토큰을 생성해주세요.
위키를 생성하는 이유는 이슈,게시판,댓글의 첨부파일을 업로드하기 위한 것입니다.
- https://github.com/사용자아이디/프로젝트명/wiki 로 접속해서
Create the first page
버튼 클릭 - 페이지 우측 하단에
Save Page
버튼 클릭
- https://github.com/settings/tokens 으로 이동
- 우측 메뉴 상단에
Generate new token
버튼 클릭 후 비번 입력 - 아래 항목들을 입력
Token Description
(토큰 설명, 예:openproject
)- 체크박스들 중에
repo
항목에 체크
- 하단에
Generate token
버튼 클릭 후 나오는 코드값을 복사 - 작업 폴더에
token.txt
라는 파일을 만들고 복사한 토큰을 넣어준 후 저장한다.echo 복사한토큰값 > token.txt
- 본인의 계정에 바로 마이그레이션 하는 경우
ghm --name GitHub저장소이름 --project_name 오픈프로젝트이름
- 특정 Organization의 저장소에 마이그레이션 하는 경우
ghm -name GitHub저장소이름 --project_name 오픈프로젝트 이름 --org_name Organization이름
오픈프로젝트이름
은 위에서 다운로드한 오픈 프로젝트 이름과 일치해야 합니다.GitHub저장소이름
은 위에서 만드신 저장소 이름과 일치해야 합니다.
주의 !! 빠른 시간 내에 많은 마이그레이션을 수행하면 Abuse Rate Limits가 발생해 일시적으로 GitHub API를 호출할 수 없게 됩니다. 몇 분 후에 다시 시도해주세요.
프로젝트의 이슈가 너무 많아서 마이그레이션 진행 중 위에서 말한 제한이 걸려 프로그램이 종료될 경우 GitHub 이슈로 알려주세요.
중요 !! Github에 위키를 만들지 않았다면 첨부파일 업로드 과정이 실패합니다. 위키 생성을 반드시 해주세요.
중요 !! Git 설치 후 최초 설정을 했는지 확인해주세요. 하지 않았다면 첨부파일이 업로드 되지 않습니다. 아래 명령어를 입력해주세요. 상세 설명
-
자신의 이름 입력
$ git config --global user.name "John Doe"
-
자신의 이메일 입력
$ git config --global user.email [email protected]
-
아래의 명령어를 입력해서 이슈 및 게시판 마이그레이션을 시작합니다.
$ ghm --name GitHub저장소이름 --project_name 프로젝트이름
프로젝트이름
은 위에서 다운로드한 프로젝트 이름과 일치해야 합니다.GitHub저장소이름
은 위에서 만드신 GitHub repository 이름과 일치해야 합니다.
-
ghm
명령어 동작 화면
a8b9g3q9c... is valid token # 토큰 검증
53%|█| 17/32 [00:17<00:16, 1.11s/it] # 이슈 업로드
... # Git 메시지 (이슈 첨부파일 업로드 과정)
100%|███| 2/2 [00:08<00:00, 5.34s # 다운로드 마이그레이션
- 위 과정을 거친 후 아무 에러메시지 없이 끝났다면 성공한 것입니다.
-
모두 GitHub Issue로 옮겨집니다.
- 오픈 프로젝트 게시판 ->
forum
라벨 - 오픈 프로젝트 이슈 ->
issue
라벨 - 오픈 프로젝트
foo
게시판/이슈 목록 ->foo
라벨
- 오픈 프로젝트 게시판 ->
-
아래와 같은 형식(마크다운)으로 이슈/게시판/댓글 이 옮겨집니다.
This {issue OR comment} created by **{작성자}** and assigned to **{담당자}** | {작성시간}
------
{이슈 본문}
-----
### Attachments
* {첨부파일명}
![{첨부파일명}]({첨부파일링크})
...
- 이슈/게시판/댓글의 첨부파일은 각 이슈 본문에서 확인할 수 있습니다.
- 프로젝트의 git/SVN 저장소가 GitHub로 옮겨집니다.
- GitHub는 SVN 방식의 디렉토리 구조를 따르지 않으므로 GitHub에서 저장소 구조가 조금 달라보일 수 있습니다.
- GitHub에서 SVN 클라이언트 이용하기
- GitHub의 Releases로 옮겨집니다.
- 버전 라벨이 원래 프로젝트와 조금 다를 수 있지만 순서는 일치합니다.
- 다운로드의 첨부파일도 릴리즈에서 다운로드 가능합니다.
- GitHub의 Wiki로 옮겨집니다.
- 원본 문서 형식 그대로 저장하기 때문에 렌더링이 제대로 되지 않았을 수 있습니다.