Skip to main content

MCP server for searching Korean government procurement bids (나라장터 입찰공고)

Project description

Nara MCP Server (나라장터 입찰공고 검색)

MCP server for searching Korean government procurement bid notices from G2B (나라장터 - Nara Jangteo).

Features

  • 🔍 통합 검색: 용역 입찰공고 + 사전규격을 키워드로 검색 (검색 기간 자유 설정, 기본 7일)
  • 💰 예산 정보: 모든 검색 결과에 예산 금액 표시
  • 📅 마감 상태 표시: 모든 공고를 표시하고 ✅ 진행중 / 🔴 마감 상태를 명확히 구분
  • 📎 파일 추출: 제안요청서(RFP) 자동 다운로드 및 텍스트 추출
  • 🗂️ 스마트 필터링: 제안요청서/과업지시서 파일만 자동 선별
  • 🏢 맞춤형 추천: 부서 프로필 기반 유연한 추천 (Top N 또는 전체 목록)
  • 📄 다형식 지원: HWP, HWPX, PDF, DOCX, XLSX, ZIP 파일 자동 처리
  • 🎯 전략 분석: 첨부파일 기반 입찰 전략 제안

Quick Start

Get started in 3 steps:

  1. Install from PyPI

    pip install nara-mcp-server
    
  2. Get API keys (2개 필요)

    • 공공데이터포털 에서 "조달청_나라장터 입찰공고정보서비스" 활용신청 → NARA_API_KEY
    • 동일 포털에서 "조달청_나라장터 사전규격정보서비스(HrcspSsstndrdInfoService)" 활용신청 → NARA_PRESPEC_API_KEY
  3. Configure Claude Desktop Add to claude_desktop_config.json:

    {
      "mcpServers": {
        "nara-jangteo": {
          "command": "uvx",
        "args": [
            "--python",
            "3.11",
            "--from",
            "nara-mcp-server",
            "nara-server"
          ],
          "env": {
            "NARA_API_KEY": "입찰공고 API KEY",
            "NARA_PRESPEC_API_KEY": "사전규격 API KEY",
            "UV_LINK_MODE": "copy"
          }
        }
      }
    }
    
  4. Start using! Restart Claude Desktop and ask: "나라장터에서 'AI' 키워드로 입찰공고를 검색해줘"

Prerequisites

1. API 키 발급 (필수 — 2가지)

나라장터 API는 일반 입찰공고사전규격이 별도 서비스로 분리되어 있어 각각 활용신청이 필요합니다.

① 입찰공고 API 키 (NARA_API_KEY)

  1. 공공데이터포털 접속 및 회원가입
  2. "조달청_나라장터 입찰공고정보서비스" 검색 후 활용신청
  3. 마이페이지 > 개발계정 에서 ServiceKey 확인 (일반 인증키 Decoding 사용)

② 사전규격 API 키 (NARA_PRESPEC_API_KEY)

  1. 동일 포털에서 "조달청_나라장터 사전규격정보서비스(HrcspSsstndrdInfoService)" 검색 후 활용신청
  2. 승인 후 동일하게 ServiceKey 확인

두 서비스의 키가 동일할 수도 있으나, 각각 활용신청이 완료되어야 정상 동작합니다.

2. Python 환경

  • Python 3.10 이상 필요

Installation

Option 1: From PyPI (Recommended)

The simplest way to install:

pip install nara-mcp-server

Note: This installs the nara-server command globally for easy access.

Option 2: From Source (For Development)

If you want to contribute or modify the code:

git clone https://github.com/Datajang/narajangteo_mcp_server.git
cd narajangteo_mcp_server
pip install -e .

Configuration

Using .env File (Recommended for Development)

Create a .env file in the project root:

# .env
NARA_API_KEY=입찰공고_서비스키
NARA_PRESPEC_API_KEY=사전규격_서비스키

The .env file is automatically loaded when running the server.

Claude Desktop Configuration

