transcoder

package
v0.181.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 16, 2024 License: BSD-3-Clause Imports: 16 Imported by: 0

Documentation

Overview

Package transcoder provides access to the Transcoder API.

For product documentation, see: https://cloud.google.com/transcoder/docs/

Library status

These client libraries are officially supported by Google. However, this library is considered complete and is in maintenance mode. This means that we will address critical bugs and security issues but will not add any new features.

When possible, we recommend using our newer [Cloud Client Libraries for Go](https://pkg.go.dev/cloud.google.com/go) that are still actively being worked and iterated on.

Creating a client

Usage example:

import "google.golang.org/api/transcoder/v1"
...
ctx := context.Background()
transcoderService, err := transcoder.NewService(ctx)

In this example, Google Application Default Credentials are used for authentication. For information on how to create and obtain Application Default Credentials, see https://developers.google.com/identity/protocols/application-default-credentials.

Other authentication options

To use an API key for authentication (note: some APIs do not support API keys), use google.golang.org/api/option.WithAPIKey:

transcoderService, err := transcoder.NewService(ctx, option.WithAPIKey("AIza..."))

To use an OAuth token (e.g., a user token obtained via a three-legged OAuth flow, use google.golang.org/api/option.WithTokenSource:

config := &oauth2.Config{...}
// ...
token, err := config.Exchange(ctx, ...)
transcoderService, err := transcoder.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token)))

See google.golang.org/api/option.ClientOption for details on options.

Index

Constants

View Source
const (
	// See, edit, configure, and delete your Google Cloud data and see the email
	// address for your Google Account.
	CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform"
)

OAuth2 scopes used by this API.

Variables

This section is empty.

Functions

This section is empty.

Types

type AdBreak

