1. Authentication
모든 API 요청에는 HTTP Header에 Bearer Token을 포함해야 합니다.
Authorization: Bearer <API_KEY>
API 키는 상단의 'API 키 발급 신청' 버튼을 통해 신청하실 수 있습니다.
⚡ Performance & Benchmark
Ablecity는 단순한 만세력 산출 도구가 아닙니다. 글로벌 서비스(SaaS, Game, App)를 지탱하기 위해 설계된 엔터프라이즈급 인프라를 제공합니다. 기존 레거시 API 서비스와 성능을 비교해 보세요.
| Metrics (성능 지표) | Legacy Competitor (타사) | Ablecity (Global Std) |
|---|---|---|
| Global Latency (US West) | 1,200ms ~ 2,500ms | 30ms ~ 150ms |
| Max Concurrency (TPS) | ~ 50 TPS (Throttled) | 30,000+ TPS |
| Astronomical Precision | 평균 태양시 (KST 고정) | GPS 기반 진태양시 보정 |
| Payload Efficiency | Heavy HTML/Text Mixed | Lightweight JSON |
| SLA (가용성 보장) | None (Best Effort) | 99.99% Guaranteed |
2. 공통 응답 형식
{
"status": "success", // or "error"
"data": ... , // 결과 데이터
"message": "..." // 설명 메시지
}
3. Endpoints
3.1 GET /api/v2/saju/fortune
Current Standard
사용자의 생년월일·출생 시각(birth), 성별(gender),
(선택) 태어난 도시(city), 자정 처리 방식, 사용 달력을 기반으로
만세력(사주팔자), 오행, 격국, 용신, 대운, 띠 궁합, 공망, 신살까지 v2 기준으로 계산합니다.
v2 사용 기준
- 신규 테스트키/정식키는 모두
GET /api/v2/saju/fortune기준으로 제공됩니다. - 기존
v1사용 고객은 2026년 12월 31일까지 이용 가능하지만, 신규 기능과 문서는 모두v2기준으로 안내됩니다. - 응답은
status,message,data구조를 그대로 유지하므로 기존 JSON 처리 패턴을 재사용하기 쉽습니다.
🧩 신살(SIS) 옵션 안내
- 기본 만세력 조회는 신살(SIS)을 제외하고 반환합니다.
- SIS(신살) 포함은 API 키 발급 신청 시 별도 신청/승인이 필요합니다. 승인된 API Key에는
sinsal,relations_ui,gongmang등이 포함됩니다. - v2 문서에는 실제 서비스에서 활용하는 공개 필드만 안내합니다. 엔진 내부 디버그용 필드는 문서에서 제외했습니다.
curl -X GET \
"https://api.ablecity.kr/api/v2/saju/fortune?birth=1990-01-01T01:00:00&gender=male" \
-H "Authorization: Bearer <API_KEY>" \
-H "Accept: application/json"
* midnightType(0:야자/조자 분리)과 calendar(solar:양력)는 미입력 시 기본값으로 처리됩니다.
Query Parameters
| Name | Type | Required | Description |
|---|---|---|---|
| birth | string | Yes |
태어난 시간. yyyy-MM-ddTHH:mm:ss 형식만 지원합니다. (날짜와 시간 사이 대문자 T)
|
| gender | string | Yes |
성별. 남자: male, 여자: female (그 외 값 오류)
|
| city | string | Optional |
태어난 도시 (LMT 보정용). 미입력 시 서울특별시 기준. 지원 도시는 아래 목록 참고. |
| midnightType | integer | Optional |
0: 야자/조자 분리 (기본값)1: 정자시 방식 (23:00~00:59를 모두 익일로 처리)
|
| calendar | string | Optional |
solar(양력, 기본값), lunar(음력), leap(윤달)
|
📍 사주 API 지원 도시 목록 (city) 전체 보기 ▼
표기 예: city=서울특별시
Response Example
{
"status": "success",
"message": "요청이 완료되었습니다.",
"data": {
"year": {
"branch_element": "earth",
"branch_polarity": "yang",
"branch_sipseong": "정인",
"stem_polarity": "yang",
"stem_sipseong": "정인",
"hangul": "무진",
"hanja": "戊辰",
"stem_element": "earth"
},
"month": {
"branch_element": "water",
"branch_polarity": "yang",
"branch_sipseong": "식신",
"stem_polarity": "yang",
"stem_sipseong": "정재",
"hangul": "갑자",
"hanja": "甲子",
"stem_element": "wood"
},
"day": {
"branch_element": "earth",
"branch_polarity": "yin",
"branch_sipseong": "편인",
"stem_polarity": "yin",
"stem_sipseong": "비견",
"hangul": "신축",
"hanja": "辛丑",
"stem_element": "metal"
},
"hour": {
"branch_element": "water",
"branch_polarity": "yang",
"branch_sipseong": "식신",
"stem_polarity": "yang",
"stem_sipseong": "정인",
"hangul": "무자",
"hanja": "戊子",
"stem_element": "earth"
},
"fortune": 8,
"hehua": {
"effective": [],
"failed": [],
"applied_true": false,
"applied_pseudo": false,
"applied_any": false,
"applied": false,
"five_before_pct": {
"earth": 32.8,
"metal": 11,
"fire": 0,
"wood": 12.6,
"water": 43.6
},
"five_after_pct": {
"earth": 32.8,
"metal": 11,
"fire": 0,
"wood": 12.6,
"water": 43.6
},
"five_changed": false,
"strength_before": "balanced",
"strength_after": "balanced",
"strength_changed": false,
"yongshin_changed": false
},
"five_pct": {
"earth": 32.8,
"metal": 11,
"fire": 0,
"wood": 12.6,
"water": 43.6
},
"five_star": {
"earth": "★★★★☆",
"metal": "★☆☆☆☆",
"fire": "★☆☆☆☆",
"wood": "★☆☆☆☆",
"water": "★★★★★"
},
"five_kor": {
"목(木)": 1.3,
"금(金)": 1.13,
"토(土)": 3.38,
"화(火)": 0,
"수(水)": 4.49
},
"twelve_growth": { "month": "長生", "hour": "長生", "year": "墓", "day": "養" },
"twelve_growth_kor": { "month": "장생", "hour": "장생", "year": "묘", "day": "양" },
"strength": "balanced",
"geokguk": {
"geok": "식신격",
"geok_kor": "식신격",
"geok_detail": null,
"is_follower": false,
"follower_candidate": false,
"variant_signal": false
},
"yongshin": {
"primary": "fire",
"primary_kor": "화(火)",
"secondary": "earth",
"secondary_kor": "토(土)"
},
"branch_relations": {
"harmonies": ["子-丑", "丑-子"],
"breaks": ["辰-丑"],
"clashes": [],
"punishments": [],
"harms": [],
"wonjins": [],
"half_three_harmonies": ["子-辰"]
},
"branch_relations_kor": {
"harmonies": ["자-축", "축-자"],
"breaks": ["진-축"],
"clashes": [],
"punishments": [],
"harms": [],
"wonjins": [],
"half_three_harmonies": ["자-진"]
},
"relations_ui": {
"summary": {
"harmony_count": 2,
"tension_count": 2,
"special_count": 1,
"top_alert": "공망"
},
"items": [
{
"key": "branch_harmony",
"label": "지지육합",
"group": "harmony",
"tone": "good",
"count": 2,
"tokens": ["子-丑 (자-축)", "丑-子 (축-자)"]
},
{
"key": "gongmang",
"label": "공망",
"group": "tension",
"tone": "warn",
"count": 2,
"tokens": ["공망지 辰巳 (진사)", "원국 포함 辰 (진)"]
}
],
"gongmang": {
"day_pillar": "辛丑",
"xun_start": "甲午",
"void_branches": ["辰", "巳"],
"void_branches_kor": ["진", "사"],
"present_branches": ["辰"],
"present_branches_kor": ["진"]
}
},
"big_luck": [
{ "age_range": "8–17", "year_range": "1996–2005", "pillar": "乙丑", "pillar_kor": "을축" },
{ "age_range": "18–27", "year_range": "2006–2015", "pillar": "丙寅", "pillar_kor": "병인" },
{ "age_range": "28–37", "year_range": "2016–2025", "pillar": "丁卯", "pillar_kor": "정묘" }
],
"first_big_luck": "을축",
"lucky": {
"good_num": 2,
"bad_num": 7,
"good_dir": "서쪽",
"bad_dir": "동쪽",
"need_elem": "fire",
"need_elem_kor": "화(火)"
},
"summary": {
"pillars": "무진년 갑자월 신축일 무자시",
"strength": "중화(中和)",
"zodiac": "용띠"
},
"zodiac_compatibility": [
{
"score": 95,
"grade": "best",
"animal": "쥐",
"branch": "子",
"relation": "삼합(三合)",
"desc": "서로 부족한 점을 채워주는 최상의 궁합입니다."
},
{
"score": 20,
"grade": "bad",
"animal": "개",
"branch": "戌",
"relation": "충(沖)",
"desc": "서로 부딪히는 기운으로, 갈등에 주의가 필요합니다."
}
],
"sinsal": [
{
"sis_code": "S005",
"name_kr": "공망",
"name_en": "The Void (Null State)",
"chart_vector": {
"creativity": 100,
"material_luck": 79,
"reality_grip": 74,
"reversal_potential": 95,
"spiritual_depth": 100
},
"attributes": {
"affected_element": "재성 (Wealth)",
"void_type": "진사공망 (Dragon/Snake Void)",
"positions": ["year"],
"manifest_label": "년주(태어난 해)",
"resolved_by_combine": true
},
"final_verdict": {
"grade": "S_ACTIVE",
"keyword": "채워질 준비가 된 그릇",
"description": "공망이 합 작용으로 해공된 상태입니다.",
"advice": "협업과 관계 조정을 활용해 공백 리스크를 줄이는 편이 좋습니다."
},
"beginner_explanation": "공망이 합 작용으로 해공된 상태이며, 급격한 붕괴보다 완충 흐름이 우세합니다.",
"is_present": true
}
],
"gongmang": {
"sinsals": [
{
"name": "공망",
"score": 6,
"desc": "[수(水)]비움과 채움의 미학. 해당 궁위의 결핍.",
"relatedChar": "辰",
"positions": ["YEAR"],
"is_present": true
}
],
"present_branches": ["辰"],
"hanja": ["辰", "巳"],
"hangul": ["진", "사"]
}
}
}
처음 쓰는 개발자를 위한 읽는 순서
data.summary부터 읽으면 사람이 바로 이해할 수 있는 핵심 요약을 먼저 보여줄 수 있습니다.data.year / month / day / hour는 사주 원국 4기둥입니다. 표나 카드 UI를 만들 때 가장 먼저 매핑하는 필드입니다.data.five_pct와data.five_star는 오행 밸런스를 시각화하기 가장 좋습니다. 차트, 막대그래프, 배지 UI에 바로 활용할 수 있습니다.data.yongshin,data.strength,data.geokguk은 해석형 서비스의 핵심 요약 변수입니다.data.big_luck와data.lucky는 대운 타임라인, 추천 방향/숫자 같은 부가 UI에 적합합니다.data.sinsal,data.relations_ui,data.gongmang는 신살 옵션 승인 시 활용하는 심화 데이터입니다.
주요 필드 설명
사주 기둥 (year, month, day, hour)
hangul, hanja, 천간/지지 오행, 음양, 십성 정보가 함께 들어갑니다. 사주표를 그릴 때 가장 기본이 되는 필드입니다.
운세 점수 (fortune)
전체 흐름을 빠르게 요약하는 숫자입니다. 목록형 카드나 간단한 요약 배지에 붙이기 좋습니다.
오행 분포 (five_pct, five_star, five_kor)
퍼센트, 별점, 한글 키 버전을 함께 제공합니다. 차트나 설명문을 만들 때 원하는 형태로 바로 사용할 수 있습니다.
합화 분석 (hehua)
합화가 실제로 적용됐는지, 적용 전후 오행 비율과 강약이 바뀌었는지를 확인하는 영역입니다.
강약 / 격국 / 용신
strength, geokguk, yongshin은 해석형 콘텐츠를 만들 때 가장 많이 참조하는 핵심 변수입니다.
지지 관계 (branch_relations, relations_ui)
합·충·형·해·파 같은 관계를 원본 배열과 UI 친화 요약 두 가지 방식으로 제공합니다.
대운 / 행운 정보
big_luck, first_big_luck, lucky는 타임라인, 추천 방향, 숫자 UI를 구성할 때 유용합니다.
신살 / 공망 / 띠 궁합
sinsal, gongmang, zodiac_compatibility는 해석 콘텐츠와 관계형 기능을 확장할 때 바로 활용할 수 있습니다.
v2 주요 필드 상세
| Field | Type | Description |
|---|---|---|
| year / month / day / hour | Object | 각 기둥의 간지, 오행, 음양, 십성 정보입니다. 사주 원국 UI의 기본 데이터입니다. |
| fortune | Number | 현재 만세력 종합 점수입니다. 정렬, 추천, 간단한 등급 표시용으로 쓰기 좋습니다. |
| hehua | Object | effective, failed, applied*, five_before_pct, five_after_pct 등으로 합화 적용 결과를 보여줍니다. |
| five_pct / five_star / five_kor | Object | 오행 비율, 별점, 한글 표기 버전입니다. 숫자 UI와 설명 텍스트를 함께 만들기 좋습니다. |
| twelve_growth / twelve_growth_kor | Object | 십이운성 정보입니다. 한자/한글 버전이 모두 제공돼 표기 방식 선택이 쉽습니다. |
| strength | String | 일간 강약을 요약한 값입니다. 예: balanced, weak, strong. |
| geokguk | Object | geok, geok_kor, geok_detail, follower_candidate 등 격국 요약을 담습니다. |
| yongshin | Object | 보완이 필요한 핵심 오행입니다. 추천 컬러, 방향, 콘텐츠 추천 로직과 연결하기 쉽습니다. |
| branch_relations / branch_relations_kor | Object | 합·충·형·해·파·원진 등 관계를 원본 표기와 한글 표기로 함께 반환합니다. |
| relations_ui | Object | 관계 신호를 화면에 바로 쓰기 쉬운 형태로 정리한 객체입니다. (SIS 옵션) |
| big_luck / first_big_luck | Array / String | 10년 단위 대운 흐름과 첫 대운 정보를 제공합니다. 타임라인 카드 구성에 적합합니다. |
| lucky | Object | 행운 숫자, 방향, 보완 오행 등 부가 추천 정보를 제공합니다. |
| summary | Object | 사람에게 바로 보여주기 좋은 요약 필드입니다. 카드 상단 제목용으로 가장 먼저 쓰기 좋습니다. |
| zodiac_compatibility | Array<Object> | 본인 띠 기준 12지신 궁합 데이터입니다. 띠궁합 콘텐츠, 매칭 추천 로직에 활용할 수 있습니다. |
| sinsal | Array<Object> | sis_code, chart_vector, attributes, final_verdict, beginner_explanation를 포함한 신살 상세 데이터입니다. (SIS 옵션) |
| gongmang | Object | 공망지 한자/한글 목록과 관련 신살 요약을 제공합니다. 공망 특화 UI에 바로 사용할 수 있습니다. (SIS 옵션) |
📚 지원하는 신살 전체 목록 (56종) Enum Reference ▼
Ablecity 사주 API는 국내 최다 수준인 56종의 신살을 정밀 분석합니다.
응답 데이터는 SIS(신살) 정식 버전에서 sis_code(S001~S056)·name_kr·name_en를 반환합니다.
아래 목록의 No.와 sis_code는 1:1로 매핑됩니다. (예: No. 1 ↔ S001)
* 상세 산출 로직(공식)은 에이블시티의 핵심 IP로, API 응답을 통해서만 결과를 제공합니다.
| No. | 구분 | 한글명 (Name) | 영문 키 (Key) |
|---|---|---|---|
| 1 | 흉살 | 격각살 | gyeok-gak-sal |
| 2 | 흉살 | 겁살 | geop-sal |
| 3 | 흉살 | 고란살 | go-ran-sal |
| 4 | 흉살 | 고신살 | go-sin-sal |
| 5 | 기타 | 공망 | gong-mang |
| 6 | 흉살 | 과숙살 | gwa-suk-sal |
| 7 | 길신 | 괴강귀인 | goe-gang-gwi-in |
| 8 | 흉살 | 괴강살 | goe-gang-sal |
| 9 | 흉살 | 귀문관살 | gwi-mun-gwan-sal |
| 10 | 길신 | 금여 | geum-yeo |
| 11 | 길신 | 록신귀인 | rok-sin-gwi-in |
| 12 | 흉살 | 망신살 | mang-sin-sal |
| 13 | 길신 | 문곡귀인 | mun-gok-gwi-in |
| 14 | 길신 | 문창귀인 | mun-chang-gwi-in |
| 15 | 길신 | 반안살 | ban-an-sal |
| 16 | 흉살 | 백호살 | baek-ho-sal |
| 17 | 길신 | 복성귀인 | bok-seong-gwi-in |
| 18 | 길신 | 삼기 | sam-gi |
| 19 | 흉살 | 조객살 | jo-gaek-sal |
| 20 | 흉살 | 상문살 | sang-mun-sal |
| 21 | 흉살 | 양인살 | yang-in-sal |
| 22 | 흉살 | 역마살 | yeok-ma-sal |
| 23 | 흉살 | 도화살(연살,함지살) | do-hwa-sal |
| 24 | 흉살 | 원진살 | won-jin-sal |
| 25 | 길신 | 월덕귀인 | wol-deok-gwi-in |
| 26 | 흉살 | 월살 | wol-sal |
| 27 | 흉살 | 육해살 | yuk-hae-sal |
| 28 | 길신 | 장성살 | jang-seong-sal |
| 29 | 흉살 | 재살 | jae-sal |
| 30 | 흉살 | 지복살 | ji-bok-sal |
| 31 | 길신 | 지살 | ji-sal |
| 32 | 길신 | 천계귀인 | cheon-gye-gwi-in |
| 33 | 길신 | 천관성 | cheon-gwan-seong |
| 34 | 길신 | 천덕귀인 | cheon-deok-gwi-in |
| 35 | 흉살 | 천라지망 | cheon-ra-ji-mang |
| 36 | 길신 | 천문성 | cheon-mun-seong |
| 37 | 길신 | 천복성 | cheon-bok-seong |
| 38 | 길신 | 천수성 | cheon-su-seong |
| 39 | 길신 | 천을귀인 | cheon-eul-gwi-in |
| 40 | 길신 | 천의성 | cheon-ui-seong |
| 41 | 길신 | 천주귀인 | cheon-ju-gwi-in |
| 42 | 흉살 | 충살 | chung-sal |
| 43 | 길신 | 태극귀인 | tae-geuk-gwi-in |
| 44 | 길신 | 학당귀인 | hak-dang-gwi-in |
| 45 | 기타 | 현침살 | hyeon-chim-sal |
| 46 | 흉살 | 형살 | hyeong-sal |
| 47 | 길신 | 홍염살 | hong-yeom-sal |
| 48 | 기타 | 화개 | hwa-gae |
| 49 | 길신 | 천덕합 | cheon-deok-hap |
| 50 | 길신 | 월덕합 | wol-deok-hap |
| 51 | 길신 | 협록 | hyeop-rok |
| 52 | 길신 | 암록 | am-rok |
| 53 | 흉살 | 파살 | pa-sal |
| 54 | 흉살 | 천살 | cheon-sal |
| 55 | 흉살 | 탕화살 | tang-hwa-sal |
| 56 | 흉살 | 효신살 | hyo-sin-sal |
3.2 v2 Add-ons 및 심화 분석
기본 만세력 외에 오늘의 운세, 올해 운세, 정통사주, 궁합, 작명, 관상, 손금 등 다양한 v2 Add-on API를 제공합니다.
fortune/request-analysis/로 시작하는 엔드포인트는 모두 POST + Callback 방식이며, 나머지는 GET 방식입니다.
-
GET
동기 처리:
/fortune,/daily,/zodiac-luck,/luck-flow는 호출 즉시 결과를 반환합니다. -
POST
비동기 처리:
/fortune/request-analysis/...계열은 연산 후X-Callback-URL로 결과를 전송합니다. - MIGRATION 기존 v1 Add-on 사용자는 2026년 12월 31일까지 이용 가능하며, 2026년 4월 1일 이후 신규 신청은 모두 v2입니다.
🔗 서비스 엔드포인트 목록
| Method | Endpoint Path (Full URL) | Description |
|---|---|---|
| GET | /api/v2/saju/fortune/daily | 오늘의 운세 |
| GET | /api/v2/saju/fortune/zodiac-luck | 오늘의 띠별 운세 |
| GET | /api/v2/saju/fortune/luck-flow | 대운 / 연운 / 월운 |
| POST | /api/v2/saju/fortune/request-analysis/this-year-luck | 올해 운세 (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/telling | 정통사주 (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/match | 궁합(2인) (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/week-luck | 주간 운세 (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/love-luck | 올해 애정운 (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/rich-luck | 올해 재물운 (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/naming | 작명(추천 + 풀이) (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/face | 관상(얼굴 이미지) (Callback 필수) |
| POST | /api/v2/saju/fortune/request-analysis/palmistry | 손금(손 이미지) (Callback 필수) |
Request Example (POST / Callback, v2)
* /api/v2/saju/fortune/request-analysis/... 계열은 모두 X-Callback-URL 헤더가 필수입니다.
curl -X POST \
"https://api.ablecity.kr/api/v2/saju/fortune/request-analysis/rich-luck" \
-H "Authorization: Bearer <API_KEY>" \
-H "X-Callback-URL: https://your-server.com/webhook/result" \
-H "Content-Type: application/json" \
-d '{
"birth": "1990-01-01T00:00:00",
"gender": "male",
"city": "서울특별시",
"calendar": "solar",
"midnightType": 0
}'
3.2 POST /api/v1/matching
소개팅·결혼중개 매칭 요청을 생성하며, 사용자의 선호도(나이, 관심사)와 위치 반경(Radius) 필터링을 지원합니다.
Request Example
curl -X POST https://api.ablecity.kr/v1/matching \
-H "Authorization: Bearer <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"userId": "USER123",
"preferences": {
"ageRange": [25, 35],
"interests": ["travel", "music"],
"location": { "lat": 37.5665, "lng": 126.9780, "radiusKm": 30 }
},
"maxResults": 10
}'
Response Example (201 Created)
{
"status": "success",
"data": {
"requestId": "REQ-67890",
"status": "processing",
"submittedAt": "2025-05-10T11:00:00+09:00"
}
}
3.3 GET /api/v1/matching/{requestId}/results
비동기로 처리된 매칭 진행 상황과 결과 리스트를 조회합니다. limit과 offset을 사용해 페이징 처리가 가능합니다.
Request Example
curl -X GET \
"https://api.ablecity.kr/v1/matching/REQ-67890/results?limit=5&offset=0" \
-H "Authorization: Bearer <API_KEY>"
Response Example
{
"status": "success",
"data": {
"requestId": "REQ-67890",
"status": "completed",
"results": [
{
"matchId": "MCH-001",
"name": "홍길동",
"age": 29,
"distanceKm": 3.5,
"commonInterests": ["travel", "cooking"],
"matchScore": 0.92,
"profileImage": "https://ablecity.kr/images/users/hong.jpg"
},
{
"matchId": "MCH-002",
"name": "김미영",
"age": 32,
"distanceKm": 5.8,
"commonInterests": ["music", "art"],
"matchScore": 0.88,
"profileImage": "https://ablecity.kr/images/users/kim.jpg"
}
],
"totalResults": 8
}
}
3.4 GET /api/v1/tutoring/availability
특정 날짜와 서비스 유형에 대해 예약 가능한 시간대(Slot) 목록을 조회합니다.
Request Example
curl -X GET \
"https://api.ablecity.kr/v1/tutoring/availability?date=2025-06-15&serviceType=care" \
-H "Authorization: Bearer <API_KEY>"
Response Example
{
"status": "success",
"data": [
{
"slotId": "SLT-001",
"start": "2025-06-15T09:00:00+09:00",
"end": "2025-06-15T10:00:00+09:00",
"price": 35000
},
{
"slotId": "SLT-002",
"start": "2025-06-15T14:00:00+09:00",
"end": "2025-06-15T15:30:00+09:00",
"price": 50000
}
]
}
3.5 POST /api/v1/tutoring/book
선택한 시간대(Slot ID)로 서비스를 예약하고 결제를 진행합니다.
Request Example
curl -X POST https://api.ablecity.kr/v1/tutoring/book \
-H "Authorization: Bearer <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"userId": "USER123",
"slotId": "SLT-001",
"paymentMethod":"card",
"cardInfo": {
"cardNumber": "4111111111111111",
"expiry": "12/25",
"cvc": "123"
}
}'
Response Example (201 Created)
{
"status": "success",
"data": {
"bookingId": "BOOK-34567",
"status": "confirmed",
"paidAmount": 35000,
"confirmationUrl": "https://ablecity.kr/booking/BOOK-34567"
}
}
3.6 GET /api/v1/otc/listings
거래 가능한 OTC(장외거래) 리스팅을 조회하며, 자산 유형(BTC/ETH 등)과 최소 수량 필터를 지원합니다.
Request Example
curl -X GET \
"https://api.ablecity.kr/v1/otc/listings?assetType=BTC&minQuantity=0.5" \
-H "Authorization: Bearer <API_KEY>"
Response Example
{
"status": "success",
"data": [
{
"listingId": "LST-1001",
"assetType": "BTC",
"quantity": 1.2,
"pricePerUnit": 50000000,
"totalPrice": 60000000,
"sellerId": "TraderA",
"escrowStatus": "pending"
}
]
}
3.7 POST /api/v1/otc/order
선택한 리스팅으로 OTC 거래 주문을 생성하고, 안전 거래를 위한 스마트 컨트랙트 에스크로 주소를 반환합니다.
Request Example
curl -X POST https://api.ablecity.kr/v1/otc/order \
-H "Authorization: Bearer <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"listingId": "LST-1001",
"buyerId": "USER456",
"quantity": 0.8
}'
Response Example (201 Created)
{
"status": "success",
"data": {
"orderId": "ORD-2002",
"escrowAddress": "0xabcd1234ef567890...",
"expiresAt": "2025-05-10T12:00:00+09:00"
}
}
3.8 GET /api/v1/rental/assets
렌탈 가능한 자산 목록을 조회하며, 카테고리(카메라, 장비 등) 및 위치 기반(반경) 필터를 지원합니다.
Request Example
curl -X GET \
"https://api.ablecity.kr/v1/rental/assets?category=camera&lat=37.5665&lng=126.9780&radiusKm=10" \
-H "Authorization: Bearer <API_KEY>"
Response Example
{
"status": "success",
"data": [
{
"assetId": "ASSET-3001",
"name": "Canon EOS R5",
"category": "camera",
"location": { "lat": 37.5665, "lng": 126.9780 },
"hourlyRate": 15000,
"availabilityCount": 3
}
]
}
3.9 POST /api/v1/rental/reserve
선택한 자산을 예약하고, 총 비용 계산 및 예약 확인 URL을 반환합니다.
Request Example
curl -X POST https://api.ablecity.kr/v1/rental/reserve \
-H "Authorization: Bearer <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"userId": "USER123",
"assetId": "ASSET-3001",
"startTime": "2025-06-20T09:00:00+09:00",
"endTime": "2025-06-20T17:00:00+09:00"
}'
Response Example (201 Created)
{
"status": "success",
"data": {
"reservationId": "RES-4003",
"totalCost": 120000,
"confirmationUrl": "https://ablecity.kr/reservations/RES-4003"
}
}
4. Error Codes
| HTTP Status | Code | Description |
|---|---|---|
| 400 | INVALID_REQUEST | 잘못된 요청입니다. |
| 401 | UNAUTHORIZED | 인증 실패 또는 토큰 만료. |
| 404 | NOT_FOUND | 리소스를 찾을 수 없습니다. |
| 429 | RATE_LIMIT | 요청 한도 초과입니다. |
| 500 | SERVER_ERROR | 서버 내부 오류. |
4.1 공통 message 값
요청이 완료되었습니다.– 성공 처리.서버 처리 중 오류가 발생했습니다.– 서버 내부 오류. 서버 로그 확인 필요.서비스를 찾을 수 없습니다.– 지원하지 않는 서비스(URL)를 호출한 경우.
4.2 인증 / Rate Limit 관련 message
-
●
유효하지 않은 API Key입니다.
API Key가 삭제(비활성화)되었거나 만료되었거나, 요청 헤더에 존재하지 않을 때. -
●
허용된 전체 분당 요청 횟수가 초과되었습니다.
API Key에 할당된 1분당 전체 요청 횟수를 초과. -
●
허용된 전체 일일 요청 횟수가 초과되었습니다.
API Key에 할당된 일일 전체 요청 횟수를 초과. -
●
허용되지 않은 서비스입니다.
요청한 서비스(URI)가 해당 API Key에 할당되지 않았거나, 비활성/만료 상태일 때. -
●
서비스가 일시적으로 불안정합니다. 잠시 후 다시 시도해주세요.
Redis 등 내부 요청 횟수 관리 중 일시적인 오류가 발생했을 때.
4.3 사주 API 전용 message
-
ℹ️
invalid birth date format
birth형식 오류.yyyy-MM-dd HH:mm:ss형식만 허용됩니다. -
ℹ️
gender must be 'male' or 'female'
gender값이male또는female이 아닐 때. -
ℹ️
invalid timezone
태어난 지역 시간대 오류. IANA tz 데이터베이스 기준으로 검증됩니다.
5. Rate Limit
안정적인 서비스 제공을 위해 API 호출 빈도를 제한하고 있습니다. 모든 엔드포인트는 발급받은 API Key를 기준으로 아래의 기본 한도가 적용됩니다.
⚠️ 한도 초과 시 처리 (Throttling)
서비스별 혹은 전체 한도를 초과하면 HTTP Status 429 (Too Many Requests)와 함께
Rate Limit 관련 message가 반환됩니다.
비즈니스 규모에 따라 더 높은 한도가 필요하신 경우, 고객센터([email protected])를 통해 상향을 요청할 수 있습니다.
6. FAQ (자주 묻는 질문)
2026년 4월 1일 이후 신규 API 키는 어떤 버전으로 발급되나요? ▼
만세력 & 신살 API v1 신규 발급은 2026년 3월 31일에 종료되었습니다. 2026년 4월 1일부터 발급되는 테스트키와 정식키는 모두 v2로 제공됩니다.
기존 v1 API 키는 언제까지 사용할 수 있나요? ▼
기존에 v1으로 발급된 API 키는 2026년 12월 31일까지 계속 사용할 수 있습니다. 다만 신규 프로젝트나 신규 발급은 모두 v2 기준으로 개발하시는 것을 권장합니다.
애드온도 v2로 신청해야 하나요? ▼
네. 애드온도 2026년 4월 1일부터 신규 신청은 모두 v2로만 제공됩니다. 기존 v1 애드온 이용자는 2026년 12월 31일까지 계속 사용할 수 있습니다.
fortune/request-analysis/로 시작하는 엔드포인트는 왜 POST와 callback URL이 필요한가요?
▼
정통사주, 올해 운세, 궁합, 작명처럼 생성 시간이 더 필요한 분석형 API는 비동기로 처리합니다.
그래서 요청은 POST로 보내고, 결과는 X-Callback-URL로 전달받는 구조입니다.
만세력 API 사용료는 어떻게 되나요? ▼
테스트는 100건까지 무료이며, 이후에는 구독 형태에 따라(건당 10원~100원)가 적용됩니다.
사주 API는 어떤 프로그래밍 언어에서 사용할 수 있나요? ▼
표준 RESTful JSON 응답을 제공하므로 Python, JavaScript(Node.js), Java, PHP, Go 등 HTTP 클라이언트를 지원하는 모든 언어 및 플랫폼에서 호출할 수 있습니다.
무료 체험용 API 키는 어떻게 받나요? ▼
👉 API 키 발급 신청서(구글폼)를 통해 접수해 주시면, 관리자가 검토 후 1~2일 이내에 이메일로 키를 발송해 드립니다.
7. Support
도움이 필요하신가요?
API 연동 중 발생하는 기술적인 이슈나 추가 도움말은 이메일로 문의해 주세요.
담당 엔지니어가 빠르게 확인 후 답변드립니다.