insert method
Inserts a new resource into this collection.
request
- The metadata request object.
Request parameters:
part
- The part parameter specifies the caption resource parts that
the API response will include. Set the parameter value to snippet.
onBehalfOf
- ID of the Google+ Page for the channel that the request is
be on behalf of
onBehalfOfContentOwner
- Note: This parameter is intended exclusively
for YouTube content partners. The onBehalfOfContentOwner parameter
indicates that the request's authorization credentials identify a YouTube
CMS user who is acting on behalf of the content owner specified in the
parameter value. This parameter is intended for YouTube content partners
that own and manage many different YouTube channels. It allows content
owners to authenticate once and get access to all their video and channel
data, without having to provide authentication credentials for each
individual channel. The actual CMS account that the user authenticates
with must be linked to the specified YouTube content owner.
sync
- Extra parameter to allow automatically syncing the uploaded
caption/transcript with the audio.
$fields
- Selector specifying which fields to include in a partial
response.
uploadMedia
- The media to upload.
uploadOptions
- Options for the media upload. Streaming Media without
the length being known ahead of time is only supported via resumable
uploads.
Completes with a Caption.
Completes with a commons.ApiRequestError if the API endpoint returned an error.
If the used http.Client
completes with an error when making a REST call,
this method will complete with the same error.
Implementation
async.Future<Caption> insert(
Caption request,
core.List<core.String> part, {
core.String? onBehalfOf,
core.String? onBehalfOfContentOwner,
core.bool? sync,
core.String? $fields,
commons.UploadOptions uploadOptions = commons.UploadOptions.defaultOptions,
commons.Media? uploadMedia,
}) async {
final body_ = convert.json.encode(request);
if (part.isEmpty) {
throw core.ArgumentError('Parameter part cannot be empty.');
}
final queryParams_ = <core.String, core.List<core.String>>{
'part': part,
if (onBehalfOf != null) 'onBehalfOf': [onBehalfOf],
if (onBehalfOfContentOwner != null)
'onBehalfOfContentOwner': [onBehalfOfContentOwner],
if (sync != null) 'sync': ['${sync}'],
if ($fields != null) 'fields': [$fields],
};
core.String url_;
if (uploadMedia == null) {
url_ = 'youtube/v3/captions';
} else if (uploadOptions is commons.ResumableUploadOptions) {
url_ = '/resumable/upload/youtube/v3/captions';
} else {
url_ = '/upload/youtube/v3/captions';
}
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
uploadMedia: uploadMedia,
uploadOptions: uploadOptions,
);
return Caption.fromJson(response_ as core.Map<core.String, core.dynamic>);
}