insert method
Inserts a new resource into this collection.
request
- The metadata request object.
Request parameters:
part
- The part parameter serves two purposes in this operation. It
identifies the properties that the write operation will set as well as the
properties that the API response will include. Note that not all parts
contain properties that can be set when inserting or updating a video. For
example, the statistics object encapsulates statistics that YouTube
calculates for a video and does not contain values that you can set or
modify. If the parameter value specifies a part that does not contain
mutable values, that part will still be included in the API response.
autoLevels
- Should auto-levels be applied to the upload.
notifySubscribers
- Notify the channel subscribers about the new video.
As default, the notification is enabled.
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 CMS account that the user authenticates with must
be linked to the specified YouTube content owner.
onBehalfOfContentOwnerChannel
- This parameter can only be used in a
properly authorized request. Note: This parameter is intended
exclusively for YouTube content partners. The
onBehalfOfContentOwnerChannel parameter specifies the YouTube channel ID
of the channel to which a video is being added. This parameter is required
when a request specifies a value for the onBehalfOfContentOwner parameter,
and it can only be used in conjunction with that parameter. In addition,
the request must be authorized using a CMS account that is linked to the
content owner that the onBehalfOfContentOwner parameter specifies.
Finally, the channel that the onBehalfOfContentOwnerChannel parameter
value specifies must be linked to the content owner that the
onBehalfOfContentOwner parameter specifies. This parameter is intended for
YouTube content partners that own and manage many different YouTube
channels. It allows content owners to authenticate once and perform
actions on behalf of the channel specified in the parameter value, without
having to provide authentication credentials for each separate channel.
stabilize
- Should stabilize be applied to the upload.
$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 Video.
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<Video> insert(
Video request,
core.List<core.String> part, {
core.bool? autoLevels,
core.bool? notifySubscribers,
core.String? onBehalfOfContentOwner,
core.String? onBehalfOfContentOwnerChannel,
core.bool? stabilize,
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 (autoLevels != null) 'autoLevels': ['${autoLevels}'],
if (notifySubscribers != null)
'notifySubscribers': ['${notifySubscribers}'],
if (onBehalfOfContentOwner != null)
'onBehalfOfContentOwner': [onBehalfOfContentOwner],
if (onBehalfOfContentOwnerChannel != null)
'onBehalfOfContentOwnerChannel': [onBehalfOfContentOwnerChannel],
if (stabilize != null) 'stabilize': ['${stabilize}'],
if ($fields != null) 'fields': [$fields],
};
core.String url_;
if (uploadMedia == null) {
url_ = 'youtube/v3/videos';
} else if (uploadOptions is commons.ResumableUploadOptions) {
url_ = '/resumable/upload/youtube/v3/videos';
} else {
url_ = '/upload/youtube/v3/videos';
}
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
uploadMedia: uploadMedia,
uploadOptions: uploadOptions,
);
return Video.fromJson(response_ as core.Map<core.String, core.dynamic>);
}