GitHub REST API로 한국 법령·판례를 조회하는 CLI — 클론 없이, 인증 없이 바로 사용.
legalize-kr 미러에서 한국 법령 및 법원 판례를 직접 명령줄로 조회합니다. LLM/에이전트 소비(--json 지원)와 사람이 직접 탐색하는 용도 모두를 위해 설계되었습니다.
Python 3.10+가 필요합니다.
# 권장: 격리 설치
pipx install legalize-cli
# venv 또는 CI 내부
pip install legalize-cli
# 설치 없이 바로 실행
uvx legalize-cli laws list --json# 법률 목록 조회 (JSON, 처음 5개)
legalize laws list --category 법률 --json | jq '.items[:5]'
# 민법 전문 조회 (2015-06-01 기준)
legalize laws get 민법 --date 2015-06-01
# 민법 특정 조문 조회
legalize laws article 민법 제839조의2 --date 2015-06-01 --json
# 민법 두 시점 비교 (조문별 변경 내역)
legalize laws diff 민법 민법 --date-a 2015-01-01 --date-b 2024-01-01 --mode article
# 법령에서 키워드 검색
legalize search "부동산 점유취득시효" --in laws --jsonGitHub API는 인증 없이 시간당 60회 요청만 허용합니다. 토큰을 사용하면 시간당 5,000회로 늘어납니다.
| 상태 | 요청 한도 |
|---|---|
| 미인증 (기본) | 60 req/hr (IP당) |
| GitHub 토큰 사용 | 5,000 req/hr |
명령당 소비 요청 수:
| 명령 | 소비 요청 수 (콜드) |
|---|---|
laws list |
1회 (이후 1시간 캐시) |
laws get <name> --date D |
2회 (커밋 조회 + 파일 조회) |
laws diff A B |
4회 (as-of 해석 2회 × 2) |
search --heavy-content-scan |
최대 N회 (후보 수만큼); 토큰 없으면 --yes-exhaust-quota 필요 |
방법 1: GitHub CLI 사용 (가장 간단)
# GitHub CLI 설치 후 로그인
gh auth login
# 현재 로그인된 토큰을 환경변수로 설정
export GITHUB_TOKEN=$(gh auth token)방법 2: Personal Access Token (PAT) 직접 발급
- GitHub → Settings → Developer settings → Personal access tokens → Tokens (classic) 접속
- "Generate new token (classic)" 클릭
- Note:
legalize-cli입력 - 권한 선택:
public_repo스코프만 체크 (공개 저장소 읽기 전용으로 충분) - 생성된 토큰을 복사
# 환경변수로 설정 (셸 프로파일에 추가 권장)
export GITHUB_TOKEN=ghp_xxxxxxxxxxxxxxxxxxxx방법 3: Fine-grained Personal Access Token (더 안전)
- GitHub → Settings → Developer settings → Personal access tokens → Fine-grained tokens 접속
- "Generate new token" 클릭
- Repository access: "Public Repositories (read-only)" 선택
- 별도 권한 추가 없이 생성
export GITHUB_TOKEN=github_pat_xxxxxxxxxxxxxxxxxxxx우선순위 순서로 세 가지 방식을 지원합니다:
# 1순위: 매 명령에 직접 전달
legalize laws list --token ghp_xxxx
# 2순위: 표준 환경변수 (권장)
export GITHUB_TOKEN=ghp_xxxx
legalize laws list
# 3순위: legalize-cli 전용 환경변수
export LEGALIZE_GITHUB_TOKEN=ghp_xxxx
legalize laws list셸 프로파일(~/.bashrc, ~/.zshrc)에 추가하면 매번 설정할 필요가 없습니다:
echo 'export GITHUB_TOKEN=$(gh auth token)' >> ~/.zshrclegalize auth status --json출력 예시:
{
"schema_version": "1.0",
"kind": "auth.status",
"token_present": true,
"token_source": "GITHUB_TOKEN",
"token_preview": "ghp_…****",
"rate_limit": {
"limit": 5000,
"remaining": 4987,
"used": 13,
"reset": "2024-01-15T11:00:00+09:00"
}
}Claude Desktop, Cursor 등 MCP 지원 클라이언트에 legalize-kr을 tool로 등록할 수 있습니다.
pip install 'legalize-cli[mcp]'
# 또는
pipx install 'legalize-cli[mcp]'| Tool | 설명 |
|---|---|
laws_list |
법령 목록 조회 (카테고리·페이지 필터) |
laws_get |
법령 전문 조회 (날짜 기준) |
laws_article |
특정 조문 조회 (제839조 등) |
search |
법령·판례 키워드 검색 |
precedents_list |
판례 목록 조회 (법원·사건종류 필터) |
precedents_get |
판례 전문 조회 (사건번호·판례일련번호) |
~/Library/Application Support/Claude/claude_desktop_config.json 에 추가:
{
"mcpServers": {
"legalize-kr": {
"command": "legalize-mcp",
"env": {
"GITHUB_TOKEN": "ghp_xxxxxxxxxxxxxxxxxxxx"
}
}
}
}legalize-mcp 대신 legalize mcp serve를 사용하는 경우:
{
"mcpServers": {
"legalize-kr": {
"command": "legalize",
"args": ["mcp", "serve"],
"env": {
"GITHUB_TOKEN": "ghp_xxxxxxxxxxxxxxxxxxxx"
}
}
}
}.cursor/mcp.json 또는 .vscode/mcp.json:
{
"servers": {
"legalize-kr": {
"type": "stdio",
"command": "legalize-mcp",
"env": {
"GITHUB_TOKEN": "ghp_xxxxxxxxxxxxxxxxxxxx"
}
}
}
}# stdio 서버 직접 실행
legalize mcp serve
# 또는 단축 엔트리포인트
legalize-mcpMCP 서버 등록 후 Claude에게 자연어로 질문할 수 있습니다:
"민법 제750조 조문을 알려줘" "부동산 점유취득시효 관련 판례를 검색해줘" "근로기준법이 2020년과 2024년 사이에 어떻게 바뀌었는지 확인해줘"
MCP 서버는 환경변수를 자동으로 읽습니다. env 설정에 GITHUB_TOKEN을 추가하거나 시스템 환경변수로 미리 설정해두면 됩니다. 토큰 없이도 동작하지만 시간당 60회 제한이 있습니다 (토큰 사용 시 5,000회).
토큰 발급 방법:
# 방법 1: GitHub CLI (가장 간단)
gh auth login
export GITHUB_TOKEN=$(gh auth token)GitHub CLI가 없다면 직접 발급합니다:
- GitHub → Settings → Developer settings → Personal access tokens → Tokens (classic) 접속
- "Generate new token (classic)" 클릭
- 권한:
public_repo스코프만 체크 (공개 저장소 읽기 전용으로 충분) - 생성된 토큰을
claude_desktop_config.json의env.GITHUB_TOKEN에 입력
더 안전한 Fine-grained token을 사용하려면 GitHub → Settings → Developer settings → Personal access tokens → Fine-grained tokens에서 "Public Repositories (read-only)" 권한으로 생성합니다. 자세한 내용은 GitHub 토큰 설정 섹션을 참고하세요.
legalize laws list [--category 법률|시행령|시행규칙|대통령령|all] [--page N] [--page-size M] [--json]JSON 응답: {"schema_version": "1.0", "kind": "laws.list", "total": N, "items": [{"name", "path", "category"}], ...}
특정 날짜 기준으로 유효한 법령을 나열합니다 (기본값: 오늘, KST).
legalize laws as-of [--date YYYY-MM-DD] [--category 법률|...] [--include-repealed] [--semantic 공포일자|시행일자] [--json]legalize laws get <법령명> [--category 법률|시행령|...] [--date YYYY-MM-DD] [--json]JSON 응답: {"schema_version": "1.0", "kind": "laws.get", "law", "resolved_commit_date", "frontmatter", "body"}
legalize laws article <법령명> <조문번호> [--category X] [--date YYYY-MM-DD] [--json]조문번호 형식 모두 허용: 제839조, 839, 839조의2, 839-2, 제839조의2
JSON 응답: {"schema_version": "1.0", "kind": "laws.article", "article_no": {"조": "839", "의": "2", "항": null, "호": null}, "status", "annotations", "content", "parent_structure"}
주로 동일 법령의 시점 간 변경을 비교합니다.
legalize laws diff <법령-a> <법령-b> [--date-a D] [--date-b D] [--mode unified|side-by-side|article] [--json]article 모드 상태값: modified | added | removed | renamed | whitespace-only
legalize precedents list [--court 대법원|하급심] [--type 민사|형사|가사|...] [--page N] [--page-size M] [--json]사건번호, 판례일련번호, 또는 경로로 단일 판례를 조회합니다.
legalize precedents get <사건번호|path> [--json]법령 및/또는 판례 전체에서 키워드를 검색합니다.
legalize search <키워드> [--in laws|precedents|all] [--strategy auto|code|tree|metadata] [--json]검색 전략:
code: GitHub 코드 검색 (토큰 필수, 가장 정확)tree: 토큰 없이 경로명 매칭 (빠름)metadata: 판례 인덱스 검색 (캐시 후 API 비용 0)auto: 토큰 유무에 따라 자동 선택
legalize cache info [--json]
legalize cache clear [--older-than 7d] [--yes]legalize auth status [--json]# 2015년과 2024년의 재산분할 관련 조문 비교
legalize laws diff 민법 민법 \
--date-a 2015-01-01 \
--date-b 2024-01-01 \
--mode article \
--json | jq '.articles[] | select(.status == "modified")'# 민법 제839조의2 전문을 JSON으로 가져와서 LLM 컨텍스트로 사용
legalize laws article 민법 제839조의2 --json | jq '{
조문: .article_no,
상태: .status,
기준일: .resolved_commit_date,
본문: .content
}'# 판례 메타데이터 인덱스에서 검색 (API 비용 없음)
legalize search "부동산 점유취득시효" --in precedents --strategy metadata --json | \
jq '.items[:5] | .[] | {사건번호: .사건번호, 법원: .법원명, 날짜: .선고일자}'# GitHub 코드 검색으로 법령 본문에서 키워드 검색 (토큰 필수)
export GITHUB_TOKEN=$(gh auth token)
legalize search "개인정보 처리" --in laws --strategy code --json | jq '.items'# 근로기준법 현재 전문 확인
legalize laws get 근로기준법
# 5년 전 시점과 비교
legalize laws diff 근로기준법 근로기준법 \
--date-a 2019-01-01 \
--date-b 2024-01-01 \
--mode unified# 2020-01-01 기준 시행 중인 법률 목록 (시행일자 기준)
legalize laws as-of --date 2020-01-01 --semantic 시행일자 --category 법률 --json | \
jq '.items | length'# 캐시된 데이터만 사용 (네트워크 차단 환경에서 유용)
legalize laws get 민법 --offline
legalize search "손해배상" --in precedents --offline --json# 대법원 판례 목록에서 민사 판례 5개 확인
legalize precedents list --court 대법원 --type 민사 --page-size 5 --json
# 사건번호로 특정 판례 조회
legalize precedents get "2022다12345" --json# .github/workflows/law-check.yml
- name: 법령 최신 상태 확인
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
uvx legalize-cli laws get 개인정보보호법 --json > current-law.json# 자주 사용하는 법령 미리 캐시
for law in 민법 형법 상법 근로기준법 개인정보보호법; do
legalize laws get "$law" > /dev/null
echo "$law 캐시 완료"
done| 플래그 | 설명 |
|---|---|
--json |
기계가 읽기 쉬운 JSON 출력 (안정적 스키마) |
--token <t> |
$GITHUB_TOKEN 환경변수를 직접 덮어씀 |
--no-cache |
디스크 캐시 우회 |
--cache-dir <p> |
캐시 디렉터리 경로 직접 지정 |
--offline |
네트워크 호출 거부; 캐시만 읽음 |
-v / -vv |
stderr에 로그 상세도 증가 |
모든 --json 출력에 "schema_version": "1.0"이 포함됩니다.
- 마이너 버전 증가 (1.0 → 1.1): 필드 추가만 — 1.x 소비자는 계속 동작
- 메이저 버전 증가 (1.0 → 2.0): 파괴적 변경
CI에서 tests/unit/test_json_schema_version.py로 강제 검증합니다.
| 코드 | 의미 |
|---|---|
| 0 | 성공 |
| 1 | 일반 오류 |
| 4 | 해당 날짜에 없음 |
| 5 | 불명확한 헤딩 레벨 (파서) |
| 6 | 조문을 찾을 수 없음 |
| 7 | Rate limit 초과 / 인증 필요 |
| 8 | 파서 오류 |
| 9 | 오프라인 모드이나 네트워크 필요 |
위치: ~/.cache/legalize-cli/ ($XDG_CACHE_HOME/legalize-cli/ 또는 $LEGALIZE_CLI_CACHE_DIR로 변경 가능)
| 서브디렉터리 | TTL | 내용 |
|---|---|---|
trees/ |
1시간 | 저장소 트리 목록 |
commits/ |
10분 | 경로별 커밋 목록 |
contents/ |
7일 | 법령/판례 마크다운 (경로 + author_date 키) |
precedent-index/ |
24시간 | precedent-kr/metadata.json (~34MB) |
search/ |
1시간 | 코드 검색 결과 |
etag/ |
7일 | 조건부 재검증용 ETag 본문 |
legalize-kr과 precedent-kr 저장소는 파이프라인이 이력을 재구성할 때 주기적으로 force-push됩니다. 이 도구는 캐시 데이터를 커밋 SHA가 아닌 (path, author_date) 기준으로 주소를 지정합니다. 경로별 핑거프린트가 재빌드 후 콘텐츠 변경을 감지하고 오래된 캐시 항목을 자동으로 무효화합니다.
"Rate limit exceeded"
export GITHUB_TOKEN=$(gh auth token)
# 또는 GitHub에서 PAT 발급 후:
export GITHUB_TOKEN=ghp_xxxxxxxxxxxxxxxxxxxx"Code search requires authentication"
# 토큰 없이 검색하려면 전략을 명시적으로 지정
legalize search "키워드" --strategy tree # 경로명 매칭
legalize search "키워드" --strategy metadata # 판례 인덱스만오래된 캐시
legalize cache clear
# 또는 특정 기간 이전 캐시만 삭제
legalize cache clear --older-than 1d --yescd cli-tools
pip install -e ".[dev]"
pytest테스트는 실제 GitHub API를 매번 호출하지 않고 tests/fixtures/cassettes/에 녹화된 HTTP 응답을 재생합니다. API 응답 형식이 바뀌거나 새 테스트 케이스를 추가할 때 실제 네트워크로 재녹화합니다.
LEGALIZE_CLI_LIVE=1 ./scripts/record-cassettes.sh라이브 테스트만 별도로 실행하려면:
LEGALIZE_CLI_LIVE=1 pytest tests/live/| 패키지 | 용도 |
|---|---|
typer |
CLI 프레임워크 |
httpx |
HTTP 클라이언트 |
pydantic |
데이터 검증 |
PyYAML |
frontmatter 파싱 |
regex |
한국어 조문 번호 파싱 |
python-dateutil |
날짜 파싱 |
- 법령/판례 텍스트: 공개 도메인 (대한민국 정부 저작물)
- 이 도구: MIT