Skip to content

Create video

client.Videos.New(ctx, body) (*Video, error)
POST/videos

Create a video

ParametersExpand Collapse
body VideoNewParams
Prompt param.Field[string]

Text prompt that describes the video to generate.

maxLength32000
minLength1
InputReference param.Field[Reader]optional

Optional image reference that guides generation.

Model param.Field[VideoModel]optional

The video generation model to use (allowed values: sora-2, sora-2-pro). Defaults to sora-2.

Seconds param.Field[VideoSeconds]optional

Clip duration in seconds (allowed values: 4, 8, 12). Defaults to 4 seconds.

Size param.Field[VideoSize]optional

Output resolution formatted as width x height (allowed values: 720x1280, 1280x720, 1024x1792, 1792x1024). Defaults to 720x1280.

ReturnsExpand Collapse
type Video struct{…}

Structured information describing a generated video job.

ID string

Unique identifier for the video job.

CompletedAt int64

Unix timestamp (seconds) for when the job completed, if finished.

CreatedAt int64

Unix timestamp (seconds) for when the job was created.

Error payload that explains why generation failed, if applicable.

Code string

A machine-readable error code that was returned.

Message string

A human-readable description of the error that was returned.

ExpiresAt int64

Unix timestamp (seconds) for when the downloadable assets expire, if set.

Model VideoModel

The video generation model that produced the job.

Accepts one of the following:
string
type VideoModel string
Accepts one of the following:
const VideoModelSora2 VideoModel = "sora-2"
const VideoModelSora2Pro VideoModel = "sora-2-pro"
const VideoModelSora2_2025_10_06 VideoModel = "sora-2-2025-10-06"
const VideoModelSora2Pro2025_10_06 VideoModel = "sora-2-pro-2025-10-06"
const VideoModelSora2_2025_12_08 VideoModel = "sora-2-2025-12-08"
Object Video

The object type, which is always video.

Progress int64

Approximate completion percentage for the generation task.

Prompt string

The prompt that was used to generate the video.

RemixedFromVideoID string

Identifier of the source video if this video is a remix.

Seconds VideoSeconds

Duration of the generated clip in seconds.

Accepts one of the following:
const VideoSeconds4 VideoSeconds = "4"
const VideoSeconds8 VideoSeconds = "8"
const VideoSeconds12 VideoSeconds = "12"

The resolution of the generated video.

Accepts one of the following:
const VideoSize720x1280 VideoSize = "720x1280"
const VideoSize1280x720 VideoSize = "1280x720"
const VideoSize1024x1792 VideoSize = "1024x1792"
const VideoSize1792x1024 VideoSize = "1792x1024"
Status VideoStatus

Current lifecycle status of the video job.

Accepts one of the following:
const VideoStatusQueued VideoStatus = "queued"
const VideoStatusInProgress VideoStatus = "in_progress"
const VideoStatusCompleted VideoStatus = "completed"
const VideoStatusFailed VideoStatus = "failed"

Create video

package main

import (
  "context"
  "fmt"

  "github.com/openai/openai-go"
)

func main() {
  client := openai.NewClient()
  video, err := client.Videos.New(context.TODO(), openai.VideoNewParams{
    Prompt: "A calico cat playing a piano on stage",
  })
  if err != nil {
    panic(err.Error())
  }
  fmt.Printf("%+v\n", video.ID)
}
{
  "id": "video_123",
  "object": "video",
  "model": "sora-2",
  "status": "queued",
  "progress": 0,
  "created_at": 1712697600,
  "size": "1024x1792",
  "seconds": "8",
  "quality": "standard"
}
Returns Examples
{
  "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": "4",
  "size": "720x1280",
  "status": "queued"
}