From k-skill
Browse Korean court auction property notices (courtauction.go.kr) by sale date, court, and bid type. Expand notices for case number, address, appraisal price, and minimum bid. Search by region, use, price, area, or failed auction count. Look up cases directly. Read-only, slow-by-design (~2s/call) to avoid IP blocks.
How this skill is triggered — by the user, by Claude, or both
Slash command
/k-skill:court-auction-notice-searchThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
대한민국 법원이 운영하는 공식 **법원경매정보** 사이트(`courtauction.go.kr`) 의 매각공고와 사건정보를 에이전트가 활용할 수 있는 JSON 형태로 변환해서 돌려준다.
대한민국 법원이 운영하는 공식 법원경매정보 사이트(courtauction.go.kr) 의 매각공고와 사건정보를 에이전트가 활용할 수 있는 JSON 형태로 변환해서 돌려준다.
BLOCKED/ipcheck=false)은 기본적으로 중단한다 (rebrowser-playwright 또는 playwright-core 가 있을 때만).data.ipcheck === false 즉시 throw 로 보수적으로 동작한다.date — 매각기일 월(YYYY-MM 또는 YYYYMM) 또는 특정일(YYYY-MM-DD 또는 YYYYMMDD). 필수. 실제 사이트 검색 버튼은 월(YYYYMM) 단위로 조회하므로 특정일 입력은 월 조회 후 해당 일자만 필터링한다.courtCode — 법원사무소코드 (예: B000210 = 서울중앙지방법원). 비우면 전체. getCourtCodes() 또는 codes courts 로 받아온다.bidType — date (= 기일입찰, code 000331) 또는 period (= 기간입찰, code 000332). 빈값이면 둘 다.caseNumber — 사건번호. 2024타경100001 형식 권장. 2024-100001 도 받아서 2024타경100001 로 정규화한다.이 스킬은 사용자에게 다음 사실을 항상 알려야 한다.
correctionCount, cancellationCount 필드를 참고).https://www.courtauction.go.krhttps://www.courtauction.go.kr/pgj/index.on?w2xPath=/pgj/ui/pgj100/PGJ143M01.xml&pgjId=143M01https://www.courtauction.go.kr/pgj/index.on?w2xPath=/pgj/ui/pgj100/PGJ159M00.xml&pgjId=159M00POST /pgj/pgj143/selectRletDspslPbanc.on — 매각공고 목록POST /pgj/pgj143/selectRletDspslPbancDtl.on — 매각공고 상세 (사건/물건 펼치기)POST /pgj/pgj15A/selectAuctnCsSrchRslt.on — 사건 단건 조회POST /pgj/pgjsearch/searchControllerMain.on — 물건 자유 조건검색 (PGJ151F00 → PGJ151M01)POST /pgj/pgjComm/selectCortOfcCdLst.on — 법원사무소코드 전체searchSaleNotices({ date, courtCode, bidType }) 호출 → 그 날·그 법원의 매각공고 카드 목록.raw)를 그대로 getSaleNoticeDetail(notice) 에 넘긴다.items[] 가 caseNumber, usage, address, appraisedPrice, minimumSalePrice, remarks 를 가진다 (이슈 본문이 명시한 4필드 모두 포함).getCaseByCaseNumber({ courtCode, caseNumber }) 호출.found:false / status:204 면 사건이 존재하지 않거나 비공개. 사건번호 형식·법원이 맞는지 사용자에게 다시 확인한다.found:true 면 caseInfo(사건명·접수일·청구액·재판부·진행상태), items[](매각목적물 — 주소/배당요구종기), schedule[](매각기일별 최저가/감정가/결과), claimDeadline, relatedCases, stakeholders 가 채워진다.searchProperties() 입력으로 매핑한다.
region: { sido, sigungu, dong } — 코드 또는 대표 정적 sido 코드테이블의 한국어명. 지역을 주면 지번주소 검색(cortStDvs:"2")으로, 지역이 없으면 매각공고 모드(cortStDvs:"1")로 조회한다. 시군구/읍면동은 정적 표가 없으므로 코드로 직접 전달(예: { sido:"11", sigungu:"11680", dong:"11680101" })한다.usage: { large, medium, small } — 용도 대/중/소분류 코드(5자리, 예: 건물=20000) 또는 대분류 한국어명(토지/건물/차량및운송장비/기타).priceRange — 최저매각가격 원 단위 { min, max } (실수 허용)appraisedPriceRange — 감정평가액 원 단위 { min, max } (실수 허용)saleDate — { from, to }flbdCount — 유찰횟수 { min, max } 정수만area — 면적(㎡) { min, max } (실수 허용)pageSize — 페이지당 결과 수, upstream PGJ151 드롭다운에서 확인된 10/20/50/100 중 하나(기본 10). 1 등 임의 값은 live endpoint 가 HTTP 400을 반환하므로 로컬에서 거부한다.searchProperties({ ... }) 호출 → POST /pgj/pgjsearch/searchControllerMain.on.
{ fallback: false }. BLOCKED(ipcheck=false)는 사이트의 명시적 차단 신호이므로 기본적으로 즉시 중단하며, 사용자가 위험을 이해하고 명시적으로 { fallbackOnBlocked: true } 를 준 경우에만 재시도한다.items[] 는 핵심 raw 컬럼을 영문 키로 정규화한다:
saNo → caseNumber, srnSaNo/printCsNo → displayCaseNumbermokmulSer/maemulSer → itemNumberhjguSido + hjguSigu + hjguDong + daepyoLotno + buldNm → addressgamevalAmt → appraisedPrice, minmaePrice → minimumSalePriceyuchalCnt → flbdCount, mulStatcd → statusCode, jinstatCd → progressStatusCodeboCd → courtCode, jiwonNm → courtName, jpDeptNm → judgeDeptNamelclsUtilCd/mclsUtilCd/sclsUtilCd → usageCodes.{large,medium,small}srchHjguSidoCd/SiguCd/DongCd → regionCodes.{sido,sigungu,dong}xCordi/yCordi → coordinates, wgs84Xcordi/Ycordi → coordinatesWgs84buldList/areaList/jimokList → buildingList/areaList/landCategoryListpjbBuldList → propertyDescription, mulBigo → remarksgetUsageCodes() 는 4개 대분류(10000=토지, 20000=건물, 30000=차량및운송장비, 40000=기타)와 일부 대표 중/소분류를 정적으로 반환한다. getRegionCodes() 는 19개 시도 + 코드만 반환한다. 시군구/읍면동은 upstream cascade XHR이 안정적이지 않아 정적 표에 포함하지 않으며 raw 코드를 그대로 전달하면 된다. 알 수 없는 값은 fail-open으로 통과한다.resolveUsageCode("아파트", "large") 처럼 입력 이름이 다른 level 에만 존재하면, 같은 이름의 medium/small 코드를 잘못 리턴하지 않고 fail-open(원문 통과)한다.--min-delay-ms 3000.new CourtAuctionHttpClient) maxCallsPerSession 을 명시적으로 늘린다.data.ipcheck === false)을 만나면 BLOCKED 에러를 즉시 throw 하고 멈춘다. 자동 retry 하지 않는다 (차단 연장 위험).searchProperties() 는 1차 direct HTTP에서 WAF성 HTTP 400을 만났을 때만 Playwright fallback 으로 재시도한다. 명시적 차단(BLOCKED/ipcheck=false)은 기본적으로 즉시 중단하며, 사용자가 위험을 이해하고 fallbackOnBlocked:true 를 준 경우에만 재시도한다. Playwright fallback 모듈(rebrowser-playwright 또는 playwright-core)이 없으면 첫 HTTP 400 실패가 그대로 throw 된다.const {
searchSaleNotices,
getSaleNoticeDetail,
getCaseByCaseNumber,
getCourtCodes
} = require("court-auction-notice-search");
async function main() {
const courts = await getCourtCodes();
console.log(`법원사무소 ${courts.count}개 로드됨`);
const notices = await searchSaleNotices({
date: "2026-04-27",
courtCode: "B000210",
bidType: "date"
});
console.log(`서울중앙지방법원 매각공고 ${notices.count}건`);
if (notices.items.length > 0) {
const detail = await getSaleNoticeDetail(notices.items[0]);
for (const item of detail.items) {
console.log(
`${item.caseNumber} (${item.usage}) — 감정 ${item.appraisedPrice}원 / 최저 ${item.minimumSalePrice}원`
);
console.log(` 주소: ${item.address}`);
}
}
const caseInfo = await getCaseByCaseNumber({
courtCode: "B000210",
caseNumber: "2024타경100001"
});
if (caseInfo.found) {
console.log(`사건명: ${caseInfo.caseInfo.caseName}`);
console.log(`매각기일 횟수: ${caseInfo.schedule.length}`);
}
}
main().catch((error) => {
if (error.code === "BLOCKED") {
console.error("[BLOCKED] 사이트가 1시간 차단했습니다. 다른 IP에서 다시 시도하거나 1시간 뒤 재시도하세요.");
} else {
console.error(error);
}
process.exitCode = 1;
});
# 1. 법원사무소 코드표
court-auction-notice-search codes courts --pretty | head -40
# 2. 입찰구분 (정적 코드)
court-auction-notice-search codes bid-types --pretty
court-auction-notice-search codes usages --pretty
court-auction-notice-search codes regions --pretty
# 3. 매각공고 목록
court-auction-notice-search notices --date 2026-04 --court-code B000210 --bid-type date --pretty
# 4. 매각공고 상세 — list 응답의 row 의 raw 필드를 그대로 detail 호출에 사용한다.
# (CLI 단발 호출에서는 list -> detail 으로 결과를 파이프할 수 있도록 jq 등을 함께 사용)
# 5. 사건번호 직접 조회
court-auction-notice-search case --court-code B000210 --case-number "2024타경100001" --pretty
# 6. 자유 조건검색
court-auction-notice-search search --sido 서울특별시 --sigungu 11680 --usage-large 건물 --usage-medium 21200 \
--price-min 100000000 --price-max 500000000 --sale-from 2026-05-01 --sale-to 2026-05-20 --pretty
error.code === "BLOCKED" — data.ipcheck === false. 1시간 대기 후 다른 IP에서 재시도. 사용자에게 차단 사실과 대기 안내를 그대로 전달한다.error.code === "BUDGET_EXCEEDED" — 세션 budget 초과. 의도적인 안전장치다. 정말 필요하면 --max-calls 20 같이 늘리지만 차단 위험을 함께 안내한다.error.code === "UPSTREAM_ERROR" — 사이트가 일반적인 에러를 돌려준 경우. 세션 만료 또는 잘못된 jdbnCd 가 가장 흔한 원인. warmup 부터 다시.error.code === "NETWORK_ERROR" — 타임아웃/연결 실패.error.code === "PLAYWRIGHT_UNAVAILABLE" — Playwright fallback 을 명시적으로 쓰려는데 모듈이 깔려있지 않음. npm i rebrowser-playwright 또는 npm i playwright-core 로 해결.caseNumber/usage/address/appraisedPrice/minimumSalePrice 가 채워진 JSON을 돌려줬다.found:false 일 때 사용자가 후속 조치를 알 수 있도록 안내했다.npx claudepluginhub nomadamas/k-skill --plugin k-skillAnalisa editais e oportunidades de leilões judiciais e extrajudiciais de imóveis com integração de módulos jurídico, pericial e de mercado.
Searches LH (Korea Land & Housing Corporation) lease/subscription public notices via k-skill-proxy. Use when a user asks about specific 청년/행복/영구/국민/매입/전세임대, 분양주택, or 신혼희망타운 공고 on apply.lh.or.kr.
Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.