메인 콘텐츠로 건너뛰기
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-video-edit",
  "prompt": "Have the character in the video wear the striped sweater from the image",
  "video_urls": [
    "https://cdn.example.com/source.mp4"
  ],
  "image_urls": [
    "https://cdn.example.com/sweater.jpg"
  ],
  "quality": "720p",
  "keep_original_sound": true
}
'
{
  "created": 1761313744,
  "id": "task-unified-1761313744-h1edgh12",
  "model": "happyhorse-1.0-video-edit",
  "object": "video.generation.task",
  "progress": 0,
  "status": "pending",
  "task_info": {
    "can_cancel": true,
    "estimated_time": 2400,
    "video_duration": 6
  },
  "type": "video",
  "usage": {
    "billing_rule": "per_second",
    "credits_reserved": 1608660,
    "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-video-edit
필수

비디오 생성 모델 이름

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

"happyhorse-1.0-video-edit"

prompt
string
필수

편집 지시 텍스트, 필수

길이 제한:

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

프롬프트 팁:

  • 창의적 묘사 대신 편집 지시를 사용하세요
  • 예: 주인공의 옷을 이미지의 줄무늬 스웨터로 교체, 비디오 배경을 설산으로 교체
예시:

"Have the character in the video wear the striped sweater from the image"

video_urls
string<uri>[]
필수

편집할 소스 비디오 URL, 필수, 1개만 (배열의 첫 번째 요소 사용)

비디오 요구 사항:

  • 지원 형식: MP4, MOV (H.264 인코딩 권장)
  • 재생 시간: 3 ~ 60
  • 모델은 15초를 초과하는 입력을 자동으로 첫 15초로 자릅니다
  • 해상도: 긴 변 ≤ 2160 px, 짧은 변 ≥ 320 px
  • 화면 비율: 1:2.5 ~ 2.5:1
  • 파일 크기: ≤ 100MB
  • 프레임 레이트: > 8 fps
  • 비디오 URL은 공개적으로 접근 가능(HTTP 또는 HTTPS)해야 합니다. 비공개 OSS, 인트라넷 또는 인증 필요 링크는 지원되지 않습니다

호환 필드: video_url / video도 허용 (video_urls보다 우선 순위 낮음)

Required array length: 1 element
예시:
["https://cdn.example.com/source.mp4"]
image_urls
string<uri>[]

참조 이미지 URL 배열, 선택 사항, 0 ~ 5장

스타일 / 주체 가이드에 사용.

이미지 요구 사항:

  • 지원 형식: JPEG, JPG, PNG, WEBP
  • 해상도: 너비와 높이 ≥ 300 px
  • 화면 비율: 1:2.5 ~ 2.5:1
  • 파일 크기: ≤ 10MB
  • 이미지 URL은 공개적으로 접근 가능(HTTP 또는 HTTPS)해야 합니다
Maximum array length: 5
예시:
["https://cdn.example.com/sweater.jpg"]
keep_original_sound
boolean
기본값:false

입력 비디오의 원본 오디오 유지 여부, 기본값은 false

옵션:

  • true: 입력 비디오의 원본 오디오 유지
  • false: 원본 오디오 제거; 모델이 새 오디오 생성
예시:

false

quality
enum<string>
기본값:720p

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

옵션:

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

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

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

"720p"

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-h1edgh12"

model
string

실제 사용된 모델 이름

예시:

"happyhorse-1.0-video-edit"

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

사용량 및 과금 정보