type AdBreak struct {
	// StartTimeOffset: Start time in seconds for the ad break, relative to the
	// output file timeline. The default is `0s`.
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// ForceSendFields is a list of field names (e.g. "StartTimeOffset") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "StartTimeOffset") to include in
	// API requests with the JSON null value. By default, fields with empty values
	// are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AdBreak: Ad break.

func (*AdBreak) MarshalJSON

func (s *AdBreak) MarshalJSON() ([]byte, error)

type Aes128Encryption added in v0.130.0

type Aes128Encryption struct {
}

Aes128Encryption: Configuration for AES-128 encryption.

type Animation

type Animation struct {
	// AnimationEnd: End previous animation.
	AnimationEnd *AnimationEnd `json:"animationEnd,omitempty"`
	// AnimationFade: Display overlay object with fade animation.
	AnimationFade *AnimationFade `json:"animationFade,omitempty"`
	// AnimationStatic: Display static overlay object.
	AnimationStatic *AnimationStatic `json:"animationStatic,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AnimationEnd") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AnimationEnd") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Animation: Animation types.

func (*Animation) MarshalJSON

func (s *Animation) MarshalJSON() ([]byte, error)

type AnimationEnd

type AnimationEnd struct {
	// StartTimeOffset: The time to end overlay object, in seconds. Default: 0
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// ForceSendFields is a list of field names (e.g. "StartTimeOffset") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "StartTimeOffset") to include in
	// API requests with the JSON null value. By default, fields with empty values
	// are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AnimationEnd: End previous overlay animation from the video. Without `AnimationEnd`, the overlay object will keep the state of previous animation until the end of the video.

func (*AnimationEnd) MarshalJSON

func (s *AnimationEnd) MarshalJSON() ([]byte, error)

type AnimationFade

type AnimationFade struct {
	// EndTimeOffset: The time to end the fade animation, in seconds. Default:
	// `start_time_offset` + 1s
	EndTimeOffset string `json:"endTimeOffset,omitempty"`
	// FadeType: Required. Type of fade animation: `FADE_IN` or `FADE_OUT`.
	//
	// Possible values:
	//   "FADE_TYPE_UNSPECIFIED" - The fade type is not specified.
	//   "FADE_IN" - Fade the overlay object into view.
	//   "FADE_OUT" - Fade the overlay object out of view.
	FadeType string `json:"fadeType,omitempty"`
	// StartTimeOffset: The time to start the fade animation, in seconds. Default:
	// 0
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// Xy: Normalized coordinates based on output video resolution. Valid values:
	// `0.0`–`1.0`. `xy` is the upper-left coordinate of the overlay object. For
	// example, use the x and y coordinates {0,0} to position the top-left corner
	// of the overlay animation in the top-left corner of the output video.
	Xy *NormalizedCoordinate `json:"xy,omitempty"`
	// ForceSendFields is a list of field names (e.g. "EndTimeOffset") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "EndTimeOffset") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AnimationFade: Display overlay object with fade animation.

func (*AnimationFade) MarshalJSON

func (s *AnimationFade) MarshalJSON() ([]byte, error)

type AnimationStatic

type AnimationStatic struct {
	// StartTimeOffset: The time to start displaying the overlay object, in
	// seconds. Default: 0
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// Xy: Normalized coordinates based on output video resolution. Valid values:
	// `0.0`–`1.0`. `xy` is the upper-left coordinate of the overlay object. For
	// example, use the x and y coordinates {0,0} to position the top-left corner
	// of the overlay animation in the top-left corner of the output video.
	Xy *NormalizedCoordinate `json:"xy,omitempty"`
	// ForceSendFields is a list of field names (e.g. "StartTimeOffset") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "StartTimeOffset") to include in
	// API requests with the JSON null value. By default, fields with empty values
	// are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AnimationStatic: Display static overlay object.

func (*AnimationStatic) MarshalJSON

func (s *AnimationStatic) MarshalJSON() ([]byte, error)

type Audio

type Audio struct {
	// HighBoost: Enable boosting high frequency components. The default is
	// `false`. **Note:** This field is not supported.
	HighBoost bool `json:"highBoost,omitempty"`
	// LowBoost: Enable boosting low frequency components. The default is `false`.
	// **Note:** This field is not supported.
	LowBoost bool `json:"lowBoost,omitempty"`
	// Lufs: Specify audio loudness normalization in loudness units relative to
	// full scale (LUFS). Enter a value between -24 and 0 (the default), where: *
	// -24 is the Advanced Television Systems Committee (ATSC A/85) standard * -23
	// is the EU R128 broadcast standard * -19 is the prior standard for online
	// mono audio * -18 is the ReplayGain standard * -16 is the prior standard for
	// stereo audio * -14 is the new online audio standard recommended by Spotify,
	// as well as Amazon Echo * 0 disables normalization
	Lufs float64 `json:"lufs,omitempty"`
	// ForceSendFields is a list of field names (e.g. "HighBoost") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "HighBoost") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Audio: Audio preprocessing configuration.

func (*Audio) MarshalJSON

func (s *Audio) MarshalJSON() ([]byte, error)

func (*Audio) UnmarshalJSON

func (s *Audio) UnmarshalJSON(data []byte) error

type AudioMapping

type AudioMapping struct {
	// AtomKey: Required. The EditAtom.key that references the atom with audio
	// inputs in the JobConfig.edit_list.
	AtomKey string `json:"atomKey,omitempty"`
	// GainDb: Audio volume control in dB. Negative values decrease volume,
	// positive values increase. The default is 0.
	GainDb float64 `json:"gainDb,omitempty"`
	// InputChannel: Required. The zero-based index of the channel in the input
	// audio stream.
	InputChannel int64 `json:"inputChannel,omitempty"`
	// InputKey: Required. The Input.key that identifies the input file.
	InputKey string `json:"inputKey,omitempty"`
	// InputTrack: Required. The zero-based index of the track in the input file.
	InputTrack int64 `json:"inputTrack,omitempty"`
	// OutputChannel: Required. The zero-based index of the channel in the output
	// audio stream.
	OutputChannel int64 `json:"outputChannel,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AtomKey") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AtomKey") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AudioMapping: The mapping for the JobConfig.edit_list atoms with audio EditAtom.inputs.

func (*AudioMapping) MarshalJSON

func (s *AudioMapping) MarshalJSON() ([]byte, error)

func (*AudioMapping) UnmarshalJSON

func (s *AudioMapping) UnmarshalJSON(data []byte) error

type AudioStream

type AudioStream struct {
	// BitrateBps: Required. Audio bitrate in bits per second. Must be between 1
	// and 10,000,000.
	BitrateBps int64 `json:"bitrateBps,omitempty"`
	// ChannelCount: Number of audio channels. Must be between 1 and 6. The default
	// is 2.
	ChannelCount int64 `json:"channelCount,omitempty"`
	// ChannelLayout: A list of channel names specifying layout of the audio
	// channels. This only affects the metadata embedded in the container headers,
	// if supported by the specified format. The default is `["fl", "fr"]`.
	// Supported channel names: - `fl` - Front left channel - `fr` - Front right
	// channel - `sl` - Side left channel - `sr` - Side right channel - `fc` -
	// Front center channel - `lfe` - Low frequency
	ChannelLayout []string `json:"channelLayout,omitempty"`
	// Codec: The codec for this audio stream. The default is `aac`. Supported
	// audio codecs: - `aac` - `aac-he` - `aac-he-v2` - `mp3` - `ac3` - `eac3`
	Codec string `json:"codec,omitempty"`
	// DisplayName: The name for this particular audio stream that will be added to
	// the HLS/DASH manifest. Not supported in MP4 files.
	DisplayName string `json:"displayName,omitempty"`
	// LanguageCode: The BCP-47 language code, such as `en-US` or `sr-Latn`. For
	// more information, see
	// https://www.unicode.org/reports/tr35/#Unicode_locale_identifier. Not
	// supported in MP4 files.
	LanguageCode string `json:"languageCode,omitempty"`
	// Mapping: The mapping for the JobConfig.edit_list atoms with audio
	// EditAtom.inputs.
	Mapping []*AudioMapping `json:"mapping,omitempty"`
	// SampleRateHertz: The audio sample rate in Hertz. The default is 48000 Hertz.
	SampleRateHertz int64 `json:"sampleRateHertz,omitempty"`
	// ForceSendFields is a list of field names (e.g. "BitrateBps") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "BitrateBps") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

AudioStream: Audio stream resource.

func (*AudioStream) MarshalJSON

func (s *AudioStream) MarshalJSON() ([]byte, error)

type BwdifConfig added in v0.94.0

type BwdifConfig struct {
	// DeinterlaceAllFrames: Deinterlace all frames rather than just the frames
	// identified as interlaced. The default is `false`.
	DeinterlaceAllFrames bool `json:"deinterlaceAllFrames,omitempty"`
	// Mode: Specifies the deinterlacing mode to adopt. The default is
	// `send_frame`. Supported values: - `send_frame`: Output one frame for each
	// frame - `send_field`: Output one frame for each field
	Mode string `json:"mode,omitempty"`
	// Parity: The picture field parity assumed for the input interlaced video. The
	// default is `auto`. Supported values: - `tff`: Assume the top field is first
	// - `bff`: Assume the bottom field is first - `auto`: Enable automatic
	// detection of field parity
	Parity string `json:"parity,omitempty"`
	// ForceSendFields is a list of field names (e.g. "DeinterlaceAllFrames") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "DeinterlaceAllFrames") to include
	// in API requests with the JSON null value. By default, fields with empty
	// values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

BwdifConfig: Bob Weaver Deinterlacing Filter Configuration.

func (*BwdifConfig) MarshalJSON added in v0.94.0

func (s *BwdifConfig) MarshalJSON() ([]byte, error)

type Clearkey added in v0.130.0

type Clearkey struct {
}

Clearkey: Clearkey configuration.

type Color

type Color struct {
	// Brightness: Control brightness of the video. Enter a value between -1 and 1,
	// where -1 is minimum brightness and 1 is maximum brightness. 0 is no change.
	// The default is 0.
	Brightness float64 `json:"brightness,omitempty"`
	// Contrast: Control black and white contrast of the video. Enter a value
	// between -1 and 1, where -1 is minimum contrast and 1 is maximum contrast. 0
	// is no change. The default is 0.
	Contrast float64 `json:"contrast,omitempty"`
	// Saturation: Control color saturation of the video. Enter a value between -1
	// and 1, where -1 is fully desaturated and 1 is maximum saturation. 0 is no
	// change. The default is 0.
	Saturation float64 `json:"saturation,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Brightness") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Brightness") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Color: Color preprocessing configuration. **Note:** This configuration is not supported.

func (*Color) MarshalJSON

func (s *Color) MarshalJSON() ([]byte, error)

func (*Color) UnmarshalJSON

func (s *Color) UnmarshalJSON(data []byte) error

type Crop

type Crop struct {
	// BottomPixels: The number of pixels to crop from the bottom. The default is
	// 0.
	BottomPixels int64 `json:"bottomPixels,omitempty"`
	// LeftPixels: The number of pixels to crop from the left. The default is 0.
	LeftPixels int64 `json:"leftPixels,omitempty"`
	// RightPixels: The number of pixels to crop from the right. The default is 0.
	RightPixels int64 `json:"rightPixels,omitempty"`
	// TopPixels: The number of pixels to crop from the top. The default is 0.
	TopPixels int64 `json:"topPixels,omitempty"`
	// ForceSendFields is a list of field names (e.g. "BottomPixels") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "BottomPixels") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Crop: Video cropping configuration for the input video. The cropped input video is scaled to match the output resolution.

func (*Crop) MarshalJSON

func (s *Crop) MarshalJSON() ([]byte, error)

type DashConfig added in v0.129.0

type DashConfig struct {
	// SegmentReferenceScheme: The segment reference scheme for a `DASH` manifest.
	// The default is `SEGMENT_LIST`.
	//
	// Possible values:
	//   "SEGMENT_REFERENCE_SCHEME_UNSPECIFIED" - The segment reference scheme is
	// not specified.
	//   "SEGMENT_LIST" - Explicitly lists the URLs of media files for each
	// segment. For example, if SegmentSettings.individual_segments is `true`, then
	// the manifest contains fields similar to the following: “`xml ... “`
	//   "SEGMENT_TEMPLATE_NUMBER" - SegmentSettings.individual_segments must be
	// set to `true` to use this segment reference scheme. Uses the DASH
	// specification “ tag to determine the URLs of media files for each segment.
	// For example: “`xml ... “`
	SegmentReferenceScheme string `json:"segmentReferenceScheme,omitempty"`
	// ForceSendFields is a list of field names (e.g. "SegmentReferenceScheme") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "SegmentReferenceScheme") to
	// include in API requests with the JSON null value. By default, fields with
	// empty values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

DashConfig: `DASH` manifest configuration.

func (*DashConfig) MarshalJSON added in v0.129.0

func (s *DashConfig) MarshalJSON() ([]byte, error)

type Deblock

type Deblock struct {
	// Enabled: Enable deblocker. The default is `false`.
	Enabled bool `json:"enabled,omitempty"`
	// Strength: Set strength of the deblocker. Enter a value between 0 and 1. The
	// higher the value, the stronger the block removal. 0 is no deblocking. The
	// default is 0.
	Strength float64 `json:"strength,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Enabled") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Enabled") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Deblock: Deblock preprocessing configuration. **Note:** This configuration is not supported.

func (*Deblock) MarshalJSON

func (s *Deblock) MarshalJSON() ([]byte, error)

func (*Deblock) UnmarshalJSON

func (s *Deblock) UnmarshalJSON(data []byte) error

type Deinterlace added in v0.94.0

type Deinterlace struct {
	// Bwdif: Specifies the Bob Weaver Deinterlacing Filter Configuration.
	Bwdif *BwdifConfig `json:"bwdif,omitempty"`
	// Yadif: Specifies the Yet Another Deinterlacing Filter Configuration.
	Yadif *YadifConfig `json:"yadif,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Bwdif") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Bwdif") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Deinterlace: Deinterlace configuration for input video.

func (*Deinterlace) MarshalJSON added in v0.94.0

func (s *Deinterlace) MarshalJSON() ([]byte, error)

type Denoise

type Denoise struct {
	// Strength: Set strength of the denoise. Enter a value between 0 and 1. The
	// higher the value, the smoother the image. 0 is no denoising. The default is
	// 0.
	Strength float64 `json:"strength,omitempty"`
	// Tune: Set the denoiser mode. The default is `standard`. Supported denoiser
	// modes: - `standard` - `grain`
	Tune string `json:"tune,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Strength") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Strength") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Denoise: Denoise preprocessing configuration. **Note:** This configuration is not supported.

func (*Denoise) MarshalJSON

func (s *Denoise) MarshalJSON() ([]byte, error)

func (*Denoise) UnmarshalJSON

func (s *Denoise) UnmarshalJSON(data []byte) error

type DrmSystems added in v0.130.0

type DrmSystems struct {
	// Clearkey: Clearkey configuration.
	Clearkey *Clearkey `json:"clearkey,omitempty"`
	// Fairplay: Fairplay configuration.
	Fairplay *Fairplay `json:"fairplay,omitempty"`
	// Playready: Playready configuration.
	Playready *Playready `json:"playready,omitempty"`
	// Widevine: Widevine configuration.
	Widevine *Widevine `json:"widevine,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Clearkey") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Clearkey") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

DrmSystems: Defines configuration for DRM systems in use.

func (*DrmSystems) MarshalJSON added in v0.130.0

func (s *DrmSystems) MarshalJSON() ([]byte, error)

type EditAtom

type EditAtom struct {
	// EndTimeOffset: End time in seconds for the atom, relative to the input file
	// timeline. When `end_time_offset` is not specified, the `inputs` are used
	// until the end of the atom.
	EndTimeOffset string `json:"endTimeOffset,omitempty"`
	// Inputs: List of Input.key values identifying files that should be used in
	// this atom. The listed `inputs` must have the same timeline.
	Inputs []string `json:"inputs,omitempty"`
	// Key: A unique key for this atom. Must be specified when using advanced
	// mapping.
	Key string `json:"key,omitempty"`
	// StartTimeOffset: Start time in seconds for the atom, relative to the input
	// file timeline. The default is `0s`.
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// ForceSendFields is a list of field names (e.g. "EndTimeOffset") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "EndTimeOffset") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

EditAtom: Edit atom.

func (*EditAtom) MarshalJSON

func (s *EditAtom) MarshalJSON() ([]byte, error)

type ElementaryStream

type ElementaryStream struct {
	// AudioStream: Encoding of an audio stream.
	AudioStream *AudioStream `json:"audioStream,omitempty"`
	// Key: A unique key for this elementary stream.
	Key string `json:"key,omitempty"`
	// TextStream: Encoding of a text stream. For example, closed captions or
	// subtitles.
	TextStream *TextStream `json:"textStream,omitempty"`
	// VideoStream: Encoding of a video stream.
	VideoStream *VideoStream `json:"videoStream,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AudioStream") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AudioStream") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

ElementaryStream: Encoding of an input file such as an audio, video, or text track. Elementary streams must be packaged before mapping and sharing between different output formats.

func (*ElementaryStream) MarshalJSON

func (s *ElementaryStream) MarshalJSON() ([]byte, error)

type Empty

type Empty struct {
	// ServerResponse contains the HTTP response code and headers from the server.
	googleapi.ServerResponse `json:"-"`
}

Empty: A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }

type Encryption added in v0.130.0

type Encryption struct {
	// Aes128: Configuration for AES-128 encryption.
	Aes128 *Aes128Encryption `json:"aes128,omitempty"`
	// DrmSystems: Required. DRM system(s) to use; at least one must be specified.
	// If a DRM system is omitted, it is considered disabled.
	DrmSystems *DrmSystems `json:"drmSystems,omitempty"`
	// Id: Required. Identifier for this set of encryption options.
	Id string `json:"id,omitempty"`
	// MpegCenc: Configuration for MPEG Common Encryption (MPEG-CENC).
	MpegCenc *MpegCommonEncryption `json:"mpegCenc,omitempty"`
	// SampleAes: Configuration for SAMPLE-AES encryption.
	SampleAes *SampleAesEncryption `json:"sampleAes,omitempty"`
	// SecretManagerKeySource: Keys are stored in Google Secret Manager.
	SecretManagerKeySource *SecretManagerSource `json:"secretManagerKeySource,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Aes128") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Aes128") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Encryption: Encryption settings.

func (*Encryption) MarshalJSON added in v0.130.0

func (s *Encryption) MarshalJSON() ([]byte, error)

type Fairplay added in v0.130.0

type Fairplay struct {
}

Fairplay: Fairplay configuration.

type Fmp4Config added in v0.142.0

type Fmp4Config struct {
	// CodecTag: Optional. Specify the codec tag string that will be used in the
	// media bitstream. When not specified, the codec appropriate value is used.
	// Supported H265 codec tags: - `hvc1` (default) - `hev1`
	CodecTag string `json:"codecTag,omitempty"`
	// ForceSendFields is a list of field names (e.g. "CodecTag") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "CodecTag") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Fmp4Config: `fmp4` container configuration.

func (*Fmp4Config) MarshalJSON added in v0.142.0

func (s *Fmp4Config) MarshalJSON() ([]byte, error)

type H264CodecSettings

type H264CodecSettings struct {
	// AllowOpenGop: Specifies whether an open Group of Pictures (GOP) structure
	// should be allowed or not. The default is `false`.
	AllowOpenGop bool `json:"allowOpenGop,omitempty"`
	// AqStrength: Specify the intensity of the adaptive quantizer (AQ). Must be
	// between 0 and 1, where 0 disables the quantizer and 1 maximizes the
	// quantizer. A higher value equals a lower bitrate but smoother image. The
	// default is 0.
	AqStrength float64 `json:"aqStrength,omitempty"`
	// BFrameCount: The number of consecutive B-frames. Must be greater than or
	// equal to zero. Must be less than H264CodecSettings.gop_frame_count if set.
	// The default is 0.
	BFrameCount int64 `json:"bFrameCount,omitempty"`
	// BPyramid: Allow B-pyramid for reference frame selection. This may not be
	// supported on all decoders. The default is `false`.
	BPyramid bool `json:"bPyramid,omitempty"`
	// BitrateBps: Required. The video bitrate in bits per second. The minimum
	// value is 1,000. The maximum value is 800,000,000.
	BitrateBps int64 `json:"bitrateBps,omitempty"`
	// CrfLevel: Target CRF level. Must be between 10 and 36, where 10 is the
	// highest quality and 36 is the most efficient compression. The default is 21.
	CrfLevel int64 `json:"crfLevel,omitempty"`
	// EnableTwoPass: Use two-pass encoding strategy to achieve better video
	// quality. H264CodecSettings.rate_control_mode must be `vbr`. The default is
	// `false`.
	EnableTwoPass bool `json:"enableTwoPass,omitempty"`
	// EntropyCoder: The entropy coder to use. The default is `cabac`. Supported
	// entropy coders: - `cavlc` - `cabac`
	EntropyCoder string `json:"entropyCoder,omitempty"`
	// FrameRate: Required. The target video frame rate in frames per second (FPS).
	// Must be less than or equal to 120.
	FrameRate float64 `json:"frameRate,omitempty"`
	// FrameRateConversionStrategy: Optional. Frame rate conversion strategy for
	// desired frame rate. The default is `DOWNSAMPLE`.
	//
	// Possible values:
	//   "FRAME_RATE_CONVERSION_STRATEGY_UNSPECIFIED" - Unspecified frame rate
	// conversion strategy.
	//   "DOWNSAMPLE" - Selectively retain frames to reduce the output frame rate.
	// Every _n_ th frame is kept, where `n = ceil(input frame rate / target frame
	// rate)`. When _n_ = 1 (that is, the target frame rate is greater than the
	// input frame rate), the output frame rate matches the input frame rate. When
	// _n_ > 1, frames are dropped and the output frame rate is equal to `(input
	// frame rate / n)`. For more information, see [Calculate frame
	// rate](https://cloud.google.com/transcoder/docs/concepts/frame-rate).
	//   "DROP_DUPLICATE" - Drop or duplicate frames to match the specified frame
	// rate.
	FrameRateConversionStrategy string `json:"frameRateConversionStrategy,omitempty"`
	// GopDuration: Select the GOP size based on the specified duration. The
	// default is `3s`. Note that `gopDuration` must be less than or equal to
	// `segmentDuration` (#SegmentSettings), and `segmentDuration`
	// (#SegmentSettings) must be divisible by `gopDuration`.
	GopDuration string `json:"gopDuration,omitempty"`
	// GopFrameCount: Select the GOP size based on the specified frame count. Must
	// be greater than zero.
	GopFrameCount int64 `json:"gopFrameCount,omitempty"`
	// HeightPixels: The height of the video in pixels. Must be an even integer.
	// When not specified, the height is adjusted to match the specified width and
	// input aspect ratio. If both are omitted, the input height is used. For
	// portrait videos that contain horizontal ASR and rotation metadata, provide
	// the height, in pixels, per the horizontal ASR. The API calculates the width
	// per the horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	HeightPixels int64 `json:"heightPixels,omitempty"`
	// Hlg: Optional. HLG color format setting for H264.
	Hlg *H264ColorFormatHLG `json:"hlg,omitempty"`
	// PixelFormat: Pixel format to use. The default is `yuv420p`. Supported pixel
	// formats: - `yuv420p` pixel format - `yuv422p` pixel format - `yuv444p` pixel
	// format - `yuv420p10` 10-bit HDR pixel format - `yuv422p10` 10-bit HDR pixel
	// format - `yuv444p10` 10-bit HDR pixel format - `yuv420p12` 12-bit HDR pixel
	// format - `yuv422p12` 12-bit HDR pixel format - `yuv444p12` 12-bit HDR pixel
	// format
	PixelFormat string `json:"pixelFormat,omitempty"`
	// Preset: Enforces the specified codec preset. The default is `veryfast`. The
	// available options are FFmpeg-compatible
	// (https://trac.ffmpeg.org/wiki/Encode/H.264#Preset). Note that certain values
	// for this field may cause the transcoder to override other fields you set in
	// the `H264CodecSettings` message.
	Preset string `json:"preset,omitempty"`
	// Profile: Enforces the specified codec profile. The following profiles are
	// supported: * `baseline` * `main` * `high` (default) The available options
	// are FFmpeg-compatible (https://trac.ffmpeg.org/wiki/Encode/H.264#Tune). Note
	// that certain values for this field may cause the transcoder to override
	// other fields you set in the `H264CodecSettings` message.
	Profile string `json:"profile,omitempty"`
	// RateControlMode: Specify the mode. The default is `vbr`. Supported rate
	// control modes: - `vbr` - variable bitrate - `crf` - constant rate factor
	RateControlMode string `json:"rateControlMode,omitempty"`
	// Sdr: Optional. SDR color format setting for H264.
	Sdr *H264ColorFormatSDR `json:"sdr,omitempty"`
	// Tune: Enforces the specified codec tune. The available options are
	// FFmpeg-compatible (https://trac.ffmpeg.org/wiki/Encode/H.264#Tune). Note
	// that certain values for this field may cause the transcoder to override
	// other fields you set in the `H264CodecSettings` message.
	Tune string `json:"tune,omitempty"`
	// VbvFullnessBits: Initial fullness of the Video Buffering Verifier (VBV)
	// buffer in bits. Must be greater than zero. The default is equal to 90% of
	// H264CodecSettings.vbv_size_bits.
	VbvFullnessBits int64 `json:"vbvFullnessBits,omitempty"`
	// VbvSizeBits: Size of the Video Buffering Verifier (VBV) buffer in bits. Must
	// be greater than zero. The default is equal to H264CodecSettings.bitrate_bps.
	VbvSizeBits int64 `json:"vbvSizeBits,omitempty"`
	// WidthPixels: The width of the video in pixels. Must be an even integer. When
	// not specified, the width is adjusted to match the specified height and input
	// aspect ratio. If both are omitted, the input width is used. For portrait
	// videos that contain horizontal ASR and rotation metadata, provide the width,
	// in pixels, per the horizontal ASR. The API calculates the height per the
	// horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	WidthPixels int64 `json:"widthPixels,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AllowOpenGop") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AllowOpenGop") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

H264CodecSettings: H264 codec settings.

func (*H264CodecSettings) MarshalJSON

func (s *H264CodecSettings) MarshalJSON() ([]byte, error)

func (*H264CodecSettings) UnmarshalJSON

func (s *H264CodecSettings) UnmarshalJSON(data []byte) error

type H264ColorFormatHLG added in v0.162.0

type H264ColorFormatHLG struct {
}

H264ColorFormatHLG: Convert the input video to a Hybrid Log Gamma (HLG) video.

type H264ColorFormatSDR added in v0.162.0

type H264ColorFormatSDR struct {
}

H264ColorFormatSDR: Convert the input video to a Standard Dynamic Range (SDR) video.

type H265CodecSettings

type H265CodecSettings struct {
	// AllowOpenGop: Specifies whether an open Group of Pictures (GOP) structure
	// should be allowed or not. The default is `false`.
	AllowOpenGop bool `json:"allowOpenGop,omitempty"`
	// AqStrength: Specify the intensity of the adaptive quantizer (AQ). Must be
	// between 0 and 1, where 0 disables the quantizer and 1 maximizes the
	// quantizer. A higher value equals a lower bitrate but smoother image. The
	// default is 0.
	AqStrength float64 `json:"aqStrength,omitempty"`
	// BFrameCount: The number of consecutive B-frames. Must be greater than or
	// equal to zero. Must be less than H265CodecSettings.gop_frame_count if set.
	// The default is 0.
	BFrameCount int64 `json:"bFrameCount,omitempty"`
	// BPyramid: Allow B-pyramid for reference frame selection. This may not be
	// supported on all decoders. The default is `false`.
	BPyramid bool `json:"bPyramid,omitempty"`
	// BitrateBps: Required. The video bitrate in bits per second. The minimum
	// value is 1,000. The maximum value is 800,000,000.
	BitrateBps int64 `json:"bitrateBps,omitempty"`
	// CrfLevel: Target CRF level. Must be between 10 and 36, where 10 is the
	// highest quality and 36 is the most efficient compression. The default is 21.
	CrfLevel int64 `json:"crfLevel,omitempty"`
	// EnableTwoPass: Use two-pass encoding strategy to achieve better video
	// quality. H265CodecSettings.rate_control_mode must be `vbr`. The default is
	// `false`.
	EnableTwoPass bool `json:"enableTwoPass,omitempty"`
	// FrameRate: Required. The target video frame rate in frames per second (FPS).
	// Must be less than or equal to 120.
	FrameRate float64 `json:"frameRate,omitempty"`
	// FrameRateConversionStrategy: Optional. Frame rate conversion strategy for
	// desired frame rate. The default is `DOWNSAMPLE`.
	//
	// Possible values:
	//   "FRAME_RATE_CONVERSION_STRATEGY_UNSPECIFIED" - Unspecified frame rate
	// conversion strategy.
	//   "DOWNSAMPLE" - Selectively retain frames to reduce the output frame rate.
	// Every _n_ th frame is kept, where `n = ceil(input frame rate / target frame
	// rate)`. When _n_ = 1 (that is, the target frame rate is greater than the
	// input frame rate), the output frame rate matches the input frame rate. When
	// _n_ > 1, frames are dropped and the output frame rate is equal to `(input
	// frame rate / n)`. For more information, see [Calculate frame
	// rate](https://cloud.google.com/transcoder/docs/concepts/frame-rate).
	//   "DROP_DUPLICATE" - Drop or duplicate frames to match the specified frame
	// rate.
	FrameRateConversionStrategy string `json:"frameRateConversionStrategy,omitempty"`
	// GopDuration: Select the GOP size based on the specified duration. The
	// default is `3s`. Note that `gopDuration` must be less than or equal to
	// `segmentDuration` (#SegmentSettings), and `segmentDuration`
	// (#SegmentSettings) must be divisible by `gopDuration`.
	GopDuration string `json:"gopDuration,omitempty"`
	// GopFrameCount: Select the GOP size based on the specified frame count. Must
	// be greater than zero.
	GopFrameCount int64 `json:"gopFrameCount,omitempty"`
	// Hdr10: Optional. HDR10 color format setting for H265.
	Hdr10 *H265ColorFormatHDR10 `json:"hdr10,omitempty"`
	// HeightPixels: The height of the video in pixels. Must be an even integer.
	// When not specified, the height is adjusted to match the specified width and
	// input aspect ratio. If both are omitted, the input height is used. For
	// portrait videos that contain horizontal ASR and rotation metadata, provide
	// the height, in pixels, per the horizontal ASR. The API calculates the width
	// per the horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	HeightPixels int64 `json:"heightPixels,omitempty"`
	// Hlg: Optional. HLG color format setting for H265.
	Hlg *H265ColorFormatHLG `json:"hlg,omitempty"`
	// PixelFormat: Pixel format to use. The default is `yuv420p`. Supported pixel
	// formats: - `yuv420p` pixel format - `yuv422p` pixel format - `yuv444p` pixel
	// format - `yuv420p10` 10-bit HDR pixel format - `yuv422p10` 10-bit HDR pixel
	// format - `yuv444p10` 10-bit HDR pixel format - `yuv420p12` 12-bit HDR pixel
	// format - `yuv422p12` 12-bit HDR pixel format - `yuv444p12` 12-bit HDR pixel
	// format
	PixelFormat string `json:"pixelFormat,omitempty"`
	// Preset: Enforces the specified codec preset. The default is `veryfast`. The
	// available options are FFmpeg-compatible
	// (https://trac.ffmpeg.org/wiki/Encode/H.265). Note that certain values for
	// this field may cause the transcoder to override other fields you set in the
	// `H265CodecSettings` message.
	Preset string `json:"preset,omitempty"`
	// Profile: Enforces the specified codec profile. The following profiles are
	// supported: * 8-bit profiles * `main` (default) * `main-intra` *
	// `mainstillpicture` * 10-bit profiles * `main10` (default) * `main10-intra` *
	// `main422-10` * `main422-10-intra` * `main444-10` * `main444-10-intra` *
	// 12-bit profiles * `main12` (default) * `main12-intra` * `main422-12` *
	// `main422-12-intra` * `main444-12` * `main444-12-intra` The available options
	// are FFmpeg-compatible (https://x265.readthedocs.io/). Note that certain
	// values for this field may cause the transcoder to override other fields you
	// set in the `H265CodecSettings` message.
	Profile string `json:"profile,omitempty"`
	// RateControlMode: Specify the mode. The default is `vbr`. Supported rate
	// control modes: - `vbr` - variable bitrate - `crf` - constant rate factor
	RateControlMode string `json:"rateControlMode,omitempty"`
	// Sdr: Optional. SDR color format setting for H265.
	Sdr *H265ColorFormatSDR `json:"sdr,omitempty"`
	// Tune: Enforces the specified codec tune. The available options are
	// FFmpeg-compatible (https://trac.ffmpeg.org/wiki/Encode/H.265). Note that
	// certain values for this field may cause the transcoder to override other
	// fields you set in the `H265CodecSettings` message.
	Tune string `json:"tune,omitempty"`
	// VbvFullnessBits: Initial fullness of the Video Buffering Verifier (VBV)
	// buffer in bits. Must be greater than zero. The default is equal to 90% of
	// H265CodecSettings.vbv_size_bits.
	VbvFullnessBits int64 `json:"vbvFullnessBits,omitempty"`
	// VbvSizeBits: Size of the Video Buffering Verifier (VBV) buffer in bits. Must
	// be greater than zero. The default is equal to `VideoStream.bitrate_bps`.
	VbvSizeBits int64 `json:"vbvSizeBits,omitempty"`
	// WidthPixels: The width of the video in pixels. Must be an even integer. When
	// not specified, the width is adjusted to match the specified height and input
	// aspect ratio. If both are omitted, the input width is used. For portrait
	// videos that contain horizontal ASR and rotation metadata, provide the width,
	// in pixels, per the horizontal ASR. The API calculates the height per the
	// horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	WidthPixels int64 `json:"widthPixels,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AllowOpenGop") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AllowOpenGop") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

H265CodecSettings: H265 codec settings.

func (*H265CodecSettings) MarshalJSON

func (s *H265CodecSettings) MarshalJSON() ([]byte, error)

func (*H265CodecSettings) UnmarshalJSON

func (s *H265CodecSettings) UnmarshalJSON(data []byte) error

type H265ColorFormatHDR10 added in v0.162.0

type H265ColorFormatHDR10 struct {
}

H265ColorFormatHDR10: Convert the input video to a High Dynamic Range 10 (HDR10) video.

type H265ColorFormatHLG added in v0.162.0

type H265ColorFormatHLG struct {
}

H265ColorFormatHLG: Convert the input video to a Hybrid Log Gamma (HLG) video.

type H265ColorFormatSDR added in v0.162.0

type H265ColorFormatSDR struct {
}

H265ColorFormatSDR: Convert the input video to a Standard Dynamic Range (SDR) video.

type Image

type Image struct {
	// Alpha: Target image opacity. Valid values are from `1.0` (solid, default) to
	// `0.0` (transparent), exclusive. Set this to a value greater than `0.0`.
	Alpha float64 `json:"alpha,omitempty"`
	// Resolution: Normalized image resolution, based on output video resolution.
	// Valid values: `0.0`–`1.0`. To respect the original image aspect ratio, set
	// either `x` or `y` to `0.0`. To use the original image resolution, set both
	// `x` and `y` to `0.0`.
	Resolution *NormalizedCoordinate `json:"resolution,omitempty"`
	// Uri: Required. URI of the image in Cloud Storage. For example,
	// `gs://bucket/inputs/image.png`. Only PNG and JPEG images are supported.
	Uri string `json:"uri,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Alpha") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Alpha") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Image: Overlaid image.

func (*Image) MarshalJSON

func (s *Image) MarshalJSON() ([]byte, error)

func (*Image) UnmarshalJSON

func (s *Image) UnmarshalJSON(data []byte) error

type Input

type Input struct {
	// Key: A unique key for this input. Must be specified when using advanced
	// mapping and edit lists.
	Key string `json:"key,omitempty"`
	// PreprocessingConfig: Preprocessing configurations.
	PreprocessingConfig *PreprocessingConfig `json:"preprocessingConfig,omitempty"`
	// Uri: URI of the media. Input files must be at least 5 seconds in duration
	// and stored in Cloud Storage (for example, `gs://bucket/inputs/file.mp4`). If
	// empty, the value is populated from Job.input_uri. See Supported input and
	// output formats
	// (https://cloud.google.com/transcoder/docs/concepts/supported-input-and-output-formats).
	Uri string `json:"uri,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Key") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Key") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Input: Input asset.

func (*Input) MarshalJSON

func (s *Input) MarshalJSON() ([]byte, error)

type Job

type Job struct {
	// BatchModePriority: The processing priority of a batch job. This field can
	// only be set for batch mode jobs. The default value is 0. This value cannot
	// be negative. Higher values correspond to higher priorities for the job.
	BatchModePriority int64 `json:"batchModePriority,omitempty"`
	// Config: The configuration for this job.
	Config *JobConfig `json:"config,omitempty"`
	// CreateTime: Output only. The time the job was created.
	CreateTime string `json:"createTime,omitempty"`
	// EndTime: Output only. The time the transcoding finished.
	EndTime string `json:"endTime,omitempty"`
	// Error: Output only. An error object that describes the reason for the
	// failure. This property is always present when ProcessingState is `FAILED`.
	Error *Status `json:"error,omitempty"`
	// InputUri: Input only. Specify the `input_uri` to populate empty `uri` fields
	// in each element of `Job.config.inputs` or `JobTemplate.config.inputs` when
	// using template. URI of the media. Input files must be at least 5 seconds in
	// duration and stored in Cloud Storage (for example,
	// `gs://bucket/inputs/file.mp4`). See Supported input and output formats
	// (https://cloud.google.com/transcoder/docs/concepts/supported-input-and-output-formats).
	InputUri string `json:"inputUri,omitempty"`
	// Labels: The labels associated with this job. You can use these to organize
	// and group your jobs.
	Labels map[string]string `json:"labels,omitempty"`
	// Mode: The processing mode of the job. The default is
	// `PROCESSING_MODE_INTERACTIVE`.
	//
	// Possible values:
	//   "PROCESSING_MODE_UNSPECIFIED" - The job processing mode is not specified.
	//   "PROCESSING_MODE_INTERACTIVE" - The job processing mode is interactive
	// mode. Interactive job will either be ran or rejected if quota does not allow
	// for it.
	//   "PROCESSING_MODE_BATCH" - The job processing mode is batch mode. Batch
	// mode allows queuing of jobs.
	Mode string `json:"mode,omitempty"`
	// Name: The resource name of the job. Format:
	// `projects/{project_number}/locations/{location}/jobs/{job}`
	Name string `json:"name,omitempty"`
	// Optimization: Optional. The optimization strategy of the job. The default is
	// `AUTODETECT`.
	//
	// Possible values:
	//   "OPTIMIZATION_STRATEGY_UNSPECIFIED" - The optimization strategy is not
	// specified.
	//   "AUTODETECT" - Prioritize job processing speed.
	//   "DISABLED" - Disable all optimizations.
	Optimization string `json:"optimization,omitempty"`
	// OutputUri: Input only. Specify the `output_uri` to populate an empty
	// `Job.config.output.uri` or `JobTemplate.config.output.uri` when using
	// template. URI for the output file(s). For example,
	// `gs://my-bucket/outputs/`. See Supported input and output formats
	// (https://cloud.google.com/transcoder/docs/concepts/supported-input-and-output-formats).
	OutputUri string `json:"outputUri,omitempty"`
	// StartTime: Output only. The time the transcoding started.
	StartTime string `json:"startTime,omitempty"`
	// State: Output only. The current state of the job.
	//
	// Possible values:
	//   "PROCESSING_STATE_UNSPECIFIED" - The processing state is not specified.
	//   "PENDING" - The job is enqueued and will be picked up for processing soon.
	//   "RUNNING" - The job is being processed.
	//   "SUCCEEDED" - The job has been completed successfully.
	//   "FAILED" - The job has failed. For additional information, see
	// [Troubleshooting](https://cloud.google.com/transcoder/docs/troubleshooting).
	State string `json:"state,omitempty"`
	// TemplateId: Input only. Specify the `template_id` to use for populating
	// `Job.config`. The default is `preset/web-hd`, which is the only supported
	// preset. User defined JobTemplate: `{job_template_id}`
	TemplateId string `json:"templateId,omitempty"`
	// TtlAfterCompletionDays: Job time to live value in days, which will be
	// effective after job completion. Job should be deleted automatically after
	// the given TTL. Enter a value between 1 and 90. The default is 30.
	TtlAfterCompletionDays int64 `json:"ttlAfterCompletionDays,omitempty"`

	// ServerResponse contains the HTTP response code and headers from the server.
	googleapi.ServerResponse `json:"-"`
	// ForceSendFields is a list of field names (e.g. "BatchModePriority") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "BatchModePriority") to include in
	// API requests with the JSON null value. By default, fields with empty values
	// are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Job: Transcoding job resource.

func (*Job) MarshalJSON

func (s *Job) MarshalJSON() ([]byte, error)

type JobConfig

type JobConfig struct {
	// AdBreaks: List of ad breaks. Specifies where to insert ad break tags in the
	// output manifests.
	AdBreaks []*AdBreak `json:"adBreaks,omitempty"`
	// EditList: List of edit atoms. Defines the ultimate timeline of the resulting
	// file or manifest.
	EditList []*EditAtom `json:"editList,omitempty"`
	// ElementaryStreams: List of elementary streams.
	ElementaryStreams []*ElementaryStream `json:"elementaryStreams,omitempty"`
	// Encryptions: List of encryption configurations for the content. Each
	// configuration has an ID. Specify this ID in the MuxStream.encryption_id
	// field to indicate the configuration to use for that `MuxStream` output.
	Encryptions []*Encryption `json:"encryptions,omitempty"`
	// Inputs: List of input assets stored in Cloud Storage.
	Inputs []*Input `json:"inputs,omitempty"`
	// Manifests: List of output manifests.
	Manifests []*Manifest `json:"manifests,omitempty"`
	// MuxStreams: List of multiplexing settings for output streams.
	MuxStreams []*MuxStream `json:"muxStreams,omitempty"`
	// Output: Output configuration.
	Output *Output `json:"output,omitempty"`
	// Overlays: List of overlays on the output video, in descending Z-order.
	Overlays []*Overlay `json:"overlays,omitempty"`
	// PubsubDestination: Destination on Pub/Sub.
	PubsubDestination *PubsubDestination `json:"pubsubDestination,omitempty"`
	// SpriteSheets: List of output sprite sheets. Spritesheets require at least
	// one VideoStream in the Jobconfig.
	SpriteSheets []*SpriteSheet `json:"spriteSheets,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AdBreaks") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AdBreaks") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

JobConfig: Job configuration

func (*JobConfig) MarshalJSON

func (s *JobConfig) MarshalJSON() ([]byte, error)

type JobTemplate

type JobTemplate struct {
	// Config: The configuration for this template.
	Config *JobConfig `json:"config,omitempty"`
	// Labels: The labels associated with this job template. You can use these to
	// organize and group your job templates.
	Labels map[string]string `json:"labels,omitempty"`
	// Name: The resource name of the job template. Format:
	// `projects/{project_number}/locations/{location}/jobTemplates/{job_template}`
	Name string `json:"name,omitempty"`

	// ServerResponse contains the HTTP response code and headers from the server.
	googleapi.ServerResponse `json:"-"`
	// ForceSendFields is a list of field names (e.g. "Config") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Config") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

JobTemplate: Transcoding job template resource.

func (*JobTemplate) MarshalJSON

func (s *JobTemplate) MarshalJSON() ([]byte, error)

type ListJobTemplatesResponse

type ListJobTemplatesResponse struct {
	// JobTemplates: List of job templates in the specified region.
	JobTemplates []*JobTemplate `json:"jobTemplates,omitempty"`
	// NextPageToken: The pagination token.
	NextPageToken string `json:"nextPageToken,omitempty"`
	// Unreachable: List of regions that could not be reached.
	Unreachable []string `json:"unreachable,omitempty"`

	// ServerResponse contains the HTTP response code and headers from the server.
	googleapi.ServerResponse `json:"-"`
	// ForceSendFields is a list of field names (e.g. "JobTemplates") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "JobTemplates") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

ListJobTemplatesResponse: Response message for `TranscoderService.ListJobTemplates`.

func (*ListJobTemplatesResponse) MarshalJSON

func (s *ListJobTemplatesResponse) MarshalJSON() ([]byte, error)

type ListJobsResponse

type ListJobsResponse struct {
	// Jobs: List of jobs in the specified region.
	Jobs []*Job `json:"jobs,omitempty"`
	// NextPageToken: The pagination token.
	NextPageToken string `json:"nextPageToken,omitempty"`
	// Unreachable: List of regions that could not be reached.
	Unreachable []string `json:"unreachable,omitempty"`

	// ServerResponse contains the HTTP response code and headers from the server.
	googleapi.ServerResponse `json:"-"`
	// ForceSendFields is a list of field names (e.g. "Jobs") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Jobs") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

ListJobsResponse: Response message for `TranscoderService.ListJobs`.

func (*ListJobsResponse) MarshalJSON

func (s *ListJobsResponse) MarshalJSON() ([]byte, error)

type Manifest

type Manifest struct {
	// Dash: `DASH` manifest configuration.
	Dash *DashConfig `json:"dash,omitempty"`
	// FileName: The name of the generated file. The default is `manifest` with the
	// extension suffix corresponding to the Manifest.type.
	FileName string `json:"fileName,omitempty"`
	// MuxStreams: Required. List of user supplied MuxStream.key values that should
	// appear in this manifest. When Manifest.type is `HLS`, a media manifest with
	// name MuxStream.key and `.m3u8` extension is generated for each element in
	// this list.
	MuxStreams []string `json:"muxStreams,omitempty"`
	// Type: Required. Type of the manifest.
	//
	// Possible values:
	//   "MANIFEST_TYPE_UNSPECIFIED" - The manifest type is not specified.
	//   "HLS" - Create an HLS manifest. The corresponding file extension is
	// `.m3u8`.
	//   "DASH" - Create an MPEG-DASH manifest. The corresponding file extension is
	// `.mpd`.
	Type string `json:"type,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Dash") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Dash") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Manifest: Manifest configuration.

func (*Manifest) MarshalJSON

func (s *Manifest) MarshalJSON() ([]byte, error)

type MpegCommonEncryption added in v0.130.0

type MpegCommonEncryption struct {
	// Scheme: Required. Specify the encryption scheme. Supported encryption
	// schemes: - `cenc` - `cbcs`
	Scheme string `json:"scheme,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Scheme") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Scheme") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

MpegCommonEncryption: Configuration for MPEG Common Encryption (MPEG-CENC).

func (*MpegCommonEncryption) MarshalJSON added in v0.130.0

func (s *MpegCommonEncryption) MarshalJSON() ([]byte, error)

type MuxStream

type MuxStream struct {
	// Container: The container format. The default is `mp4` Supported container
	// formats: - `ts` - `fmp4`- the corresponding file extension is `.m4s` - `mp4`
	// - `vtt` See also: Supported input and output formats
	// (https://cloud.google.com/transcoder/docs/concepts/supported-input-and-output-formats)
	Container string `json:"container,omitempty"`
	// ElementaryStreams: List of ElementaryStream.key values multiplexed in this
	// stream.
	ElementaryStreams []string `json:"elementaryStreams,omitempty"`
	// EncryptionId: Identifier of the encryption configuration to use. If omitted,
	// output will be unencrypted.
	EncryptionId string `json:"encryptionId,omitempty"`
	// FileName: The name of the generated file. The default is MuxStream.key with
	// the extension suffix corresponding to the MuxStream.container. Individual
	// segments also have an incremental 10-digit zero-padded suffix starting from
	// 0 before the extension, such as `mux_stream0000000123.ts`.
	FileName string `json:"fileName,omitempty"`
	// Fmp4: Optional. `fmp4` container configuration.
	Fmp4 *Fmp4Config `json:"fmp4,omitempty"`
	// Key: A unique key for this multiplexed stream.
	Key string `json:"key,omitempty"`
	// SegmentSettings: Segment settings for `ts`, `fmp4` and `vtt`.
	SegmentSettings *SegmentSettings `json:"segmentSettings,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Container") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Container") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

MuxStream: Multiplexing settings for output stream.

func (*MuxStream) MarshalJSON

func (s *MuxStream) MarshalJSON() ([]byte, error)

type NormalizedCoordinate

type NormalizedCoordinate struct {
	// X: Normalized x coordinate.
	X float64 `json:"x,omitempty"`
	// Y: Normalized y coordinate.
	Y float64 `json:"y,omitempty"`
	// ForceSendFields is a list of field names (e.g. "X") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "X") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

NormalizedCoordinate: 2D normalized coordinates. Default: `{0.0, 0.0}`

func (*NormalizedCoordinate) MarshalJSON

func (s *NormalizedCoordinate) MarshalJSON() ([]byte, error)

func (*NormalizedCoordinate) UnmarshalJSON

func (s *NormalizedCoordinate) UnmarshalJSON(data []byte) error

type Output

type Output struct {
	// Uri: URI for the output file(s). For example, `gs://my-bucket/outputs/`. If
	// empty, the value is populated from Job.output_uri. See Supported input and
	// output formats
	// (https://cloud.google.com/transcoder/docs/concepts/supported-input-and-output-formats).
	Uri string `json:"uri,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Uri") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Uri") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Output: Location of output file(s) in a Cloud Storage bucket.

func (*Output) MarshalJSON

func (s *Output) MarshalJSON() ([]byte, error)

type Overlay

type Overlay struct {
	// Animations: List of animations. The list should be chronological, without
	// any time overlap.
	Animations []*Animation `json:"animations,omitempty"`
	// Image: Image overlay.
	Image *Image `json:"image,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Animations") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Animations") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Overlay: Overlay configuration.

func (*Overlay) MarshalJSON

func (s *Overlay) MarshalJSON() ([]byte, error)

type Pad

type Pad struct {
	// BottomPixels: The number of pixels to add to the bottom. The default is 0.
	BottomPixels int64 `json:"bottomPixels,omitempty"`
	// LeftPixels: The number of pixels to add to the left. The default is 0.
	LeftPixels int64 `json:"leftPixels,omitempty"`
	// RightPixels: The number of pixels to add to the right. The default is 0.
	RightPixels int64 `json:"rightPixels,omitempty"`
	// TopPixels: The number of pixels to add to the top. The default is 0.
	TopPixels int64 `json:"topPixels,omitempty"`
	// ForceSendFields is a list of field names (e.g. "BottomPixels") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "BottomPixels") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Pad: Pad filter configuration for the input video. The padded input video is scaled after padding with black to match the output resolution.

func (*Pad) MarshalJSON

func (s *Pad) MarshalJSON() ([]byte, error)

type Playready added in v0.130.0

type Playready struct {
}

Playready: Playready configuration.

type PreprocessingConfig

type PreprocessingConfig struct {
	// Audio: Audio preprocessing configuration.
	Audio *Audio `json:"audio,omitempty"`
	// Color: Color preprocessing configuration.
	Color *Color `json:"color,omitempty"`
	// Crop: Specify the video cropping configuration.
	Crop *Crop `json:"crop,omitempty"`
	// Deblock: Deblock preprocessing configuration.
	Deblock *Deblock `json:"deblock,omitempty"`
	// Deinterlace: Specify the video deinterlace configuration.
	Deinterlace *Deinterlace `json:"deinterlace,omitempty"`
	// Denoise: Denoise preprocessing configuration.
	Denoise *Denoise `json:"denoise,omitempty"`
	// Pad: Specify the video pad filter configuration.
	Pad *Pad `json:"pad,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Audio") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Audio") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

PreprocessingConfig: Preprocessing configurations.

func (*PreprocessingConfig) MarshalJSON

func (s *PreprocessingConfig) MarshalJSON() ([]byte, error)

type ProjectsLocationsJobTemplatesCreateCall

type ProjectsLocationsJobTemplatesCreateCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobTemplatesCreateCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobTemplatesCreateCall) Do

Do executes the "transcoder.projects.locations.jobTemplates.create" call. Any non-2xx status code is an error. Response headers are in either *JobTemplate.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobTemplatesCreateCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobTemplatesCreateCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

func (*ProjectsLocationsJobTemplatesCreateCall) JobTemplateId

JobTemplateId sets the optional parameter "jobTemplateId": Required. The ID to use for the job template, which will become the final component of the job template's resource name. This value should be 4-63 characters, and valid characters must match the regular expression `a-zA-Z*`.

type ProjectsLocationsJobTemplatesDeleteCall

type ProjectsLocationsJobTemplatesDeleteCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobTemplatesDeleteCall) AllowMissing

AllowMissing sets the optional parameter "allowMissing": If set to true, and the job template is not found, the request will succeed but no action will be taken on the server.

func (*ProjectsLocationsJobTemplatesDeleteCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobTemplatesDeleteCall) Do

Do executes the "transcoder.projects.locations.jobTemplates.delete" call. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobTemplatesDeleteCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobTemplatesDeleteCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

type ProjectsLocationsJobTemplatesGetCall

type ProjectsLocationsJobTemplatesGetCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobTemplatesGetCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobTemplatesGetCall) Do

Do executes the "transcoder.projects.locations.jobTemplates.get" call. Any non-2xx status code is an error. Response headers are in either *JobTemplate.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobTemplatesGetCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobTemplatesGetCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

func (*ProjectsLocationsJobTemplatesGetCall) IfNoneMatch

IfNoneMatch sets an optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request.

type ProjectsLocationsJobTemplatesListCall

type ProjectsLocationsJobTemplatesListCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobTemplatesListCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobTemplatesListCall) Do

Do executes the "transcoder.projects.locations.jobTemplates.list" call. Any non-2xx status code is an error. Response headers are in either *ListJobTemplatesResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobTemplatesListCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobTemplatesListCall) Filter

Filter sets the optional parameter "filter": The filter expression, following the syntax outlined in https://google.aip.dev/160.

func (*ProjectsLocationsJobTemplatesListCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

func (*ProjectsLocationsJobTemplatesListCall) IfNoneMatch

IfNoneMatch sets an optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request.

func (*ProjectsLocationsJobTemplatesListCall) OrderBy

OrderBy sets the optional parameter "orderBy": One or more fields to compare and use to sort the output. See https://google.aip.dev/132#ordering.

func (*ProjectsLocationsJobTemplatesListCall) PageSize

PageSize sets the optional parameter "pageSize": The maximum number of items to return.

func (*ProjectsLocationsJobTemplatesListCall) PageToken

PageToken sets the optional parameter "pageToken": The `next_page_token` value returned from a previous List request, if any.

func (*ProjectsLocationsJobTemplatesListCall) Pages

Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

type ProjectsLocationsJobTemplatesService

type ProjectsLocationsJobTemplatesService struct {
	// contains filtered or unexported fields
}

func NewProjectsLocationsJobTemplatesService

func NewProjectsLocationsJobTemplatesService(s *Service) *ProjectsLocationsJobTemplatesService

func (*ProjectsLocationsJobTemplatesService) Create

Create: Creates a job template in the specified region.

  • parent: The parent location to create this job template. Format: `projects/{project}/locations/{location}`.

func (*ProjectsLocationsJobTemplatesService) Delete

Delete: Deletes a job template.

  • name: The name of the job template to delete. `projects/{project}/locations/{location}/jobTemplates/{job_template}`.

func (*ProjectsLocationsJobTemplatesService) Get

Get: Returns the job template data.

  • name: The name of the job template to retrieve. Format: `projects/{project}/locations/{location}/jobTemplates/{job_template}`.

func (*ProjectsLocationsJobTemplatesService) List

List: Lists job templates in the specified region.

  • parent: The parent location from which to retrieve the collection of job templates. Format: `projects/{project}/locations/{location}`.

type ProjectsLocationsJobsCreateCall

type ProjectsLocationsJobsCreateCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobsCreateCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobsCreateCall) Do

Do executes the "transcoder.projects.locations.jobs.create" call. Any non-2xx status code is an error. Response headers are in either *Job.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobsCreateCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobsCreateCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

type ProjectsLocationsJobsDeleteCall

type ProjectsLocationsJobsDeleteCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobsDeleteCall) AllowMissing

AllowMissing sets the optional parameter "allowMissing": If set to true, and the job is not found, the request will succeed but no action will be taken on the server.

func (*ProjectsLocationsJobsDeleteCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobsDeleteCall) Do

Do executes the "transcoder.projects.locations.jobs.delete" call. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobsDeleteCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobsDeleteCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

type ProjectsLocationsJobsGetCall

type ProjectsLocationsJobsGetCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobsGetCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobsGetCall) Do

Do executes the "transcoder.projects.locations.jobs.get" call. Any non-2xx status code is an error. Response headers are in either *Job.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobsGetCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobsGetCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

func (*ProjectsLocationsJobsGetCall) IfNoneMatch

IfNoneMatch sets an optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request.

type ProjectsLocationsJobsListCall

type ProjectsLocationsJobsListCall struct {
	// contains filtered or unexported fields
}

func (*ProjectsLocationsJobsListCall) Context

Context sets the context to be used in this call's Do method.

func (*ProjectsLocationsJobsListCall) Do

Do executes the "transcoder.projects.locations.jobs.list" call. Any non-2xx status code is an error. Response headers are in either *ListJobsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

func (*ProjectsLocationsJobsListCall) Fields

Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more details.

func (*ProjectsLocationsJobsListCall) Filter

Filter sets the optional parameter "filter": The filter expression, following the syntax outlined in https://google.aip.dev/160.

func (*ProjectsLocationsJobsListCall) Header

Header returns a http.Header that can be modified by the caller to add headers to the request.

func (*ProjectsLocationsJobsListCall) IfNoneMatch

IfNoneMatch sets an optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request.

func (*ProjectsLocationsJobsListCall) OrderBy

OrderBy sets the optional parameter "orderBy": One or more fields to compare and use to sort the output. See https://google.aip.dev/132#ordering.

func (*ProjectsLocationsJobsListCall) PageSize

PageSize sets the optional parameter "pageSize": The maximum number of items to return.

func (*ProjectsLocationsJobsListCall) PageToken

PageToken sets the optional parameter "pageToken": The `next_page_token` value returned from a previous List request, if any.

func (*ProjectsLocationsJobsListCall) Pages

Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

type ProjectsLocationsJobsService

type ProjectsLocationsJobsService struct {
	// contains filtered or unexported fields
}

func NewProjectsLocationsJobsService

func NewProjectsLocationsJobsService(s *Service) *ProjectsLocationsJobsService

func (*ProjectsLocationsJobsService) Create

Create: Creates a job in the specified region.

  • parent: The parent location to create and process this job. Format: `projects/{project}/locations/{location}`.

func (*ProjectsLocationsJobsService) Delete

Delete: Deletes a job.

  • name: The name of the job to delete. Format: `projects/{project}/locations/{location}/jobs/{job}`.

func (*ProjectsLocationsJobsService) Get

Get: Returns the job data.

  • name: The name of the job to retrieve. Format: `projects/{project}/locations/{location}/jobs/{job}`.

func (*ProjectsLocationsJobsService) List

List: Lists jobs in the specified region.

- parent: Format: `projects/{project}/locations/{location}`.

type ProjectsLocationsService

type ProjectsLocationsService struct {
	JobTemplates *ProjectsLocationsJobTemplatesService

	Jobs *ProjectsLocationsJobsService
	// contains filtered or unexported fields
}

func NewProjectsLocationsService

func NewProjectsLocationsService(s *Service) *ProjectsLocationsService

type ProjectsService

type ProjectsService struct {
	Locations *ProjectsLocationsService
	// contains filtered or unexported fields
}

func NewProjectsService

func NewProjectsService(s *Service) *ProjectsService

type PubsubDestination

type PubsubDestination struct {
	// Topic: The name of the Pub/Sub topic to publish job completion notification
	// to. For example: `projects/{project}/topics/{topic}`.
	Topic string `json:"topic,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Topic") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Topic") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

PubsubDestination: A Pub/Sub destination.

func (*PubsubDestination) MarshalJSON

func (s *PubsubDestination) MarshalJSON() ([]byte, error)

type SampleAesEncryption added in v0.130.0

type SampleAesEncryption struct {
}

SampleAesEncryption: Configuration for SAMPLE-AES encryption.

type SecretManagerSource added in v0.130.0

type SecretManagerSource struct {
	// SecretVersion: Required. The name of the Secret Version containing the
	// encryption key in the following format:
	// `projects/{project}/secrets/{secret_id}/versions/{version_number}` Note that
	// only numbered versions are supported. Aliases like "latest" are not
	// supported.
	SecretVersion string `json:"secretVersion,omitempty"`
	// ForceSendFields is a list of field names (e.g. "SecretVersion") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "SecretVersion") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

SecretManagerSource: Configuration for secrets stored in Google Secret Manager.

func (*SecretManagerSource) MarshalJSON added in v0.130.0

func (s *SecretManagerSource) MarshalJSON() ([]byte, error)

type SegmentSettings

type SegmentSettings struct {
	// IndividualSegments: Required. Create an individual segment file. The default
	// is `false`.
	IndividualSegments bool `json:"individualSegments,omitempty"`
	// SegmentDuration: Duration of the segments in seconds. The default is `6.0s`.
	// Note that `segmentDuration` must be greater than or equal to `gopDuration`
	// (#videostream), and `segmentDuration` must be divisible by `gopDuration`
	// (#videostream).
	SegmentDuration string `json:"segmentDuration,omitempty"`
	// ForceSendFields is a list of field names (e.g. "IndividualSegments") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "IndividualSegments") to include
	// in API requests with the JSON null value. By default, fields with empty
	// values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

SegmentSettings: Segment settings for `ts`, `fmp4` and `vtt`.

func (*SegmentSettings) MarshalJSON

func (s *SegmentSettings) MarshalJSON() ([]byte, error)

type Service

type Service struct {
	BasePath  string // API endpoint base URL
	UserAgent string // optional additional User-Agent fragment

	Projects *ProjectsService
	// contains filtered or unexported fields
}

func New deprecated

func New(client *http.Client) (*Service, error)

New creates a new Service. It uses the provided http.Client for requests.

Deprecated: please use NewService instead. To provide a custom HTTP client, use option.WithHTTPClient. If you are using google.golang.org/api/googleapis/transport.APIKey, use option.WithAPIKey with NewService instead.

func NewService

func NewService(ctx context.Context, opts ...option.ClientOption) (*Service, error)

NewService creates a new Service.

type SpriteSheet

type SpriteSheet struct {
	// ColumnCount: The maximum number of sprites per row in a sprite sheet. The
	// default is 0, which indicates no maximum limit.
	ColumnCount int64 `json:"columnCount,omitempty"`
	// EndTimeOffset: End time in seconds, relative to the output file timeline.
	// When `end_time_offset` is not specified, the sprites are generated until the
	// end of the output file.
	EndTimeOffset string `json:"endTimeOffset,omitempty"`
	// FilePrefix: Required. File name prefix for the generated sprite sheets. Each
	// sprite sheet has an incremental 10-digit zero-padded suffix starting from 0
	// before the extension, such as `sprite_sheet0000000123.jpeg`.
	FilePrefix string `json:"filePrefix,omitempty"`
	// Format: Format type. The default is `jpeg`. Supported formats: - `jpeg`
	Format string `json:"format,omitempty"`
	// Interval: Starting from `0s`, create sprites at regular intervals. Specify
	// the interval value in seconds.
	Interval string `json:"interval,omitempty"`
	// Quality: The quality of the generated sprite sheet. Enter a value between 1
	// and 100, where 1 is the lowest quality and 100 is the highest quality. The
	// default is 100. A high quality value corresponds to a low image data
	// compression ratio.
	Quality int64 `json:"quality,omitempty"`
	// RowCount: The maximum number of rows per sprite sheet. When the sprite sheet
	// is full, a new sprite sheet is created. The default is 0, which indicates no
	// maximum limit.
	RowCount int64 `json:"rowCount,omitempty"`
	// SpriteHeightPixels: Required. The height of sprite in pixels. Must be an
	// even integer. To preserve the source aspect ratio, set the
	// SpriteSheet.sprite_height_pixels field or the
	// SpriteSheet.sprite_width_pixels field, but not both (the API will
	// automatically calculate the missing field). For portrait videos that contain
	// horizontal ASR and rotation metadata, provide the height, in pixels, per the
	// horizontal ASR. The API calculates the width per the horizontal ASR. The API
	// detects any rotation metadata and swaps the requested height and width for
	// the output.
	SpriteHeightPixels int64 `json:"spriteHeightPixels,omitempty"`
	// SpriteWidthPixels: Required. The width of sprite in pixels. Must be an even
	// integer. To preserve the source aspect ratio, set the
	// SpriteSheet.sprite_width_pixels field or the
	// SpriteSheet.sprite_height_pixels field, but not both (the API will
	// automatically calculate the missing field). For portrait videos that contain
	// horizontal ASR and rotation metadata, provide the width, in pixels, per the
	// horizontal ASR. The API calculates the height per the horizontal ASR. The
	// API detects any rotation metadata and swaps the requested height and width
	// for the output.
	SpriteWidthPixels int64 `json:"spriteWidthPixels,omitempty"`
	// StartTimeOffset: Start time in seconds, relative to the output file
	// timeline. Determines the first sprite to pick. The default is `0s`.
	StartTimeOffset string `json:"startTimeOffset,omitempty"`
	// TotalCount: Total number of sprites. Create the specified number of sprites
	// distributed evenly across the timeline of the output media. The default is
	// 100.
	TotalCount int64 `json:"totalCount,omitempty"`
	// ForceSendFields is a list of field names (e.g. "ColumnCount") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "ColumnCount") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

SpriteSheet: Sprite sheet configuration.

func (*SpriteSheet) MarshalJSON

func (s *SpriteSheet) MarshalJSON() ([]byte, error)

type Status

type Status struct {
	// Code: The status code, which should be an enum value of google.rpc.Code.
	Code int64 `json:"code,omitempty"`
	// Details: A list of messages that carry the error details. There is a common
	// set of message types for APIs to use.
	Details []googleapi.RawMessage `json:"details,omitempty"`
	// Message: A developer-facing error message, which should be in English. Any
	// user-facing error message should be localized and sent in the
	// google.rpc.Status.details field, or localized by the client.
	Message string `json:"message,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Code") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Code") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Status: The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC (https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide (https://cloud.google.com/apis/design/errors).

func (*Status) MarshalJSON

func (s *Status) MarshalJSON() ([]byte, error)

type TextMapping

type TextMapping struct {
	// AtomKey: Required. The EditAtom.key that references atom with text inputs in
	// the JobConfig.edit_list.
	AtomKey string `json:"atomKey,omitempty"`
	// InputKey: Required. The Input.key that identifies the input file.
	InputKey string `json:"inputKey,omitempty"`
	// InputTrack: Required. The zero-based index of the track in the input file.
	InputTrack int64 `json:"inputTrack,omitempty"`
	// ForceSendFields is a list of field names (e.g. "AtomKey") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "AtomKey") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

TextMapping: The mapping for the JobConfig.edit_list atoms with text EditAtom.inputs.

func (*TextMapping) MarshalJSON

func (s *TextMapping) MarshalJSON() ([]byte, error)

type TextStream

type TextStream struct {
	// Codec: The codec for this text stream. The default is `webvtt`. Supported
	// text codecs: - `srt` - `ttml` - `cea608` - `cea708` - `webvtt`
	Codec string `json:"codec,omitempty"`
	// DisplayName: The name for this particular text stream that will be added to
	// the HLS/DASH manifest. Not supported in MP4 files.
	DisplayName string `json:"displayName,omitempty"`
	// LanguageCode: The BCP-47 language code, such as `en-US` or `sr-Latn`. For
	// more information, see
	// https://www.unicode.org/reports/tr35/#Unicode_locale_identifier. Not
	// supported in MP4 files.
	LanguageCode string `json:"languageCode,omitempty"`
	// Mapping: The mapping for the JobConfig.edit_list atoms with text
	// EditAtom.inputs.
	Mapping []*TextMapping `json:"mapping,omitempty"`
	// ForceSendFields is a list of field names (e.g. "Codec") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "Codec") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

TextStream: Encoding of a text stream. For example, closed captions or subtitles.

func (*TextStream) MarshalJSON

func (s *TextStream) MarshalJSON() ([]byte, error)

type VideoStream

type VideoStream struct {
	// H264: H264 codec settings.
	H264 *H264CodecSettings `json:"h264,omitempty"`
	// H265: H265 codec settings.
	H265 *H265CodecSettings `json:"h265,omitempty"`
	// Vp9: VP9 codec settings.
	Vp9 *Vp9CodecSettings `json:"vp9,omitempty"`
	// ForceSendFields is a list of field names (e.g. "H264") to unconditionally
	// include in API requests. By default, fields with empty or default values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "H264") to include in API requests
	// with the JSON null value. By default, fields with empty values are omitted
	// from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

VideoStream: Video stream resource.

func (*VideoStream) MarshalJSON

func (s *VideoStream) MarshalJSON() ([]byte, error)

type Vp9CodecSettings

type Vp9CodecSettings struct {
	// BitrateBps: Required. The video bitrate in bits per second. The minimum
	// value is 1,000. The maximum value is 480,000,000.
	BitrateBps int64 `json:"bitrateBps,omitempty"`
	// CrfLevel: Target CRF level. Must be between 10 and 36, where 10 is the
	// highest quality and 36 is the most efficient compression. The default is 21.
	// **Note:** This field is not supported.
	CrfLevel int64 `json:"crfLevel,omitempty"`
	// FrameRate: Required. The target video frame rate in frames per second (FPS).
	// Must be less than or equal to 120.
	FrameRate float64 `json:"frameRate,omitempty"`
	// FrameRateConversionStrategy: Optional. Frame rate conversion strategy for
	// desired frame rate. The default is `DOWNSAMPLE`.
	//
	// Possible values:
	//   "FRAME_RATE_CONVERSION_STRATEGY_UNSPECIFIED" - Unspecified frame rate
	// conversion strategy.
	//   "DOWNSAMPLE" - Selectively retain frames to reduce the output frame rate.
	// Every _n_ th frame is kept, where `n = ceil(input frame rate / target frame
	// rate)`. When _n_ = 1 (that is, the target frame rate is greater than the
	// input frame rate), the output frame rate matches the input frame rate. When
	// _n_ > 1, frames are dropped and the output frame rate is equal to `(input
	// frame rate / n)`. For more information, see [Calculate frame
	// rate](https://cloud.google.com/transcoder/docs/concepts/frame-rate).
	//   "DROP_DUPLICATE" - Drop or duplicate frames to match the specified frame
	// rate.
	FrameRateConversionStrategy string `json:"frameRateConversionStrategy,omitempty"`
	// GopDuration: Select the GOP size based on the specified duration. The
	// default is `3s`. Note that `gopDuration` must be less than or equal to
	// `segmentDuration` (#SegmentSettings), and `segmentDuration`
	// (#SegmentSettings) must be divisible by `gopDuration`.
	GopDuration string `json:"gopDuration,omitempty"`
	// GopFrameCount: Select the GOP size based on the specified frame count. Must
	// be greater than zero.
	GopFrameCount int64 `json:"gopFrameCount,omitempty"`
	// HeightPixels: The height of the video in pixels. Must be an even integer.
	// When not specified, the height is adjusted to match the specified width and
	// input aspect ratio. If both are omitted, the input height is used. For
	// portrait videos that contain horizontal ASR and rotation metadata, provide
	// the height, in pixels, per the horizontal ASR. The API calculates the width
	// per the horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	HeightPixels int64 `json:"heightPixels,omitempty"`
	// Hlg: Optional. HLG color format setting for VP9.
	Hlg *Vp9ColorFormatHLG `json:"hlg,omitempty"`
	// PixelFormat: Pixel format to use. The default is `yuv420p`. Supported pixel
	// formats: - `yuv420p` pixel format - `yuv422p` pixel format - `yuv444p` pixel
	// format - `yuv420p10` 10-bit HDR pixel format - `yuv422p10` 10-bit HDR pixel
	// format - `yuv444p10` 10-bit HDR pixel format - `yuv420p12` 12-bit HDR pixel
	// format - `yuv422p12` 12-bit HDR pixel format - `yuv444p12` 12-bit HDR pixel
	// format
	PixelFormat string `json:"pixelFormat,omitempty"`
	// Profile: Enforces the specified codec profile. The following profiles are
	// supported: * `profile0` (default) * `profile1` * `profile2` * `profile3` The
	// available options are WebM-compatible
	// (https://www.webmproject.org/vp9/profiles/). Note that certain values for
	// this field may cause the transcoder to override other fields you set in the
	// `Vp9CodecSettings` message.
	Profile string `json:"profile,omitempty"`
	// RateControlMode: Specify the mode. The default is `vbr`. Supported rate
	// control modes: - `vbr` - variable bitrate
	RateControlMode string `json:"rateControlMode,omitempty"`
	// Sdr: Optional. SDR color format setting for VP9.
	Sdr *Vp9ColorFormatSDR `json:"sdr,omitempty"`
	// WidthPixels: The width of the video in pixels. Must be an even integer. When
	// not specified, the width is adjusted to match the specified height and input
	// aspect ratio. If both are omitted, the input width is used. For portrait
	// videos that contain horizontal ASR and rotation metadata, provide the width,
	// in pixels, per the horizontal ASR. The API calculates the height per the
	// horizontal ASR. The API detects any rotation metadata and swaps the
	// requested height and width for the output.
	WidthPixels int64 `json:"widthPixels,omitempty"`
	// ForceSendFields is a list of field names (e.g. "BitrateBps") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "BitrateBps") to include in API
	// requests with the JSON null value. By default, fields with empty values are
	// omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

Vp9CodecSettings: VP9 codec settings.

func (*Vp9CodecSettings) MarshalJSON

func (s *Vp9CodecSettings) MarshalJSON() ([]byte, error)

func (*Vp9CodecSettings) UnmarshalJSON

func (s *Vp9CodecSettings) UnmarshalJSON(data []byte) error

type Vp9ColorFormatHLG added in v0.162.0

type Vp9ColorFormatHLG struct {
}

Vp9ColorFormatHLG: Convert the input video to a Hybrid Log Gamma (HLG) video.

type Vp9ColorFormatSDR added in v0.162.0

type Vp9ColorFormatSDR struct {
}

Vp9ColorFormatSDR: Convert the input video to a Standard Dynamic Range (SDR) video.

type Widevine added in v0.130.0

type Widevine struct {
}

Widevine: Widevine configuration.

type YadifConfig added in v0.94.0

type YadifConfig struct {
	// DeinterlaceAllFrames: Deinterlace all frames rather than just the frames
	// identified as interlaced. The default is `false`.
	DeinterlaceAllFrames bool `json:"deinterlaceAllFrames,omitempty"`
	// DisableSpatialInterlacing: Disable spacial interlacing. The default is
	// `false`.
	DisableSpatialInterlacing bool `json:"disableSpatialInterlacing,omitempty"`
	// Mode: Specifies the deinterlacing mode to adopt. The default is
	// `send_frame`. Supported values: - `send_frame`: Output one frame for each
	// frame - `send_field`: Output one frame for each field
	Mode string `json:"mode,omitempty"`
	// Parity: The picture field parity assumed for the input interlaced video. The
	// default is `auto`. Supported values: - `tff`: Assume the top field is first
	// - `bff`: Assume the bottom field is first - `auto`: Enable automatic
	// detection of field parity
	Parity string `json:"parity,omitempty"`
	// ForceSendFields is a list of field names (e.g. "DeinterlaceAllFrames") to
	// unconditionally include in API requests. By default, fields with empty or
	// default values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more
	// details.
	ForceSendFields []string `json:"-"`
	// NullFields is a list of field names (e.g. "DeinterlaceAllFrames") to include
	// in API requests with the JSON null value. By default, fields with empty
	// values are omitted from API requests. See
	// https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details.
	NullFields []string `json:"-"`
}

YadifConfig: Yet Another Deinterlacing Filter Configuration.

func (*YadifConfig) MarshalJSON added in v0.94.0

func (s *YadifConfig) MarshalJSON() ([]byte, error)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL