메인 콘텐츠로 건너뛰기
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": "happyhorse-1.0-text-to-video",
  "prompt": "A miniature city built from cardboard and bottle caps comes to life at night. A cardboard train slowly passes through, dotted with tiny lights illuminating the path ahead.",
  "quality": "720p",
  "aspect_ratio": "16:9",
  "duration": 5,
  "seed": 42
}
'
{
  "created": 1761313744,
  "id": "task-unified-1761313744-h1t2vab8",
  "model": "happyhorse-1.0-text-to-video",
  "object": "video.generation.task",
  "progress": 0,
  "status": "pending",
  "task_info": {
    "can_cancel": true,
    "estimated_time": 2400,
    "video_duration": 5
  },
  "type": "video",
  "usage": {
    "billing_rule": "per_second",
    "credits_reserved": 607500,
    "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>
기본값:happyhorse-1.0-text-to-video
필수

비디오 생성 모델 이름

사용 가능한 옵션:
happyhorse-1.0-text-to-video
예시:

"happyhorse-1.0-text-to-video"

prompt
string
필수

텍스트 프롬프트, 필수

길이 제한:

  • 중국어: 최대 2500
  • 비중국어: 최대 5000
  • 초과 부분은 자동으로 잘립니다

프롬프트 팁:

  • 샷별 상세한 묘사가 더 나은 멀티샷 서사 결과를 가져옵니다
  • 예: 샷 1 [0~3초] 광각: ...; 샷 2 [3~6초] 미디엄 샷: ...
예시:

"A miniature city built from cardboard and bottle caps comes to life at night. A cardboard train slowly passes through, dotted with tiny lights illuminating the path ahead."

quality
enum<string>
기본값:720p

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

옵션:

  • 720p: 표준 해상도, 기본값
  • 1080p: HD 해상도

과금 참고: 해상도 등급은 과금에 직접 영향을 미칩니다

사용 가능한 옵션:
720p,
1080p
예시:

"720p"

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

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

옵션:

  • 16:9 (가로)
  • 9:16 (세로)
  • 1:1 (정사각형)
  • 4:3
  • 3:4
사용 가능한 옵션:
16:9,
9:16,
1:1,
4:3,
3:4
예시:

"16:9"

duration
integer
기본값:5

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

범위:

  • 정수 3 ~ 15
  • 재생 시간은 과금에 직접 영향을 미칩니다
필수 범위: 3 <= x <= 15
예시:

5

seed
integer

랜덤 시드, 기본값은 랜덤

설명:

  • 범위: 1 ~ 2147483647
  • 고정 시드는 프롬프트 조정 시 파라미터 변동을 줄여 재현성을 향상시킵니다
필수 범위: 1 <= x <= 2147483647
예시:

42

callback_url
string<uri>

작업 완료 후 HTTPS 콜백 주소

콜백 시점:

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

보안 제한:

  • 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-1761313744-h1t2vab8"

model
string

실제 사용된 모델 이름

예시:

"happyhorse-1.0-text-to-video"

object
enum<string>

작업의 구체적 유형

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

작업 진행률 (0-100)

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

0

status
enum<string>

작업 상태

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

"pending"

task_info
object

비디오 작업 상세 정보

type
enum<string>

작업의 출력 유형

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

"video"

usage
object

사용량 및 과금 정보