설정 파일 위치:

  • MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "nara-jangteo": {
      "command": "uvx",
      "args": [
        "--python",
        "3.11",
        "--from",
        "nara-mcp-server",
        "nara-server"
      ],
      "env": {
        "NARA_API_KEY": "입찰공고 API KEY",
        "NARA_PRESPEC_API_KEY": "사전규격 API KEY",
        "UV_LINK_MODE": "copy"
      }
    }
  }
}

중요 사항:

  • PyPI 설치 시 nara-server 명령어가 자동으로 등록됩니다
  • NARA_API_KEY — 입찰공고 ServiceKey 입력
  • NARA_PRESPEC_API_KEY — 사전규격 ServiceKey 입력 (미설정 시 사전규격 검색 비활성화)
  • Claude Desktop 재시작 필요

Other MCP Clients

Continue, Cline 등 다른 MCP 클라이언트도 동일한 방식으로 설정 가능합니다.

Development & Testing

Using .env File (Recommended)

For local development, create a .env file:

# .env
NARA_API_KEY=입찰공고_서비스키
NARA_PRESPEC_API_KEY=사전규격_서비스키

The .env file is automatically loaded and not tracked by git (.gitignore).

Example workflow:

# 1. .env 파일 생성 후 두 API 키 입력
# NARA_API_KEY=your_bid_key
# NARA_PRESPEC_API_KEY=your_prespec_key

# 2. Run MCP Inspector (no env setup needed!)
npx @modelcontextprotocol/inspector uv --directory . run python -m nara_server.server

Available Tools

1. get_bids_by_keyword

키워드로 용역 입찰공고 및 사전규격을 검색합니다. (최대 20개 결과)

파라미터:

  • keyword (필수): 검색 키워드 (예: "인공지능", "AI", "플랫폼", "시스템 구축")
  • days (선택, 기본값: 7): 검색 기간 (일). 오래된 공고 검색 시 늘릴 것 (예: 30, 60, 90)

반환 정보:

일반 입찰공고:

  • 공고명 (bidNtceNm)
  • 공고번호 (bidNtceNo)
  • 수요기관 (dminsttNm)
  • 예산 (bdgtAmt / presmptPrce)
  • 마감일시 (bidClseDt) + 진행중/마감 상태 표시
  • 제안요청서 파일 (제안요청서/제안 키워드 포함 파일만 자동 필터링)

사전규격:

  • 품명/서비스명 (prdctClsfcNoNm)
  • 사전규격번호 (bfSpecRgstNo)
  • 발주기관 (orderInsttNm)
  • 배정예산 (asignBdgtAmt)
  • 의견마감일시 (opninRgstClseDt)
  • 규격문서 파일 URL (specDocFileUrl1~5)

예시 질문:

나라장터에서 "인공지능" 키워드로 입찰공고를 검색해줘
AI 관련 정부 프로젝트 입찰 공고를 최근 30일 기준으로 찾아줘

2. recommend_bids_for_dept

부서/팀 프로필을 기반으로 맞춤형 입찰공고를 추천합니다.

파라미터:

  • keyword (필수): 검색 키워드
  • department_profile (필수): 부서/팀 설명 (예: "UI/UX 디자인팀", "AI/ML 개발팀")
  • days (선택, 기본값: 7): 검색 기간 (일). 오래된 공고 검색 시 늘릴 것 (예: 30, 60, 90)

검색 범위:

  • 최대 60개 결과 (일반 입찰 30개 + 사전규격 30개)

출력 방식:

  • 사용자가 "Top 5" 또는 특정 개수를 요청하면 해당 개수만큼 추천
  • "모든 관련 공고"를 요청하면 전체 목록을 적합도 순으로 표시
  • 예산이 있는 항목 우선 추천
  • 제안요청서/과업지시서 파일만 자동 필터링하여 표시

예시 질문:

우리 팀은 클라우드 인프라 구축 전문팀이야. "클라우드" 키워드로 우리 팀에 맞는 입찰공고 Top 5를 추천해줘
데이터베이스 마이그레이션 전문가인데, "DB" 키워드로 관련된 모든 공고를 보여줘

