Create video
$ openai videos create
post /videos
Create a new video generation job from a prompt and optional reference assets.
Parameters
-
--prompt: stringText prompt that describes the video to generate.
-
--input-reference: optional string or ImageInputReferenceParamOptional reference asset upload or reference object that guides generation.
-
--model: optional string or "sora-2" or "sora-2-pro" or "sora-2-2025-10-06" or 2 moreThe video generation model to use (allowed values: sora-2, sora-2-pro). Defaults to
sora-2. -
--seconds: optional "4" or "8" or "12"Clip duration in seconds (allowed values: 4, 8, 12). Defaults to 4 seconds.
-
--size: optional "720x1280" or "1280x720" or "1024x1792" or "1792x1024"Output resolution formatted as width x height (allowed values: 720x1280, 1280x720, 1024x1792, 1792x1024). Defaults to 720x1280.
Returns
-
video: object { id, completed_at, created_at, 10 more }Structured information describing a generated video job.
-
id: stringUnique identifier for the video job.
-
completed_at: numberUnix timestamp (seconds) for when the job completed, if finished.
-
created_at: numberUnix timestamp (seconds) for when the job was created.
-
error: object { code, message }Error payload that explains why generation failed, if applicable.
-
code: stringA machine-readable error code that was returned.
-
message: stringA human-readable description of the error that was returned.
-
-
expires_at: numberUnix timestamp (seconds) for when the downloadable assets expire, if set.
-
model: string or "sora-2" or "sora-2-pro" or "sora-2-2025-10-06" or 2 moreThe video generation model that produced the job.
-
"sora-2" -
"sora-2-pro" -
"sora-2-2025-10-06" -
"sora-2-pro-2025-10-06" -
"sora-2-2025-12-08"
-
-
object: "video"The object type, which is always
video. -
progress: numberApproximate completion percentage for the generation task.
-
prompt: stringThe prompt that was used to generate the video.
-
remixed_from_video_id: stringIdentifier of the source video if this video is a remix.
-
seconds: string or VideoSecondsDuration of the generated clip in seconds. For extensions, this is the stitched total duration.
-
"4" -
"8" -
"12"
-
-
size: "720x1280" or "1280x720" or "1024x1792" or "1792x1024"The resolution of the generated video.
-
"720x1280" -
"1280x720" -
"1024x1792" -
"1792x1024"
-
-
status: "queued" or "in_progress" or "completed" or "failed"Current lifecycle status of the video job.
-
"queued" -
"in_progress" -
"completed" -
"failed"
-
-
Example
openai videos create \
--api-key 'My API Key' \
--prompt x
Response
{
"id": "id",
"completed_at": 0,
"created_at": 0,
"error": {
"code": "code",
"message": "message"
},
"expires_at": 0,
"model": "string",
"object": "video",
"progress": 0,
"prompt": "prompt",
"remixed_from_video_id": "remixed_from_video_id",
"seconds": "string",
"size": "720x1280",
"status": "queued"
}