insert method

Future<GroupItem> insert(
  1. GroupItem request, {
  2. String? onBehalfOfContentOwner,
  3. String? $fields,
})

Creates a group item.

request - The metadata request object.

Request parameters:

onBehalfOfContentOwner - This parameter can only be used in a properly authorized request. Note: This parameter is intended exclusively for YouTube content partners that own and manage many different YouTube channels. The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube user who is acting on behalf of the content owner specified in the parameter value. 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 account that the user authenticates with must be linked to the specified YouTube content owner.

$fields - Selector specifying which fields to include in a partial response.

Completes with a GroupItem.

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<GroupItem> insert(
  GroupItem request, {
  core.String? onBehalfOfContentOwner,
  core.String? $fields,
}) async {
  final body_ = convert.json.encode(request);
  final queryParams_ = <core.String, core.List<core.String>>{
    if (onBehalfOfContentOwner != null)
      'onBehalfOfContentOwner': [onBehalfOfContentOwner],
    if ($fields != null) 'fields': [$fields],
  };

  const url_ = 'v2/groupItems';

  final response_ = await _requester.request(
    url_,
    'POST',
    body: body_,
    queryParams: queryParams_,
  );
  return GroupItem.fromJson(response_ as core.Map<core.String, core.dynamic>);
}