메인 콘텐츠로 건너뛰기
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": "videoretalk",
  "video_url": "https://example.com/speaker.mp4",
  "audio_url": "https://example.com/target-speech.wav"
}
'
{
  "created": 1775200000,
  "id": "task-unified-1775200000-xyz12345",
  "model": "videoretalk",
  "object": "video.generation.task",
  "progress": 0,
  "status": "pending",
  "task_info": {
    "can_cancel": false,
    "estimated_time": 90,
    "video_duration": 0
  },
  "type": "video",
  "usage": {
    "billing_rule": "per_second",
    "credits_reserved": 480,
    "user_group": "default"
  }
}

인증

Authorization
string
header
필수

##모든 인터페이스는 Bearer Token 인증이 필요합니다##

API Key 발급:

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

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

Authorization: Bearer YOUR_API_KEY

본문

application/json
model
enum<string>
기본값:videoretalk
필수

모델 이름

사용 가능한 옵션:
videoretalk
예시:

"videoretalk"

video_url
string<uri>
필수

입술 동작을 교체할 인물이 포함된 입력 비디오 URL

요구 사항:

  • 공개 인터넷으로 접근 가능한 비디오 URL
  • 형식: MP4, MOV 등 일반적인 형식
  • 비디오에 명확하게 보이는 얼굴이 포함되어야 함
  • 권장 시간: 2 ~ 300
예시:

"https://example.com/speaker.mp4"

audio_url
string<uri>
필수

목표 오디오 URL, 비디오 인물이 이 오디오를 말하는 것처럼 처리됩니다

요구 사항:

  • 공개 인터넷으로 접근 가능한 오디오 URL
  • 형식: WAV, MP3, M4A 등 일반적인 형식
  • 음성 발화 내용 권장
예시:

"https://example.com/target-speech.wav"

ref_image_url
string<uri>

얼굴 참조 이미지 URL

비디오에 여러 얼굴이 있을 때, 이 이미지로 입술 동작을 교체할 목표 얼굴을 지정합니다

요구 사항:

  • 이미지에 목표 인물의 정면 얼굴이 포함되어야 함
  • 비디오에 여러 얼굴이 있을 때만 필요
예시:

"https://example.com/target-person-face.jpg"

video_extension
boolean
기본값:false

오디오 시간 > 비디오 시간일 때, 비디오를 오디오 길이에 맞게 자동 확장할지 여부

  • true: 출력 시간 = 오디오 시간(비디오 자동 확장)
  • false: 출력 시간 = min(비디오 시간, 오디오 시간)
예시:

false

query_face_threshold
integer
기본값:170

얼굴 매칭 신뢰도 임계값

  • 범위: 120 ~ 200
  • 값이 낮을수록 매칭하기 쉬움(오매칭 가능성 있음)
  • 값이 높을수록 더 엄격함(매칭 실패 가능성 있음)
  • '매칭 얼굴을 찾을 수 없음' 오류 시 낮춰보세요(예: 140)
  • 잘못된 얼굴에 매칭되면 높여보세요(예: 190)
필수 범위: 120 <= x <= 200
예시:

170

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초 후 재시도)
  • 콜백 응답 본문 형식은 작업 조회 인터페이스 반환 형식과 동일
  • 콜백 주소가 2xx 상태 코드를 반환하면 성공으로 간주, 그 외 상태 코드는 재시도 트리거
예시:

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

응답

립싱크 비디오 생성 작업 생성 성공

created
integer

작업 생성 타임스탬프

예시:

1775200000

id
string

작업 ID

예시:

"task-unified-1775200000-xyz12345"

model
string

실제 사용된 모델 이름

예시:

"videoretalk"

object
enum<string>

작업의 구체적인 유형

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

작업 진행률 (0-100)

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

0

status
enum<string>

작업 상태

상태progress설명
pending0~10처리 대기 중
processing10~80처리 중
completed100완료
failed0실패
사용 가능한 옵션:
pending,
processing,
completed,
failed
예시:

"pending"

task_info
object

비디오 작업 상세 정보

type
enum<string>

작업의 출력 유형

사용 가능한 옵션:
video
예시:

"video"

usage
object

사용량 및 과금 정보