list method

Future<LiveBroadcastListResponse> list(
  1. List<String> part, {
  2. String? broadcastStatus,
  3. String? broadcastType,
  4. List<String>? id,
  5. int? maxResults,
  6. bool? mine,
  7. String? onBehalfOfContentOwner,
  8. String? onBehalfOfContentOwnerChannel,
  9. String? pageToken,
  10. String? $fields,
})

Retrieve the list of broadcasts associated with the given channel.

Request parameters:

part - The part parameter specifies a comma-separated list of one or more liveBroadcast resource properties that the API response will include. The part names that you can include in the parameter value are id, snippet, contentDetails, status and statistics.

broadcastStatus - Return broadcasts with a certain status, e.g. active broadcasts. Possible string values are:

  • "broadcastStatusFilterUnspecified"
  • "all" : Return all broadcasts.
  • "active" : Return current live broadcasts.
  • "upcoming" : Return broadcasts that have not yet started.
  • "completed" : Return broadcasts that have already ended.

broadcastType - Return only broadcasts with the selected type. Possible string values are:

  • "broadcastTypeFilterUnspecified"
  • "all" : Return all broadcasts.
  • "event" : Return only scheduled event broadcasts.
  • "persistent" : Return only persistent broadcasts.

id - Return broadcasts with the given ids from Stubby or Apiary.

maxResults - The maxResults parameter specifies the maximum number of items that should be returned in the result set. Value must be between "0" and "50".

mine - null

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.

pageToken - The pageToken parameter identifies a specific page in the result set that should be returned. In an API response, the nextPageToken and prevPageToken properties identify other pages that could be retrieved.

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

Completes with a LiveBroadcastListResponse.

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<LiveBroadcastListResponse> list(
  core.List<core.String> part, {
  core.String? broadcastStatus,
  core.String? broadcastType,
  core.List<core.String>? id,
  core.int? maxResults,
  core.bool? mine,
  core.String? onBehalfOfContentOwner,
  core.String? onBehalfOfContentOwnerChannel,
  core.String? pageToken,
  core.String? $fields,
}) async {
  if (part.isEmpty) {
    throw core.ArgumentError('Parameter part cannot be empty.');
  }
  final queryParams_ = <core.String, core.List<core.String>>{
    'part': part,
    if (broadcastStatus != null) 'broadcastStatus': [broadcastStatus],
    if (broadcastType != null) 'broadcastType': [broadcastType],
    if (id != null) 'id': id,
    if (maxResults != null) 'maxResults': ['${maxResults}'],
    if (mine != null) 'mine': ['${mine}'],
    if (onBehalfOfContentOwner != null)
      'onBehalfOfContentOwner': [onBehalfOfContentOwner],
    if (onBehalfOfContentOwnerChannel != null)
      'onBehalfOfContentOwnerChannel': [onBehalfOfContentOwnerChannel],
    if (pageToken != null) 'pageToken': [pageToken],
    if ($fields != null) 'fields': [$fields],
  };

  const url_ = 'youtube/v3/liveBroadcasts';

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