3. analyze_bid_detail

입찰공고 첨부파일(제안요청서)을 다운로드하고 텍스트를 추출하여 분석합니다.

파라미터:

  • file_url (필수): 첨부파일 URL (검색 결과의 제안요청서 URL)
  • filename (필수): 파일명 (검색 결과의 파일명)
  • department_profile (선택): 부서 설명 (입력 시 전략 분석 포함)

지원 형식:

  • HWP: 한글 문서 (주요 형식, langchain-teddynote HWPLoader 사용)
  • HWPX: 한글 오피스 XML 문서
  • PDF: 텍스트 기반 PDF (이미지 기반 PDF는 제외)
  • DOCX: MS Word 문서
  • XLSX: Excel 스프레드시트
  • ZIP: 자동으로 내부 파일 선택
    • 우선순위: 제안요청서 > 과업지시서 > .hwp/.hwpx > .docx/.pdf

예시 질문:

위 공고의 첨부파일을 분석해줘. 우리 팀은 AI 개발팀이야.

분석 결과:

  • Fit Score (0-100): 팀과 프로젝트의 적합도
  • Core Tasks: 팀이 수행할 핵심 업무
  • Winning Strategy: 입찰 전략 3가지
  • Risk Factors: 위험 요소 (기술스택, 일정, 페널티 등)

Usage Examples

기본 검색

Q: 나라장터에서 "시스템 개발" 키워드로 입찰공고를 검색해줘

A: 🔍 **일반 입찰 공고 (Regular Bids)**
   Found 15 bid notice(s) total, 15 retrieved
   📅 Search period: 20260116 ~ 20260123

   ## 1. AI 기반 고객관리 시스템 개발 용역
      📌 공고번호: 20260112345-00
      🏢 수요기관: 서울시청
      💰 예산: 150,000,000원
      ⏰ 마감일시: 202601201430 (✅ 진행중)
      📎 제안요청서:
         - 제안요청서_AI시스템.hwp: [URL]

   ================================================================================
   📋 **사전규격 공고 (Preliminary Specifications)**
   Found 3 pre-spec(s) total, 3 retrieved

   ## 1. 📋 [사전규격] 고객관리 플랫폼 구축
      📌 사전규격번호: PRE20260101-01
      🏢 발주기관: 경기도청
      💰 배정예산: 80,000,000원
      ⏰ 의견마감일시: 202601251700 (🔴 마감)
      📎 규격문서:
         - 규격문서 1: [URL]

맞춤형 추천

Q: 우리 팀은 React 기반 웹 프론트엔드 개발 전문팀이야. "플랫폼 구축" 키워드로 우리 팀에 맞는 입찰공고 Top 5를 추천해줘

A: 🎯 Department-Filtered Integrated Search Results

   📋 Department Profile: React 기반 웹 프론트엔드 개발 전문팀
   🔍 Keyword: 플랫폼 구축
   📊 Results:
     - Regular Bids: 22 open (out of 30 total)
     - Pre-Specs: 8 open (out of 30 total)

   **Top 5 Recommendations:**

   1. ✅ [BID] 시민참여 플랫폼 구축 (적합도 95점)
      - 예산: 200,000,000원
      - 이유: React/TypeScript 기반 웹 프론트엔드 구축 명시, UI/UX 디자인 역량 중요

   2. ✅ [PRESPEC] 공공서비스 웹포털 사전규격 (적합도 90점)
      - 예산: 150,000,000원
      - 이유: 반응형 웹 디자인 요구, 사전 의견 제출로 경쟁력 확보 가능
   ...

전략 분석

Q: 위 1번 공고의 첨부파일을 분석해줘

