// api guide / polling
폴링 패턴
데이터 수집은 비동기로 처리됩니다. 요청 생성 응답의 suggestedPollIntervalMs 간격으로 status 를 조회하고 SUCCEEDED/FAILED 상태가 되면 폴링을 종료합니다.
3단계 흐름
terminal — curl
# 1. 수집 요청 생성 → status: PENDING + suggestedPollIntervalMs
curl -sS -X POST https://api.h6s.ai/api/v1/data-jobs \
-H "Authorization: Bearer $H6S_API_KEY" \
-d '{ "providerCode": "CB_KB", "schema": "bank.transactions.cb.v1",
"params": { "dateRangeStart": "2026-03-01", "dateRangeEnd": "2026-03-31" } }'
# → { "id": "<job-id>", "status": "PENDING", "suggestedPollIntervalMs": 5000, "maxWaitSeconds": 600 }
# 2. status == SUCCEEDED / FAILED 가 될 때까지 suggestedPollIntervalMs 간격으로 GET
curl -sS https://api.h6s.ai/api/v1/data-jobs/<job-id> -H "Authorization: Bearer $H6S_API_KEY"
# → { "status": "RUNNING", "succeededRecordCount": 42, ... } # 진행 중
# → { "status": "SUCCEEDED", ... } # 종료, results 호출
# 3. status == SUCCEEDED 이면 결과 받기
curl -sS https://api.h6s.ai/api/v1/data-jobs/<job-id>/results -H "Authorization: Bearer $H6S_API_KEY"폴링 루프 예시
typescript
// TypeScript — fetch loop
const job = await postDataJob({ providerCode, schema, params });
let current = job;
while (current.status === "PENDING" || current.status === "RUNNING") {
await sleep(current.suggestedPollIntervalMs ?? 5000);
current = await getDataJob(job.id);
}
if (current.status === "FAILED") {
// current.errorCode 로 분기 (예: LOGIN_FAILED, JOB_TIMEOUT),
// current.errorMessage 는 사용자에게 그대로 노출 가능,
// current.retryable === true 면 같은 요청 재시도가 안전합니다
throw new Error(`${current.errorCode}: ${current.errorMessage}`);
}
const { data } = await getDataJobResults(job.id);실패 시 다음 액션
errorCode— 오류 유형 식별자 (예:AUTH_FAILED,RATE_LIMITED)errorMessage— 사용자에게 보일 한국어 메시지retryable—true면 같은 요청 재시도 안전,false면 자격증명 확인 등 사람 개입 필요maxWaitSeconds를 넘기면 작업이FAILED로 표시될 수 있습니다. 클라이언트도 같은 시간을 hard timeout 기준으로 두는 것을 권장합니다.