list method

Future<VideoListResponse> list(
  1. List<String> part, {
  2. String? chart,
  3. String? hl,
  4. List<String>? id,
  5. String? locale,
  6. int? maxHeight,
  7. int? maxResults,
  8. int? maxWidth,
  9. String? myRating,
  10. String? onBehalfOfContentOwner,
  11. String? pageToken,
  12. String? regionCode,
  13. String? videoCategoryId,
  14. String? $fields,
})

Retrieves a list of resources, possibly filtered.

Request parameters:

part - The part parameter specifies a comma-separated list of one or more video resource properties that the API response will include. If the parameter identifies a property that contains child properties, the child properties will be included in the response. For example, in a video resource, the snippet property contains the channelId, title, description, tags, and categoryId properties. As such, if you set part=snippet, the API response will contain all of those properties.

chart - Return the videos that are in the specified chart. Possible string values are:

  • "chartUnspecified"
  • "mostPopular" : Return the most popular videos for the specified content region and video category.

hl - Stands for "host language". Specifies the localization language of the metadata to be filled into snippet.localized. The field is filled with the default metadata if there is no localization in the specified language. The parameter value must be a language code included in the list returned by the i18nLanguages.list method (e.g. en_US, es_MX).

id - Return videos with the given ids.

locale - null

maxHeight - null Value must be between "72" and "8192".

maxResults - The maxResults parameter specifies the maximum number of items that should be returned in the result set. Note: This parameter is supported for use in conjunction with the myRating and chart parameters, but it is not supported for use in conjunction with the id parameter. Value must be between "1" and "50".

maxWidth - Return the player with maximum height specified in Value must be between "72" and "8192".

myRating - Return videos liked/disliked by the authenticated user. Does not support RateType.RATED_TYPE_NONE. Possible string values are:

  • "none"
  • "like" : The entity is liked.
  • "dislike" : The entity is disliked.

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.

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. Note: This parameter is supported for use in conjunction with the myRating and chart parameters, but it is not supported for use in conjunction with the id parameter.

regionCode - Use a chart that is specific to the specified region

videoCategoryId - Use chart that is specific to the specified video category

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

Completes with a VideoListResponse.

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<VideoListResponse> list(
  core.List<core.String> part, {
  core.String? chart,
  core.String? hl,
  core.List<core.String>? id,
  core.String? locale,
  core.int? maxHeight,
  core.int? maxResults,
  core.int? maxWidth,
  core.String? myRating,
  core.String? onBehalfOfContentOwner,
  core.String? pageToken,
  core.String? regionCode,
  core.String? videoCategoryId,
  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 (chart != null) 'chart': [chart],
    if (hl != null) 'hl': [hl],
    if (id != null) 'id': id,
    if (locale != null) 'locale': [locale],
    if (maxHeight != null) 'maxHeight': ['${maxHeight}'],
    if (maxResults != null) 'maxResults': ['${maxResults}'],
    if (maxWidth != null) 'maxWidth': ['${maxWidth}'],
    if (myRating != null) 'myRating': [myRating],
    if (onBehalfOfContentOwner != null)
      'onBehalfOfContentOwner': [onBehalfOfContentOwner],
    if (pageToken != null) 'pageToken': [pageToken],
    if (regionCode != null) 'regionCode': [regionCode],
    if (videoCategoryId != null) 'videoCategoryId': [videoCategoryId],
    if ($fields != null) 'fields': [$fields],
  };

  const url_ = 'youtube/v3/videos';

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