A: 📄 Bid Document Analysis

   📎 File: 제안요청서_시민참여플랫폼.hwp

   ## Strategic Analysis

   **Fit Score:** 92/100
   - React 18, TypeScript, Tailwind CSS 기술스택 요구
   - 반응형 웹 디자인 및 접근성(WCAG 2.1) 준수 필요

   **Core Tasks:**
   1. React 기반 SPA(Single Page Application) 개발
   2. 사용자 대시보드 및 관리자 콘솔 UI 구현
   3. REST API 연동 및 상태 관리 (Redux/Zustand)

   **Winning Strategy:**
   1. 포트폴리오에서 정부기관 반응형 웹 사례 강조
   2. 접근성 준수 경험 및 웹 표준 인증서 제시
   3. React 성능 최적화 기법 (Code Splitting, Lazy Loading) 강조

   **Risk Factors:**
   - ⚠️ 개발 기간 3개월로 촉박함 (일반적으로 4-5개월 소요)
   - ⚠️ 지체상금: 일 0.1% (최대 10%)
   - ✅ 기술스택은 팀 역량과 100% 일치

Troubleshooting

1. ValueError: NARA_API_KEY / NARA_PRESPEC_API_KEY not found

원인: API 키가 환경변수로 설정되지 않았습니다.

해결 방법:

  • Claude Desktop 설정 파일의 env 섹션에 NARA_API_KEYNARA_PRESPEC_API_KEY 추가
  • 사전규격 키(NARA_PRESPEC_API_KEY) 미설정 시 사전규격 검색은 비활성화되지만 일반 입찰공고 검색은 계속 동작합니다
  • Claude Desktop 재시작

2. No Results Found

원인: 해당 기간에 해당 키워드의 공고가 없습니다.

해결 방법:

  • 다른 키워드로 검색 시도 (더 일반적인 키워드 사용)
  • days 파라미터를 늘려 검색 기간 확장 (예: days=30, days=60)
  • 마감된 공고는 🔴 마감 표시와 함께 그대로 표시되므로 별도 확인 불필요

3. API Error (Code: 20 - Access Denied)

원인: API 키가 잘못되었거나 활용신청이 승인되지 않았습니다.

해결 방법:

4. HWP 파일 추출 실패

원인:

  • DRM/암호화된 HWP 파일
  • 비표준 인코딩 또는 손상된 파일
  • 특수한 압축 방식 사용

해결 방법:

  • 원본 링크에서 수동 다운로드 시도
  • PDF 버전 파일이 있는지 확인
  • 다른 첨부파일(DOCX, PDF 등) 사용

참고:

  • 이 서버는 langchain-teddynote HWPLoader를 사용하여 대부분의 HWP 파일 처리 가능
  • 추출 실패 시 olefile 파서로 자동 폴백

API Information

  • 데이터 출처: 조달청 나라장터 (Korea Public Procurement Service)
  • 엔드포인트:
    • 일반 입찰: http://apis.data.go.kr/1230000/ad/BidPublicInfoService/getBidPblancListInfoServcPPSSrch
    • 사전규격: http://apis.data.go.kr/1230000/ao/HrcspSsstndrdInfoService/getPublicPrcureThngInfoServcPPSSrch
  • API 키: 두 서비스 각각 공공데이터포털 활용신청 필요 (NARA_API_KEY, NARA_PRESPEC_API_KEY)
  • 공고 유형: 용역 (Service) - 컨설팅, 개발, SI 프로젝트
  • 검색 기간: 기본 7일, days 파라미터로 자유 설정 가능 (예: 30, 60, 90일)
  • 날짜 청크 분할: API 날짜 범위 제한(~15일) 자동 우회, 내부적으로 15일 단위 분할 후 결과 병합
  • 필터링:
    • 모든 공고 표시, 마감일시 옆에 ✅ 진행중 / 🔴 마감 상태 표시
    • 사전규격 항목은 📋 [사전규격] 태그로 일반 입찰공고와 명확히 구분

참고:

  • 물품 공고: 엔드포인트 변경 필요 (getBidPblancListInfoThngPPSSrch)
  • 공사 공고: 엔드포인트 변경 필요 (getBidPblancListInfoCnstwkPPSSrch)

