메인 콘텐츠로 건너뛰기
POST
/
v1
/
videos
/
generations
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"
    }
  ]
}

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"
    }
  ]
}

인증

Authorization
string
필수
모든 요청은 Bearer Token 인증이 필요합니다.API Key 발급:API Key 관리 페이지에서 API Key를 발급받으세요.요청 시 다음 헤더를 추가합니다:
Authorization: Bearer YOUR_API_KEY

요청 파라미터

model
string
필수
비디오 생성 모델 이름입니다. Omni-Flash-Ext로 고정됩니다.
prompt
string
필수
비디오 내용 설명입니다. 장면, 인물, 동작, 환경, 카메라 움직임, 화면 스타일, 오디오 힌트를 자세히 작성하는 것을 권장합니다.예: "a girl is dancing happily in a sunny garden"
duration
integer
기본값:"6"
비디오 길이입니다. 단위는 초입니다.지원 값: 4, 6, 8, 10.
5, 7 등 다른 값을 전달하면 invalid_duration 오류가 반환됩니다.
resolution
string
기본값:"720p"
비디오 해상도입니다. 대소문자를 구분하지 않습니다.지원 값:
  • 720p
  • 1080p
  • 4k
다른 해상도를 전달하면 invalid_resolution 오류가 반환됩니다.
aspect_ratio
string
기본값:"16:9"
비디오 화면 비율입니다. 가로 또는 세로 출력을 제어합니다.자주 사용하는 값:
  • 16:9 - 가로
  • 9:16 - 세로
기본값: 16:9
size
string
호환 필드입니다. aspect_ratio와 같은 의미입니다. 둘 다 전달하는 경우 같은 값으로 유지하는 것을 권장합니다.
image_urls
array<url>
참조 이미지 URL 배열입니다. 생략하거나, 1장 또는 3장을 전달할 수 있습니다:
  • 생략 또는 빈 배열: 텍스트-비디오
  • 1장: 단일 이미지-비디오
  • 3장: 참조 이미지 융합
공개적으로 접근 가능한 이미지 URL을 지원합니다. data:image/...;base64,... 형식의 Base64 이미지도 지원합니다.
2장 이미지로 시작 프레임 + 끝 프레임을 지정하는 모드는 지원하지 않습니다. 2장을 전달하면 unsupported_image_count 오류가 반환됩니다. 4장 이상은 충분히 검증되지 않았으므로 권장하지 않습니다.

응답

code
integer
응답 상태 코드입니다. 성공 시 200입니다.
data
array
작업 배열을 반환합니다.

작업 결과 조회

비디오 생성은 비동기 작업입니다. 제출 후 task_id가 반환됩니다. 작업 상태 조회 API로 진행 상황과 결과를 조회하세요.
cURL
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오류 유형의미해결 방법
400invalid_request_errormodelOmni-Flash-Ext가 아니거나, prompt가 비어 있거나, JSON 형식이 올바르지 않습니다요청 본문을 확인하세요
400invalid_durationduration4, 6, 8, 10 중 하나가 아닙니다지원되는 길이로 변경하세요
400invalid_resolutionresolution720p, 1080p, 4k 중 하나가 아닙니다지원되는 해상도로 변경하세요
400unsupported_image_countimage_urls 개수가 지원되지 않습니다. 2장을 전달할 때 자주 발생합니다0장, 1장 또는 3장으로 변경하세요
401authentication_errorToken이 유효하지 않습니다Bearer Token을 확인하세요
402payment_required잔액이 부족합니다충전 후 다시 시도하세요
429rate_limit_error요청 제한에 도달했습니다동시 요청 수를 낮추거나 나중에 다시 시도하세요
작업이 실패하면 작업 상태 API가 data.error에 실패 사유를 반환합니다. 일반적인 원인은 업스트림 할당량 일시 부족, 콘텐츠 심사 실패, 업스트림 타임아웃입니다.