Documentation Index Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt
Use this file to discover all available pages before exploring further.
curl --request POST \
--url https://api.apimart.ai/v1/videos/generations \
--header 'Authorization: Bearer <token>' \
--header 'Content-Type: application/json' \
--data '{
"model": "Omni-Flash-Ext",
"prompt": "a girl is dancing happily in a sunny garden",
"duration": 10,
"resolution": "1080p",
"aspect_ratio": "9:16"
}'
{
"code" : 200 ,
"data" : [
{
"status" : "submitted" ,
"task_id" : "task_01KS1H7ZYSJWH1N779S2FSHTKA"
}
]
}
모든 요청은 Bearer Token 인증이 필요합니다. API Key 발급: API Key 관리 페이지 에서 API Key를 발급받으세요.요청 시 다음 헤더를 추가합니다: Authorization: Bearer YOUR_API_KEY
요청 파라미터
비디오 생성 모델 이름입니다. Omni-Flash-Ext로 고정됩니다.
비디오 내용 설명입니다. 장면, 인물, 동작, 환경, 카메라 움직임, 화면 스타일, 오디오 힌트를 자세히 작성하는 것을 권장합니다. 예: "a girl is dancing happily in a sunny garden"
비디오 길이입니다. 단위는 초입니다. 지원 값: 4, 6, 8, 10. 5, 7 등 다른 값을 전달하면 invalid_duration 오류가 반환됩니다.
비디오 해상도입니다. 대소문자를 구분하지 않습니다. 지원 값: 다른 해상도를 전달하면 invalid_resolution 오류가 반환됩니다.
비디오 화면 비율입니다. 가로 또는 세로 출력을 제어합니다. 자주 사용하는 값: 기본값: 16:9
호환 필드입니다. aspect_ratio와 같은 의미입니다. 둘 다 전달하는 경우 같은 값으로 유지하는 것을 권장합니다.
참조 이미지 URL 배열입니다. 생략하거나, 1장 또는 3장을 전달할 수 있습니다:
생략 또는 빈 배열: 텍스트-비디오
1장: 단일 이미지-비디오
3장: 참조 이미지 융합
공개적으로 접근 가능한 이미지 URL을 지원합니다. data:image/...;base64,... 형식의 Base64 이미지도 지원합니다. 2장 이미지로 시작 프레임 + 끝 프레임을 지정하는 모드는 지원하지 않습니다. 2장을 전달하면 unsupported_image_count 오류가 반환됩니다. 4장 이상은 충분히 검증되지 않았으므로 권장하지 않습니다.
응답 상태 코드입니다. 성공 시 200입니다.
작업 배열을 반환합니다. 작업 초기 상태입니다. 제출 성공 시 submitted입니다.
작업 고유 식별자입니다. 작업 상태와 결과 조회에 사용합니다.
작업 결과 조회
비디오 생성은 비동기 작업입니다. 제출 후 task_id가 반환됩니다. 작업 상태 조회 API로 진행 상황과 결과를 조회하세요.
curl --request GET \
--url https://api.apimart.ai/v1/tasks/task_01KS1H7ZYSJWH1N779S2FSHTKA \
--header 'Authorization: Bearer <token>'
제출 후 5-10초 기다린 뒤 처음 조회하고, 이후 5-10초마다 폴링하는 것을 권장합니다. 단일 작업은 일반적으로 약 3-5분 안에 완료됩니다.
성공 결과 예시
{
"code" : 200 ,
"data" : {
"id" : "task_01KS1H7ZYSJWH1N779S2FSHTKA" ,
"status" : "completed" ,
"progress" : 100 ,
"created" : 1779246294 ,
"completed" : 1779246534 ,
"actual_time" : 240 ,
"estimated_time" : 600 ,
"cost" : 0.4 ,
"result" : {
"videos" : [
{
"url" : [ "https://cdn.example.com/videos/abc.mp4" ],
"expires_at" : 1779332760
}
]
}
}
}
실패 결과 예시
{
"code" : 200 ,
"data" : {
"id" : "task_01KS1H7ZYSJWH1N779S2FSHTKA" ,
"status" : "failed" ,
"progress" : 100 ,
"created" : 1779246294 ,
"completed" : 1779246534 ,
"actual_time" : 240 ,
"estimated_time" : 600 ,
"cost" : 0 ,
"error" : {
"message" : "invalid duration 7, must be one of 4/6/8/10" ,
"code" : "task_failed"
}
}
}
사용 사례
시나리오 1: 텍스트-비디오
{
"model" : "Omni-Flash-Ext" ,
"prompt" : "a beautiful sunset over the ocean with seagulls flying" ,
"duration" : 6 ,
"resolution" : "720p" ,
"aspect_ratio" : "16:9"
}
시나리오 2: 단일 이미지-비디오
{
"model" : "Omni-Flash-Ext" ,
"prompt" : "make the character smile and slowly turn around, cinematic camera motion" ,
"duration" : 6 ,
"resolution" : "1080p" ,
"aspect_ratio" : "9:16" ,
"image_urls" : [ "https://example.com/character.jpg" ]
}
시나리오 3: 3장 참조 이미지 융합
{
"model" : "Omni-Flash-Ext" ,
"prompt" : "a creative scene combining these elements with smooth camera motion" ,
"duration" : 10 ,
"resolution" : "1080p" ,
"aspect_ratio" : "9:16" ,
"image_urls" : [
"https://example.com/scene.jpg" ,
"https://example.com/character.jpg" ,
"https://example.com/product.jpg"
]
}
시나리오 4: 4K 짧은 비디오
{
"model" : "Omni-Flash-Ext" ,
"prompt" : "close-up of a hummingbird hovering in front of a red flower" ,
"duration" : 4 ,
"resolution" : "4k" ,
"aspect_ratio" : "16:9"
}
오류 코드
HTTP 오류 유형 의미 해결 방법 400 invalid_request_errormodel이 Omni-Flash-Ext가 아니거나, prompt가 비어 있거나, JSON 형식이 올바르지 않습니다요청 본문을 확인하세요 400 invalid_durationduration이 4, 6, 8, 10 중 하나가 아닙니다지원되는 길이로 변경하세요 400 invalid_resolutionresolution이 720p, 1080p, 4k 중 하나가 아닙니다지원되는 해상도로 변경하세요 400 unsupported_image_countimage_urls 개수가 지원되지 않습니다. 2장을 전달할 때 자주 발생합니다0장, 1장 또는 3장으로 변경하세요 401 authentication_errorToken이 유효하지 않습니다 Bearer Token을 확인하세요 402 payment_required잔액이 부족합니다 충전 후 다시 시도하세요 429 rate_limit_error요청 제한에 도달했습니다 동시 요청 수를 낮추거나 나중에 다시 시도하세요
작업이 실패하면 작업 상태 API가 data.error에 실패 사유를 반환합니다. 일반적인 원인은 업스트림 할당량 일시 부족, 콘텐츠 심사 실패, 업스트림 타임아웃입니다.