Technical Stack

  • Python: 3.10+
  • MCP Framework:
    • mcp>=1.15.0 - Model Context Protocol SDK
  • HTTP Client: httpx>=0.27.0 - Async HTTP requests
  • File Extraction:
    • langchain-teddynote>=0.3.9 - Enhanced HWP extraction (primary, with zlib compression support)
    • olefile>=0.47 - HWP fallback (legacy MS OLE format parser)
    • pypdf>=4.0 - PDF text extraction
    • python-docx>=1.1 - DOCX parsing
    • openpyxl>=3.1 - XLSX reading
  • LLM Integration:
    • langchain>=0.1.0,<1.0.0 - Document loading framework
    • langchain-core>=0.1.0,<1.0.0 - Core LangChain utilities
  • Utilities:
    • python-dotenv>=1.0.0 - Environment variable management

Project Structure

narajangteo_mcp_server/
├── src/
│   └── nara_server/
│       ├── __init__.py          # Package initialization
│       ├── server.py             # Main MCP server (STDIO transport)
│       └── file_extractor.py     # Multi-format file text extraction
├── pyproject.toml                # Python project metadata & dependencies
├── .env                          # Environment variables (local)
├── README.md                     # This file
├── CLAUDE.md                     # Developer guide
└── LICENSE                       # MIT License

Development

Setting up development environment

# Clone repository
git clone https://github.com/Datajang/narajangteo_mcp_server.git
cd narajangteo_mcp_server

# Install in editable mode
pip install -e .

# Set environment variables
export NARA_API_KEY="your_bid_key"          # MacOS/Linux
export NARA_PRESPEC_API_KEY="your_prespec_key"

set NARA_API_KEY=your_bid_key               # Windows
set NARA_PRESPEC_API_KEY=your_prespec_key

# Or use .env file (recommended)
echo "NARA_API_KEY=your_bid_key" > .env
echo "NARA_PRESPEC_API_KEY=your_prespec_key" >> .env

Running the server

# Run directly
nara-server

# Or using Python module
python -m nara_server.server

Testing with MCP Inspector

MCP Inspector provides an interactive UI for testing tools:

# Install Inspector
npm install -g @modelcontextprotocol/inspector

# Run with Inspector (automatically loads .env)
npx @modelcontextprotocol/inspector python -m nara_server.server

The Inspector will open http://localhost:6274 with:

  • Interactive tool testing
  • Real-time request/response logs
  • Tool parameter validation

Prerequisites:

Contributing

Contributions are welcome! Please follow these guidelines:

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes with clear commit messages
  4. Test thoroughly with real API calls
  5. Submit a Pull Request

License

MIT License - see LICENSE file for details

Author

Datajang (GitHub)

Links

Acknowledgments

  • 조달청 나라장터 for providing the public API
  • Anthropic for the MCP protocol
  • Korean government for open data initiatives

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nara_mcp_server-1.3.2.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nara_mcp_server-1.3.2-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

Details for the file nara_mcp_server-1.3.2.tar.gz.

File metadata

  • Download URL: nara_mcp_server-1.3.2.tar.gz
  • Upload date:
  • Size: 21.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.16

File hashes

Hashes for nara_mcp_server-1.3.2.tar.gz
Algorithm Hash digest
SHA256 cecf553a9d50fd045c324165a0c0f1949d24378f033158bf4a432f591c4c6c63
MD5 d11881ab0a7cda02a5f0175e49e48e23
BLAKE2b-256 f3b0c303bd6be79509989a6ad62d36e6e74eb79b0d72e874811a969271d21537

See more details on using hashes here.

File details

Details for the file nara_mcp_server-1.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for nara_mcp_server-1.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8a3ca8bcabe9cc1cf487756dc63266f4ef0974ffad721bc7348a346ce9adbc16
MD5 3c0d7eac592aee6712ddde8c471a4355
BLAKE2b-256 548ac458179095e22785d15fba57ed2f1d5b91c5b7c708b176cb7728c82e4c02

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page