메인 콘텐츠로 건너뛰기
POST
/
v1
/
videos
/
generations
curl --request POST \
  --url https://api.evolink.ai/v1/videos/generations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "model": "seedance-2.0-fast-image-to-video",
  "prompt": "The camera slowly zooms in, the scene gradually comes to life",
  "image_urls": [
    "https://example.com/first-frame.jpg"
  ],
  "duration": 5,
  "aspect_ratio": "adaptive"
}
'
{
  "created": 1761313744,
  "id": "task-unified-1774857405-abc123",
  "model": "seedance-2.0-fast-image-to-video",
  "object": "video.generation.task",
  "progress": 0,
  "status": "pending",
  "task_info": {
    "can_cancel": true,
    "estimated_time": 165,
    "video_duration": 8
  },
  "type": "video",
  "usage": {
    "billing_rule": "per_second",
    "credits_reserved": 50,
    "user_group": "default"
  }
}

인증

Authorization
string
header
필수

##모든 API는 Bearer Token 인증이 필요합니다##

API Key 얻기:

API Key 관리 페이지에서 API Key를 받으세요

요청 헤더에 다음을 추가하세요:

Authorization: Bearer YOUR_API_KEY

본문

application/json
model
enum<string>
기본값:seedance-2.0-fast-image-to-video
필수

비디오 생성 모델 이름

사용 가능한 옵션:
seedance-2.0-fast-image-to-video
예시:

"seedance-2.0-fast-image-to-video"

prompt
string
필수

생성할 비디오를 설명하는 텍스트 프롬프트. 중국어와 영어를 지원하며, 중국어는 500자 이내, 영어는 1000단어 이내를 권장합니다

주의:

  • 이 모델은 video_urls, audio_urls 입력을 지원하지 않습니다
예시:

"The camera slowly zooms in, the scene gradually comes to life"

image_urls
string<uri>[]
필수

이미지 URL 배열, 1~2장

이미지 수량 및 동작:

이미지 수량동작역할
1장첫 프레임 이미지-비디오자동으로 first_frame 설정
2장첫/끝 프레임 이미지-비디오1번째 → first_frame, 2번째 → last_frame

이미지 요구사항:

  • 지원 형식: .jpeg, .png, .webp, .bmp, .tiff, .gif
  • 화면 비율(너비/높이): 0.4 ~ 2.5
  • 너비/높이 픽셀: 300 ~ 6000 px
  • 단일 파일 크기: 30MB 이하
  • 요청 본문 총 크기 64MB 이하, 대용량 파일은 Base64 인코딩을 사용하지 마세요
  • 첫/끝 프레임 입력 시 두 이미지가 동일할 수 있습니다. 화면 비율이 다를 경우 첫 프레임을 기준으로 하며, 끝 프레임은 자동으로 크롭하여 맞춥니다
  • 이미지 URL은 서버에서 직접 접근 가능해야 합니다
Required array length: 1 - 2 elements
예시:
["https://example.com/first-frame.jpg"]
duration
integer
기본값:5

비디오 길이(초), 기본값은 5

설명:

  • 4~15초 사이의 임의의 정수값을 지원합니다
  • 재생 시간은 과금에 직접적으로 영향을 미칩니다
필수 범위: 4 <= x <= 15
예시:

5

quality
enum<string>
기본값:720p

비디오 해상도, 기본값은 720p

선택 가능한 값:

  • 480p: 낮은 해상도, 낮은 가격
  • 720p: 표준 해상도, 기본값
사용 가능한 옵션:
480p,
720p
예시:

"720p"

aspect_ratio
enum<string>
기본값:16:9

비디오 화면 비율, 기본값은 16:9

선택 가능한 값:

  • 16:9(가로), 9:16(세로), 1:1(정사각형), 4:3, 3:4, 21:9(울트라와이드)
  • adaptive: 첫 프레임 이미지 비율에 따라 가장 가까운 화면 비율을 자동 선택

각 해상도별 픽셀 값:

화면 비율480p720p
16:9864×4961280×720
4:3752×5601112×834
1:1640×640960×960
3:4560×752834×1112
9:16496×864720×1280
21:9992×4321470×630
사용 가능한 옵션:
16:9,
9:16,
1:1,
4:3,
3:4,
21:9,
adaptive
예시:

"adaptive"

generate_audio
boolean
기본값:true

동기화된 오디오 생성 여부, 기본값은 true

선택 가능한 값:

  • true: 비디오에 동기화된 오디오가 포함되며, 추가 요금이 없습니다
  • false: 무음 비디오 출력
예시:

true

callback_url
string<uri>

작업 완료 후 HTTPS 콜백 주소

콜백 시점:

  • 작업 완료(completed), 실패(failed) 또는 취소(cancelled) 시 트리거
  • 과금 확인 완료 후 전송

보안 제한:

  • HTTPS 프로토콜만 지원
  • 내부 네트워크 IP 주소로의 콜백 금지(127.0.0.1, 10.x.x.x, 172.16-31.x.x, 192.168.x.x 등)
  • URL 길이는 2048자를 초과할 수 없습니다

콜백 메커니즘:

  • 타임아웃: 10
  • 실패 시 최대 3회 재시도(실패 후 각각 1/2/4초 후 재시도)
  • 콜백 응답 본문 형식은 작업 조회 API 반환 형식과 동일
  • 2xx 상태 코드를 성공으로 간주하며, 다른 상태 코드는 재시도를 트리거합니다
예시:

"https://your-domain.com/webhooks/video-task-completed"

응답

비디오 생성 작업이 성공적으로 생성되었습니다

created
integer

작업 생성 타임스탬프

예시:

1761313744

id
string

작업 ID

예시:

"task-unified-1774857405-abc123"

model
string

실제 사용된 모델 이름

예시:

"seedance-2.0-fast-image-to-video"

object
enum<string>

작업의 구체적 유형

사용 가능한 옵션:
video.generation.task
progress
integer

작업 진행률 (0-100)

필수 범위: 0 <= x <= 100
예시:

0

status
enum<string>

작업 상태

사용 가능한 옵션:
pending,
processing,
completed,
failed
예시:

"pending"

task_info
object

비디오 작업 상세 정보

type
enum<string>

작업의 출력 유형

사용 가능한 옵션:
text,
image,
audio,
video
예시:

"video"

usage
object

사용량 및 과금 정보