<?xml version="1.0" encoding="UTF-8"?>
<feed xmlns="http://www.w3.org/2005/Atom">
  <id>tag:google.com,changelog:youtube-data-api-v3-revision-history</id>
  <title>YouTube Data API v3 - Revision History</title>
  <updated>2025-12-04T16:00:00:-0800</updated>
  <link rel="self" href="https://developers.google.com/youtube/v3/feeds/data-api-revision-history.xml"/>
  <author>
    <name>YouTube</name>
  </author>
  <entry>
    <title>December 4, 2025</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2025-12-04</id>
    <updated>2025-12-04T16:00:00:-0800</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The YouTube Data API documentation and <a href="https://developers.google.com/youtube/v3/determine_quota_cost">Quota Calculator</a> have been updated to reflect a change in the quota cost of a video upload from approximately 1600 units to approximately 100 units.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 10, 2025</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2025-07-10</id>
    <updated>2025-07-10T16:00:00:-0800</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>As of July 21, 2025, YouTube will adjust the content that is returned by the <a href="https://developers.google.com/youtube/v3/guides/implementation/videos" target="_blank"><code>video.list</code></a> method's <code>mostPopular</code> chart. In the past, the <code>mostPopular</code> chart reflected the videos featured on the Trending Now list. Now, the <code>mostPopular</code> chart will feature videos from the Trending Music, Movies, and Gaming charts. This API change is in tandem with the deprecation of YouTube's <a href="https://support.google.com/youtube/thread/3567021689" target="_blank">Trending page</a>.</p></p>
]]>
    </content>
  </entry>
  <entry>
    <title>March 26, 2025</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2025-03-26</id>
    <updated>2025-03-26T16:00:00:-0800</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>Starting March 31, 2025, YouTube will change how views for Shorts are counted. In the past, for Shorts, a view was counted after a Short was played for a certain number of seconds. Now, views will count the number of times your Short starts to play or replay, with no minimum watch time requirement.
<a href="https://yt.be/help/sviews">Learn more</a></p>

<p>Starting March 31, 2025, the following fields in the Data API will return the view count for Shorts as per this change:</p>

<ul>
  <li><code>channels.statistics.viewCount</code></li>
  <li><code>videos.statistics.viewCount</code></li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 30, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-10-30</id>
    <updated>2024-10-30T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The API now supports the ability to identify videos that contain realistic <b>Altered or
    Synthetic</b> (<b>A/S</b>) content. Learn more about
    <a href="https://blog.youtube/inside-youtube/our-approach-to-responsible-ai-innovation/">YouTube
       policies related to A/S content</a>.</p>

<p>Examples of A/S content include videos that:</p>
<ul>
  <li>Make a real person appear to say or do something they didn't actually say or do</li>
  <li>Alter footage of a real event or place</li>
  <li>Generate a realistic-looking scene that did not actually occur</li>
</ul>

<p>To indicate whether a video contains A/S content, set the
  <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.containsSyntheticMedia">status.containsSyntheticMedia</a></code>
  property. This property can be set when calling the
  <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> or
  <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods. If set, the
  property is returned in the
  <code><a href="https://developers.google.com/youtube/v3/docs/videos#status">video</a></code> resource.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>April 30, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-04-30</id>
    <updated>2024-04-30T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>This update contains the following changes:</p>

<p>The API no longer supports the ability to insert or retrieve channel discussions. This change is
consistent with the functionality supported on the YouTube website, which does not support posting
comments to channels.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>March 13, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-03-13</id>
    <updated>2024-03-13T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>This update contains the following changes:</p>

<p>The <code>sync</code> parameter for the
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/insert#sync">captions.insert</a></code> and
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/update#sync">captions.update</a></code> methods
  has been deprecated. YouTube will stop supporting the
  parameter as of April 12, 2024.</p>

<p>As a result of this change, developers must include timing information when inserting or
  updating caption tracks or the upload will fail.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>March 12, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-03-12</id>
    <updated>2024-03-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<p>Documentation for the <code>captions</code> resource has been updated to note that the maximum
  allowed length for the <code><a href="https://developers.google.com/youtube/v3/docs/captions#snippet.name">snippet.name</a></code>
  field is 150 characters. The API returns a <code><a href="https://developers.google.com/youtube/v3/docs/captions/insert#youtube.captions.insert-invalidValue-nameTooLong">nameTooLong</a></code>
  error if the track name is longer than that.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>March 7, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-03-07</id>
    <updated>2024-03-07T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource property
  <code>brandingSettings.channel.moderateComments</code> has been deprecated. YouTube will stop
  supporting the parameter as of March 7, 2024.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>January 31, 2024</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2024-01-31</id>
    <updated>2024-01-31T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<p>The <code>channels.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#forHandle">forHandle</a></code>
  parameter enables you to retrieve information about a channel by specifying its YouTube handle.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>November 9, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-11-09</id>
    <updated>2023-11-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>All references to the <code>videoId</code> resource under <code><a href="https://developers.google.com/youtube/v3/docs/comments#resource-representation">Comments</a></code>
have been removed as the <code>videoId</code> resource is not being returned using an API call.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>September 12, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-09-12</id>
    <updated>2023-09-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>The <code><a href="https://developers.google.com/youtube/v3/docs/comments/markAsSpam">comments.markAsSpam</a></code> method
  has been deprecated for several years. This method is already unsupported on YouTube and is no
  longer supported through the API.</p>

<p>A deprecation notice has been added to all of the documents referencing the
  <code>comments.markAsSpam</code> method.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>August 22, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-08-22</id>
    <updated>2023-08-22T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method now supports the
  <code><a href="https://developers.google.com/youtube/v3/docs/search/list#videoPaidProductPlacement">videoPaidProductPlacement</a></code>
  parameter. This parameter enables you to filter search results to include only videos that the
  creator has denoted as having a paid promotion.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>August 18, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-08-18</id>
    <updated>2023-08-18T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The definition of the <code>video</code> resource's
  <code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.concurrentViewers">liveStreamingDetails.concurrentViewers</a></code>
  has been updated to note that the concurrent viewer counts that the YouTube Data API returns might
  differ from the processed, despammed concurrent viewer counts available through YouTube
  Analytics. The
  <a href="https://support.google.com/youtube/answer/2853833">YouTube Help Center</a>
  provides more information about live streaming metrics.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>August 7, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-08-07</id>
    <updated>2023-08-07T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>As <a href="https://developers.google.com/youtube/v3/revision_history#release_notes_06_12_2023">announced on June 12, 2023</a>, the
  <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method's
  <code>relatedToVideoId</code> parameter has been deprecated. That parameter is no longer
  supported, and references to the parameter have been removed from the API documentation.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>June 28, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-06-28</id>
    <updated>2023-06-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#errors">thumbnails.set</a> method now supports the
  <code>uploadRateLimitExceeded</code> error, which indicates that the channel has uploaded too many
  thumbnails during the past 24 hours and should try again later.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>June 12, 2023</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2023-06-12</id>
    <updated>2023-06-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>The <a href="https://developers.google.com/youtube/v3/docs/search/list#params">search.list</a> method's
  <code>relatedToVideoId</code> parameter has been deprecated. YouTube will stop supporting the
  parameter as of August 7, 2023.</p>

<p>At this time, a deprecation notice has been added to the <code>search.list</code> method's
  documentation. This parameter will be fully removed from the <code>search.list</code> documentation
  on or after August 7, 2023.</p>

<p>In addition, an example demonstrating how to retrieve related videos has been
  removed from the <a href="https://developers.google.com/youtube/v3/guides/implementation/videos">API implementation guide</a>.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>August 22, 2022</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2022-08-22</id>
    <updated>2022-08-22T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p> Corrected type annotations for <a href="https://developers.google.com/youtube/v3/docs/videos#statistics">video.statistics</a>
  fields to string from unsigned long.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>August 5, 2022</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2022-08-05</id>
    <updated>2022-08-05T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>YouTube has changed the way that caption IDs are generated and, as part of that change, is
  assigning new caption IDs to all caption tracks. This change might be a backward-incompatible
  change for applications that store
  <code><a href="https://developers.google.com/youtube/v3/docs/captions#id">caption_id</a></code> values, though it will not
  affect applications that do not store
  <code><a href="https://developers.google.com/youtube/v3/docs/captions#id">caption_id</a></code> values.</p>

<p>Between now and December 1, 2022, the
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/list">captions.list</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/update">captions.update</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/download">captions.download</a></code>, and
  and <code><a href="https://developers.google.com/youtube/v3/docs/captions/delete">captions.delete</a></code> methods will
  support both the old and new caption track IDs. However, on or after December 1, 2022, YouTube
  will stop supporting the old caption track IDs. At that time, calling any of those API methods
  with an old caption track ID will result in a
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/list#errors">captionNotFound</a></code> error.</p>

<p>To prepare for this change, you should plan to fully replace all stored caption track data
  between now and December 1, 2022. This means that for any video for which you store caption track
  data, you should delete the currently stored data, then call the
  <code><a href="https://developers.google.com/youtube/v3/docs/captions/list">captions.list</a></code> method to retrieve the
  current set of caption tracks for the video and store the data in the API response as you would
  normally.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 12, 2022</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2022-07-12</id>
    <updated>2022-07-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
  <p>Section 4 of the <a href="https://developers.google.com/youtube/terms/api-services-terms-of-service">YouTube API Terms of Service</a> has been updated to clarify when and why registration data may be retained.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>April 27, 2022</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2022-04-27</id>
    <updated>2022-04-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method description has been updated to note that the maximum file size for uploaded videos has increased from 128GB to 256GB.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>April 8, 2022</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2022-04-08</id>
    <updated>2022-04-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <code>subscriptions.list</code> method's
  <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#myRecentSubscribers">myRecentSubscribers</a></code>
  and <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#mySubscribers">mySubscribers</a></code> parameter definitions
  have both been updated to note that the maximum number of subscribers returned by the API might be limited.
  This change represents a documentation correction and not a change in API behavior.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>December 15, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-12-15</id>
    <updated>2021-12-15T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>As announced on <a href="https://developers.google.com/youtube/v3/revision_history#release_notes_11_18_2021">November 18, 2021</a>, in conjunction with
  <a href="https://blog.youtube/news-and-events/update-to-youtube/">changes to make video dislike
  counts private across the entire YouTube platform</a>, the <code>video</code> resource's
  <code><a href="https://developers.google.com/youtube/v3/docs/videos#statistics.dislikeCount">statistics.dislikeCount</a></code>
  property is now private.</p>

<p>You can learn more about this change on <a href="https://blog.youtube/news-and-events/update-to-youtube/">YouTube's official blog</a>.
]]>
    </content>
  </entry>
  <entry>
    <title>November 18, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-11-18</id>
    <updated>2021-11-18T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>In conjunction with <a href="https://blog.youtube/news-and-events/update-to-youtube/">changes to
  make video dislike counts private across the entire YouTube platform</a>, the <code>video</code> resource's
  <code><a href="https://developers.google.com/youtube/v3/docs/videos#statistics.dislikeCount">statistics.dislikeCount</a></code>
  property will be made private as of December 13, 2021. This means that the property will only
  be included in an API response from the <code>videos.list</code> endpoint if the API request was
  authenticated by the video owner.</p>

<p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> endpoint is not affected
  by this change.</p>

<p>Developers who do not display dislike counts publicly and still need the dislike count for their
  API client can apply to be put on an allow list for an exemption. To apply for an exemption, you
  must complete this
  <a href="https://notifications.google.com/g/p/AD-FnEwIDS4bp_9WIGI6OCm7hPkOGOc3EDhVzSdo6a5ljmBmeIxVk1jJrP7Hn6cl_hmtGNwuNJqwNJ-zvpTM59UJovol1xJUpPy6xtfNKXczNtlYxda1JQPLK0uUUrwbxDi06PtUZTcIitRJKPWSUKXeYzdNFLeyP49q6N8yzgRdDZDAmEEQ8cenCu1GsjMo5Dv7NqSv2_IJ-9VF">application form</a>.</p>

<p>You can learn more about this change on <a href="https://blog.youtube/news-and-events/update-to-youtube/">YouTube's official blog</a>.
]]>
    </content>
  </entry>
  <entry>
    <title>July 2, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-07-02</id>
    <updated>2021-07-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <code>commentThreads.update</code> endpoint has been deprecated and is no longer supported.
  This endpoint duplicated functionality available through other API endpoints. Instead, you can
  call the <code><a href="https://developers.google.com/youtube/v3/docs/comments/update">comments.update</a></code></p> method
  and, if your code requires a <code>commentThreads</code> resource, make a secondary call to the
  <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list">commentThreads.list</a></code> method.</p>

]]>
    </content>
  </entry>
  <entry>
    <title>July 1, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-07-01</id>
    <updated>2021-07-01T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[

  <p>All developers using YouTube’s API Services must complete an API Compliance Audit in order to be granted more than the default quota allocation of 10,000 units. To date, both the compliance audit process and requests for additional quota unit allocations have been conducted by developers filling out and submitting the <a href="https://support.google.com/youtube/contact/yt_api_form">YouTube API Services - Audit and Quota Extension Form</a>.</p>

  <p>To clarify these processes and better meet the needs of developers using our API Services, we are adding 3 new forms and a <a href="https://developers.google.com/youtube/v3/guides/quota_and_compliance_audits">guide</a>.</p>

  <ul>
    <li><a href="https://support.google.com/youtube/contact/yt_api_audited_developer_requests_form">Audited Developer Requests Form</a>: Developers who have already passed an API Compliance Audit can fill out and submit this shorter form to request an allocated quota extension.</li>
    <li><a href="https://support.google.com/youtube/contact/yt_api_appeals">Appeals Form</a>: Developers whose API projects have failed a compliance audit (or been denied a quota unit increase) can fill out and submit this form.</li>
    <li><a href="https://support.google.com/youtube/contact/yt_api_change_of_control_form">Change of Control Form</a>: Developers, or any party operating an API client on a developer’s behalf, who experience a change of control (for example, through a stock purchase or sale, merger or other form of corporate transaction) associated with an API project must fill out and submit this form. This enables YouTube’s API team to update our records, audit the new API project’s use case compliance, and validate the developer’s current quota allocation.</li>
  </ul>

<p>Each new form will inform us of your intended usage of YouTube’s API and enable us to better assist you.</p>

<p>More details are available in our new API Compliance Audits <a href="https://developers.google.com/youtube/v3/guides/quota_and_compliance_audits">guide</a>.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>May 12, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-05-12</id>
    <updated>2021-05-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>This update covers the following API changes:</p>

<ul>
  <li>
    <p>The <code>channel</code> resource's
      <code><a href="https://developers.google.com/youtube/v3/docs/channels#contentDetails.relatedPlaylists.favorites">contentDetails.relatedPlaylists.favorites</a></code>
      property has been deprecated. Favorite videos functionality has already been deprecated for
      several years as noted in the <a href="#release_notes_04_28_2016">April 28, 2016</a>, revision
      history entry.</p>
    <p>Prior to this update, the API would still create a new playlist if an API client attempted to
      add a video to a nonexistent favorites playlist. Going forward, the playlist will not be
      created in this case and the API will return an error. Attempts to modify favorites playlists
      by adding, modifying, or deleting items are also all deprecated per prior announcements and
      might start returning errors at any time.</p>
  </li>
  <li>
    <p>The following <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource
    properties have been deprecated. These properties are already unsupported in the YouTube Studio UI
      and on YouTube. As a result, they are also no longer supported via the API.</p>
    <ul>
      <li><code>brandingSettings.channel.defaultTab</code></li>
      <li><code>brandingSettings.channel.featuredChannelsTitle</code></li>
      <li><code>brandingSettings.channel.featuredChannelsUrls[]</code></li>
      <li><code>brandingSettings.channel.profileColor</code></li>
      <li><code>brandingSettings.channel.showBrowseView</code></li>
      <li><code>brandingSettings.channel.showRelatedChannels</code></li>
    </ul>
    <p>All of the properties have been removed from the
      <a href="https://developers.google.com/youtube/v3/docs/channels#resource-representation"><code>channel</code>
        resource representation</a>, and their definitions have been removed from the resource's
      <a href="https://developers.google.com/youtube/v3/docs/channels#properties">property list</a>. In addition, errors
      associated with these properties have been removed from the method-specific documentation.</p>
  </li>
  <li>
    <p>The following <code><a href="https://developers.google.com/youtube/v3/docs/channelSections">channelSection</a></code> resource
    properties have been deprecated. These properties are already unsupported in the YouTube Studio UI
      and on YouTube. As a result, they are also no longer supported via the API.</p>

  <ul>
    <li><code>snippet.style</code></li>
    <li><code>snippet.defaultLanguage</code></li>
    <li><code>snippet.localized.title</code></li>
    <li><code>localizations</code></li>
    <li><code>localizations.(key)</code></li>
    <li><code>localizations.(key).title</code></li>
    <li><code>targeting</code></li>
    <li><code>targeting.languages[]</code></li>
    <li><code>targeting.regions[]</code></li>
    <li><code>targeting.countries[]</code></li>
  </ul>

    <p>In conjunction with this change, the <code>channelSection.list</code> method's
      <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/list#hl">hl</a></code> parameter has also
      been deprecated since the features it supports are not supported.</p>

    <p>All of the properties have been removed from the
      <a href="https://developers.google.com/youtube/v3/docs/channelSections#resource-representation"><code>channelSection</code>
        resource representation</a>, and their definitions have been removed from the resource's
      <a href="https://developers.google.com/youtube/v3/docs/channelSections#properties">property list</a>. In addition, errors
      associated with these properties have been removed from the method-specific documentation.</p>
  </li>
  <li>
    <p>For the <code>channelSection</code> resource's
      <code><a href="https://developers.google.com/youtube/v3/docs/channelSections#snippet.type">snippet.type</a></code> property,
      the following values have been deprecated. These values are already unsupported on YouTube
      channel pages and, as a result, they are also no longer supported via the API.</p>
    <ul>
      <li><code>likedPlaylists</code></li>
      <li><code>likes</code></li>
      <li><code>postedPlaylists</code></li>
      <li><code>postedVideos</code></li>
      <li><code>recentActivity</code></li>
      <li><code>recentPosts</code></li>
    </ul>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlists">playlist</a></code> resource's
      <code>snippet.tags[]</code> property has been deprecated. This property is already unsupported
      on YouTube and, as a result, it is no longer supported via the API.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>February 9, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-02-09</id>
    <updated>2021-02-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems">playlistItem</a></code> resource supports two new properties:</p>

<ul>
  <li>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#snippet.videoOwnerChannelId">snippet.videoOwnerChannelId</a></code>
    property identifies the ID of the channel that uploaded the playlist video.</li>
  <li>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#snippet.videoOwnerChannelTitle">snippet.videoOwnerChannelTitle</a></code>
    property identifies the name of the channel that uploaded the playlist video.</li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>January 28, 2021</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2021-01-28</id>
    <updated>2021-01-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
<p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/delete">playlistItems.delete</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list">playlistItems.list</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update">playlistItems.update</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/playlists/delete">playlists.delete</a></code>,
  <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code>, and
  <code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code> methods all support
  a new <code>playlistOperationUnsupported</code> error. The error occurs when a request attempts to
  perform an operation that is not allowed for a particular playlist. For example, a user cannot
  delete a video from their uploaded videos playlist or delete the playlist itself.</p>

<p>In all cases, this error returns a <code>400</code> HTTP response code (Bad Request).</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list">playlistItems.list</a></code> method's
      <code>watchHistoryNotAccessible</code> and <code>watchLaterNotAccessible</code> errors have
      been removed from the documentation. While users' watch history and watch later lists are, indeed,
      not accessible via the API, these particular errors are not returned by the API.</p>
  </li>
    </ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 15, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-10-15</id>
    <updated>2020-10-15T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
    <p>Two new sections have been added to the <a href="https://developers.google.com/youtube/terms/developer-policies">Developer
    Policies</a>:</p>

  <ul>
    <li>The new <a href="https://developers.google.com/youtube/terms/developer-policies#III-E-4-i">Section III.E.4.i</a> provides
      additional information about the data collected and sent via the YouTube embedded player. You
      are responsible for any user data you send to us via any YouTube embedded player before the
      user has interacted with the player to indicate playback intent. You can limit the data shared
      with YouTube before a user interacts with the player by setting Autoplay to false.</li>
    <li>The new <a href="https://developers.google.com/youtube/terms/developer-policies#III-E-4-j">Section III.E.4.j</a> relates
      to checking the Made for Kids (MFK) status of content before embedding it on your sites and
      apps. You are responsible for knowing when videos that you embed on your API Client are made
      for kids and treating data collected from the embedded player accordingly. As such, you must
      check the status of content using YouTube Data API Service before embedding it on your API
      Client via any YouTube embedded players.</li>
  </ul>

<p>The new <a href="https://developers.google.com/youtube/v3/guides/made_for_kids_status">Finding the MadeForKids status of a video</a>
  guide explains how to look up the MFK status of a video using the
  <a href="https://developers.google.com/youtube/v3/getting-started">YouTube Data API Service</a>.</p>

<p>In conjunction with these changes, a reminder has been added to the
  <a href="https://developers.google.com/youtube/player_parameters">Embedded Player Parameter documentation</a> to explain that
  if you enable Autoplay, playback will occur without any user interaction with the player; playback
  data collection and sharing will therefore occur upon page load.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>October 8, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-10-08</id>
    <updated>2020-10-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
    <p>This update covers three small changes related to the
      <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource:</p>
    <ul>
      <li>The <code><a href="https://developers.google.com/youtube/v3/docs/channels#snippet.thumbnails">snippet.thumbnails</a></code>
        object, which identifies a channel's thumbnail images, might be empty for newly created
        channels and might take up to one day to populate.</li>
      <li>The <code><a href="https://developers.google.com/youtube/v3/docs/channels#statistics.videoCount">statistics.videoCount</a></code>
        property reflects the count of the channel's public videos only, even to owners. This change
        is consistent with counts shown on the YouTube website.</li>
      <li>Channel keywords, which are identified in the
        <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.channel.keywords">brandingSettings.channel.keywords</a></code>
        property, might be truncated if they exceed the maximum allowed length of 500 characters or
        if they contained unescaped quotation marks (<code>"</code>). Note that the 500 character
        limit is not a per-keyword limit but rather a limit on the total length of all keywords.
        This behavior is consistent with that on the YouTube website.</li>
    </ul>
]]>
    </content>
  </entry>
  <entry>
    <title>September 9, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-09-09</id>
    <updated>2020-09-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
    <p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

    <p>This update covers the following API changes. All changes will go into effect on or after
      9 September 2020, the date of this announcement. With that in mind, developers should no longer
      rely on any of the API features listed below.</p>

    <ul>
      <li>
        The following API resources, methods, parameters, and resource properties are deprecated
        immediately and will stop working on or after the date of this announcement:

        <ul>
          <li>The following <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource
            properties:
            <ul>
              <li>The <code>statistics.commentCount</code> property</li>
              <li>The <code>brandingSettings.image</code> object and all of its child properties</li>
              <li>The <code>brandingSettings.hints</code>list and all of its child properties</li>
            </ul>
          </li>
          <li>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method's
            <code>categoryId</code> filter parameter</li>
          <li>The <code><a href="https://developers.google.com/youtube/v3/docs/guideCategories">guideCategories</a></code> resource
            and the <code><a href="https://developers.google.com/youtube/v3/docs/guideCategories/list">guideCategories.list</a></code>
            method</li>
        </ul>
      </li>

      <li>
        API responses for the
        <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method no
        longer contain the
        <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#prevPageToken">prevPageToken</a></code>
        property if the API request sets the
        <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#managedByMe">managedByMe</a></code> parameter
        to <code>true</code>. This change does not affect the <code>prevPageToken</code> property
        for other <code>channels.list</code> requests, and it does not affect the
        <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#nextPageToken">nextPageToken</a></code>
        property for any requests.
      </li>

      <li>
        The <code>channel</code> resource's <code>contentDetails.relatedPlaylists.watchLater</code>
        and <code>contentDetails.relatedPlaylists.watchHistory</code> properties were both announced
        as deprecated on <a href="https://developers.google.com/youtube/v3/revision_history#august-11,-2016">11 August 2016</a>. The
        <code>playlistItems.insert</code> method's and <code>playlistItems.delete</code> method's support
        for these playlists are also now fully deprecated, and the two properties have been removed
        from the documentation.</li>

      <li>
        The <code>channels.list</code> method's <code>mySubscribers</code> parameter, which was
        announced as deprecated on <a href="https://developers.google.com/youtube/v3/revision_history#release_notes_07_30_2013">30 July 2013</a>, has been
        removed from the documentation. Use the
        <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list">subscriptions.list</a></code> method and
        its <code>mySubscribers</code> parameter to retrieve a list of subscribers to the
        authenticated user's channel.
      </li>

      <li>
        The <code>channel</code> resource's <code>invideoPromotion</code> object and all of its child
        properties, which were announced as deprecated on
        <a href="https://developers.google.com/youtube/v3/revision_history#november-27,-2017">27 November 2017</a>, have been removed from the documentation.
      </li>
    </ul>
]]>
    </content>
  </entry>
  <entry>
    <title>July 29, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-07-29</id>
    <updated>2020-07-29T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>We have simplified our process for charging quota for API requests by removing the additional
  cost associated with the <code>part</code> parameter. Effective immediately, we will only charge
  the base cost for the method that is called. You can find more information about the simplified
  quota <a href="https://developers.google.com/youtube/v3/determine_quota_cost">here</a>.</p>

<p>The effect of this change is that most API calls will have a marginally lower quota cost, while
  some API calls will still have the same cost. This change does not increase the cost of any API
  calls. Overall, the likely impact is that your allocated quota, which can be seen in the
  <a href="http://console.cloud.google.com">Google Cloud Console</a>, will go a little further.</p>

<p>We strongly recommend that all developers complete a
  <a href="https://support.google.com/youtube/contact/yt_api_form">compliance audit</a> for their
  projects to ensure continued access to the YouTube API Services.</p>

<p class="note">This revision history entry was originally published on July 20, 2020.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 28, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-07-28</id>
    <updated>2020-07-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
    <p>All videos uploaded via the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code>
      endpoint from unverified API projects created after <b>28 July 2020</b> will be restricted to
      private viewing mode. To lift this restriction, each project must
      <a href="https://support.google.com/youtube/contact/yt_api_form">undergo an audit</a> to verify
      compliance with the
      <a href="https://developers.google.com/youtube/terms/api-services-terms-of-service">Terms of Service</a>.
    </p>

    <p>Creators who use an unverified API client to upload video will receive an email explaining that
      their video is locked as private, and that they can avoid the restriction by using an official
      or audited client.</p>

    <p>API projects created prior to 28 July 2020 are
      not currently affected by this change. However, we strongly recommend that all developers
      <a href="https://support.google.com/youtube/contact/yt_api_form">complete a compliance audit</a>
      for their projects to ensure continued access to the YouTube API Services.
    </p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 21, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-07-21</id>
    <updated>2020-07-21T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="note">This revision history entry replaces a previous entry.</p>

<p>Yesterday, we published a documentation update related to our process for charging quota.
  However, due to unforeseen circumstances, the quota change is not yet in effect. As a result, the
  documentation has been reverted in the interest of accuracy. To avoid confusion, the revision
  history entry explaining the change has been removed and will be republished in the near future.
</p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 7, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-07-07</id>
    <updated>2020-07-07T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method's
<code>autoLevels</code> and <code>stabilize</code> parameters are now deprecated, and both parameters have been removed
from the documentation. Their values are ignored and do not affect the way newly uploaded videos are processed.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>June 15, 2020</title>
    <id>tag:google.com,changelog:youtube-api-services-terms-of-service-revision-history#2020-06-15</id>
    <updated>2020-06-15T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/terms/revision-history"/>
    <content type="html"><![CDATA[
<p>The new <a href="https://developers.google.com/youtube/terms/developer-policies-guide">Complying with the YouTube Developer
  Policies</a> guide provides guidance and examples to help you ensure that your API clients adhere
  to specific portions of the YouTube API Services
  <a href="https://developers.google.com/youtube/terms/api-services-terms-of-service">Terms</a> and
  <a href="https://developers.google.com/youtube/terms/developer-policies">Policies</a> (API TOS).</p>

<p>This guidance offers insight into how YouTube enforces certain aspects of the API TOS but does
  not replace any existing documents. The guide addresses some of the most common questions that
  developers ask during API compliance audits. We hope that it simplifies your feature development
  process by helping you understand how we interpret and enforce our policies.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>June 4, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-06-04</id>
    <updated>2020-06-04T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is an update to a prior deprecation announcement.</p>

<p>The channel bulletin feature has now been fully deprecated. This change was initially announced
  on 17 April 2020 and has now taken effect. As a result, the
  <code><a href="https://developers.google.com/youtube/v3/docs/activities/insert">activities.insert</a></code>
  method is no longer supported, and the
  <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code>
  method no longer returns channel bulletins. For more details, please see the
  <a href="https://support.google.com/youtube?p=channel-bulletins">YouTube Help Center</a>.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>April 17, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-04-17</id>
    <updated>2020-04-17T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p class="warning"><b>Note:</b> This is a deprecation announcement.</p>

<p>YouTube is deprecating the channel bulletin feature. As a result, the
  <code><a href="https://developers.google.com/youtube/v3/docs/activities/insert">activities.insert</a></code> method will be
  deprecated, and the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code>
  method will stop returning channel bulletins. These changes will be effective in the API on or
  after May 18, 2020. For more details, please see the
  <a href="https://support.google.com/youtube?p=channel-bulletins">YouTube Help Center</a>.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>March 31, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-03-31</id>
    <updated>2020-03-31T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>New resources and methods</strong></p>
    <ul>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/members">member</a></code> resource represents a
          channel member for a YouTube channel. A member provides recurring monetary support to a
          creator and receives special benefits. For example, members are able to chat when the
          creator turns on members-only mode for a chat.</p>
        <p>This resource replaces the <code><a href="https://developers.google.com/youtube/v3/live/docs/sponsors">sponsor</a></code>
          resource, which is documented as part of the YouTube Live Streaming API. The
          <code>sponsor</code> resource is now deprecated and API clients should update calls to
          the <code>sponsors.list</code> method to use the
          <code><a href="https://developers.google.com/youtube/v3/docs/members/list">members.list</a></code> method instead.</p>
      </li>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/membershipsLevels">membershipsLevel</a></code>
          resource identifies a pricing level managed by the creator that authorized the API request.
          The <code><a href="https://developers.google.com/youtube/v3/docs/membershipsLevels/list">membershipsLevels.list</a></code>
          method retrieves a list of all of the creator's membership levels.</p>
       </li>
    </ul>
  </li>
</ul>]]>
    </content>
  </entry>
  <entry>
    <title>January 10, 2020</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2020-01-10</id>
    <updated>2020-01-10T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The API now supports the ability to identify child-directed content, which YouTube calls
  "made for kids." <a href="https://support.google.com/youtube/answer/9528076">Learn more about
  "made for kids" content</a> in the YouTube Help Center.</p>

<p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> and
  <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resources support two new properties to
  enable content creators and viewers to identify content that is made for kids:</p>

<ul>
  <li>
    The <code>selfDeclaredMadeForKids</code> property enables content creators to specify whether a
    <a href="https://developers.google.com/youtube/v3/docs/channels#status.selfDeclaredMadeForKids">channel</a> or
    <a href="https://developers.google.com/youtube/v3/docs/videos#status.selfDeclaredMadeForKids">video</a> is made for kids.
    <br><br>
    For channels, this property can be set when calling the
    <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method. For videos,
    this property can be set when calling either the
    <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> or
    <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods.
    <br><br>
    Note that this property is only included in API responses that contain <code>channel</code> or
    <code>video</code> resources if the channel owner authorized the API request.
  </li>
  <li>
    The <code>madeForKids</code> property enables any user to retrieve the "made for kids" status
    of a <a href="https://developers.google.com/youtube/v3/docs/channels#status.madeForKids">channel</a> or
    <a href="https://developers.google.com/youtube/v3/docs/videos#status.madeForKids">video</a>. For example, the status might be
    determined based on the value of the <code>selfDeclaredMadeForKids</code> property. See the
    <a href="https://support.google.com/youtube/answer/9527654">YouTube Help Center</a> for more
    information about setting the audience for your channel, videos, or broadcasts.
  </li>
</ul>

<p>We have also updated the YouTube API Services Terms of Service and Developer Policies. Please
  see the <a href="https://developers.google.com/youtube/terms/revision-history">YouTube API Services Terms of Service - Revision
  History</a> for more information. The changes to the YouTube API Services Terms of Service and
  Developer Policies will take effect on January 10, 2020 Pacific Time.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>September 10, 2019</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2019-09-10</id>
    <updated>2019-09-10T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The API reference documentation has been updated to reflect a change to the way that subscriber
   counts are reported on YouTube and, consequently, in API responses. As a result of the change,
   subscriber counts returned by the YouTube Data API Service are rounded down to three significant
    figures for subscriber counts greater than 1000 subscribers. This change affects the
   <code>channel</code> resource's
   <a href="https://developers.google.com/youtube/v3/docs/channels#statistics.subscriberCount">statistics.subscriberCount</a>
   property.</p>

<p class="note"><b>Note:</b> This change affects this property value even in cases where a user
  sends an authorized request for data about their own channel. Channel owners can still see exact
  subscriber counts in YouTube Studio.</p>

<p>For example, if a channel has 123,456 subscribers, the
  <code>statistics.subscriberCount</code> property will contain the value <code>123000</code>.
  The table below shows examples of how subscriber counts are rounded in API responses and
  abbreviated in other publicly visible YouTube user interfaces:</p>

<table id="sample-subscriber-data">
  <thead>
    <tr>
      <th>Example subscriber count</th>
      <th>YouTube Data API</th>
      <th>Publicly visible YouTube UIs</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>1,234</td>
      <td>1230</td>
      <td>1.23K</td>
    </tr>
    <tr>
      <td>12,345</td>
      <td>12300</td>
      <td>12.3K</td>
    </tr>
    <tr>
      <td>123,456</td>
      <td>123000</td>
      <td>123K</td>
    </tr>
    <tr>
      <td>1,234,567</td>
      <td>1230000</td>
      <td>1.23M</td>
    </tr>
    <tr>
      <td>12,345,678</td>
      <td>12300000</td>
      <td>12.3M</td>
    </tr>
    <tr>
      <td>123,456,789</td>
      <td>123000000</td>
      <td>123M</td>
    </tr>
  </tbody>
</table>
]]>
    </content>
  </entry>
  <entry>
    <title>April 4, 2019</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2019-04-04</id>
    <updated>2019-04-04T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API reference documentation has been updated to better explain common use cases for each method and to provide dynamic, high-quality code samples through the APIs Explorer widget. See the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method's documentation for an example. There are now two new elements on pages that describe API methods:</p>
    <ul>
      <li>
        <p>The APIs Explorer widget lets you select authorization scopes, enter sample parameter and property values, and then send actual API requests and see actual API responses. The widget also offers a fullscreen view that shows complete code samples, which dynamically update to use the scopes and values that you have entered.</p>
      </li>
      <li>
        <p>The <b>Common use cases</b> section describes one or more common use cases for the method explained on the page. For example, you could call the <code>channels.list</code> method to retrieve data about a specific channel or to retrieve data about the current user's channel.</p>
        <p>You can use links in that section to populate the APIs Explorer with sample values for your use case or to open the fullscreen APIs Explorer with those values already populated. These changes aim to make it easier for you to see code samples that are directly applicable to the use case that you're trying to implement in your own application.</p>
      </li>
    </ul>

    <p>Code samples are currently supported for Java, JavaScript, PHP, Python, and curl.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">code samples</a> tool has also been updated with a new UI that offers all of the same features described above. Using that tool, you can explore use cases for different methods, load values into the APIs Explorer, and open the fullscreen APIs Explorer to get code samples in Java, JavaScript, PHP, and Python.</p>
    <p>In conjunction with this change, the pages that previously listed available code samples for Java, JavaScript, PHP, and Python have been removed.</p>
  </li>
  <li>
    <p>The quickstart guides for <a href="https://developers.google.com/youtube/v3/quickstarts/java">Java</a>, <a href="https://developers.google.com/youtube/v3/quickstarts/js">JavaScript</a>, <a href="https://developers.google.com/youtube/v3/quickstarts/php">PHP</a>, and <a href="https://developers.google.com/youtube/v3/quickstarts/python">Python</a> have been updated. The revised guides explain how to run one sample with an API key and another sample with an OAuth 2.0 client ID using code samples from the APIs Explorer.</p>
  </li>
</ul>

<p>Note that the changes described above replace an interactive tool that had been added to the API documentation in 2017.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>July 9, 2018</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2018-07-09</id>
    <updated>2018-07-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The definition of the <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#snippet.thumbnails">snippet.thumbnails</a></code> property has been updated to note that when displaying thumbnails in your application, your code should use the image URLs exactly as they are returned in API responses. For example, your application should not use the <code>http</code> domain instead of the <code>https</code> domain in a URL returned in an API response.</p>
    <p>Beginning in July 2018, channel thumbnail URLs will only be available in the <code>https</code> domain, which is how the URLs appear in API responses. After that time, you might see broken images in your application if it tries to load YouTube images from the <code>http</code> domain.</p>
  </li>
  <li>
    <p class="warning"><b>Note:</b> This is a deprecation announcement.</p>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.altitude">recordingDetails.location.altitude</a></code> property has been deprecated. There is no guarantee that videos will return values for this property. Similarly, even if API requests attempt to set a value for that property, it is possible that the incoming data will not be stored.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 22, 2018</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2018-06-22</id>
    <updated>2018-06-22T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The <a href="https://developers.google.com/youtube/v3/guides/implementation">Implementation
  guide</a>, formerly known as the Implementation and Migration guide, has been updated to remove
  instructions for migrating from the v2 API to the v3 API. In addition, instructions have also been
  removed for features that have since been deprecated in the v3 API, such as favorite videos.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>November 27, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-11-27</id>
    <updated>2017-11-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p class="warning"><b>Note:</b> This is a deprecation announcement.</p>
    <p>YouTube is removing support for the <b>Featured Video</b> and <b>Featured Website</b> features, which are supported in the API via the <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">invideoPromotion</a></code> object. As a result, that object, including all of its child properties are being deprecated.</p>
    <p>You can still retrieve and set <code>invideoPromotion</code> data until December 14, 2017. After that date:</p>
    <ul>
      <li>Attempts to retrieve the <code>invideoPromotion</code> part when calling <code>channels.list</code> will return an empty <code>invideoPromotion</code> or will not return any <code>invideoPromotion</code> data at all.</li>
      <li>Attempts to update <code>invideoPromotion</code> data when calling <code>channels.update</code> will return a successful response until at least May 27, 2018, but they will be treated as no-ops, meaning that they will not actually perform an update.</li>
    </ul>
    <p>After May 27, 2018, it is possible that these requests could return error messages to indicate, for example, that <code>invalidPromotion</code> is an invalid part.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>November 16, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-11-16</id>
    <updated>2017-11-16T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">interactive code snippet tool</a> now supports Node.js code samples. The samples are also visible in the documentation for almost all API methods, such as the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#usage">channels.list</a></code> method.</p>
    <p>The customizable samples are designed to give you a use-case-specific starting point for a Node.js application. The functionality is similar to the code in the <a href="https://developers.google.com/youtube/v3/quickstart/nodejs">Node.js quickstart guide</a>. However, the samples do contain some utility functions that don't appear in the quickstart:</p>
    <ul>
      <li>The <code>removeEmptyParameters</code> function takes a list of key-value pairs corresponding to API request parameters and removes the parameters that don't have values.</li>
      <li>The <code>createResource</code> function takes a list of key-value pairs corresponding to properties in an API resource. It then converts the properties into a JSON object that can be used in <code>insert</code> and <code>update</code> operations. The example below shows a set of property names and values and the JSON object that the code would create for them:
      <pre># Key-value pairs:
{'id': 'ABC123',
 'snippet.title': 'Resource title',
 'snippet.description': 'Resource description',
 'status.privacyStatus': 'private'}

# JSON object:
{
 'id': 'ABC123',
 'snippet': {
   'title': 'Resource title',
   'description': 'Resource description',
 },
 'status': {
   'privacyStatus': 'private'
 }
}</pre>
      </li>
    </ul>
    <p>All of these samples are designed to be downloaded and run locally. For more information, see the prerequisites for <a href="https://developers.google.com/youtube/v3/code_samples/code_snippet_instructions#toggle-code-snippets-and-full-samples">running full code samples locally</a> in the code snippet tool instructions.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 25, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-10-25</id>
    <updated>2017-10-25T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The Python code samples in the <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">interactive code snippet tool</a> have been updated to use the <code>google-auth</code> and <code>google-auth-oauthlib</code> libraries instead of the <code>oauth2client</code> library, which is now deprecated.</p>
    <p>In addition to that change, the tool now provides full code samples for installed Python applications and Python web server applications, which use slightly different authorization flows. To see the full samples (and this change):</p>
    <ol>
      <li>Go to the <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">interactive code snippet tool</a> or to the documentation for any API method, such as the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#usage">channels.list</a></code> method.</li>
      <li>Click the <code>Python</code> tab above the code samples.</li>
      <li>Click the toggle above the tabs to switch from seeing a snippet to a full sample.<br>
          <img src="https://developers.google.com/youtube/images/interactive-snippet-slider.png">
      </li>
      <li>The tab should now show a complete code sample that uses the <code>InstalledAppFlow</code> authorization flow. The description above the sample explains this and also links to a sample for a web server application.</li>
      <li>Click the link to switch to the web server example. That sample uses the Flask web application framework and a different authorization flow.</li>
    </ol>
    <p>All of these samples are designed to be downloaded and run locally. If you'd like to run the samples, see the instructions for <a href="https://developers.google.com/youtube/v3/code_samples/code_snippet_instructions#toggle-code-snippets-and-full-samples">running full code samples locally</a> in the code snippet tool instructions.</p>
  </li>
</ul>

]]>
    </content>
  </entry>
  <entry>
    <title>August 29, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-08-29</id>
    <updated>2017-08-29T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>The definition of the <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#forContentOwner">forContentOwner</a></code> parameter has been updated to note that if that parameter is set to <code>true</code>, the <code>type</code> parameter must be set to <code>video</code>.</li>
  <li>The definition of the <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#regionCode">regionCode</a></code> parameter has been updated to clarify that the parameter restricts search results to videos that can be viewed in the specified region.</li>
  <li>YouTube has updated its branding logos and icons. New "developed with YouTube" logos can be downloaded from the <a href="https://developers.google.com/youtube/terms/branding-guidelines">branding guidelines</a> page. Other new YouTube logos and icons are also shown on that page and can be downloaded from the <a href="https://www.youtube.com/yt/about/brand-resources/#logos-icons-colors">YouTube brand site</a>.</li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>July 24, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-07-24</id>
    <updated>2017-07-24T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>A new YouTube Data API quickstart guide is available for <a href="https://developers.google.com/youtube/v3/quickstart/ios">iOS</a>. The guide explains how to use the YouTube Data API in a simple iOS application written in either Objective-C or Swift.</li>
  <li>The <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">interactive code snippet tool</a> for the YouTube Data API now includes documentation explaining some of the tool's features:
    <ul>
      <li>Executing API requests</li>
      <li>Toggling between code snippets and full code samples</li>
      <li>Using boilerplate functions</li>
      <li>Loading existing resources (for update methods)</li>
    </ul>
    <p class="note"><b>Note:</b> The tool is also embedded in API reference documentation for API methods (<a href="https://developers.google.com/youtube/v3/docs/search/list#usage">example</a>).</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 1, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-06-01</id>
    <updated>2017-06-01T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p class="warning"><b>Note:</b> This is a deprecation announcement.</p>
    <p>The following <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resource properties are being deprecated. While the properties will be supported until December 1, 2017, there is no guarantee that videos will continue to return values for those properties until that time. Similarly, <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> requests that set those property values will not generate errors before that date, but it is possible that the incoming data will not be stored.</p>
    <ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.locationDescription">recordingDetails.locationDescription</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.latitude">recordingDetails.location.latitude</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.longitude">recordingDetails.location.longitude</a></code></li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 17, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-05-17</id>
    <updated>2017-05-17T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API reference documentation has been updated to make code snippets more ubiquitous and interactive. Pages that explain API methods, like <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#usage">channels.list</a></code> or <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate#usage">videos.rate</a></code>, now feature an interactive tool that lets you view and customize code snippets in Java, JavaScript, PHP, Python, Ruby, Apps Script, and Go.</p>
    <p>For any given method, the tool shows code snippets for one or more use cases, and each use case describes a common way of calling that method. For example, you can call the <code>channels.list</code> method to retrieve data about a specific channel or about the current user's channel.</p>
    <p>You can also interact with code samples:</p>
    <ul>
      <li>
        <p>Modify parameter and property values, and the code snippets dynamically update to reflect the values you provide.</p>
      </li>
      <li>
        <p>Toggle between code snippets and full samples. A code snippet shows the portion of the code that calls the API method. A full sample contains that snippet as well as boilerplate code for authorizing and sending requests. Full samples can be copied and run from the command line or a local web server.</p>
      </li>
      <li>
        <p>Execute requests by clicking a button. (To execute requests, you need to authorize the tool to call the API on your behalf.)</p>
      </li>
    </ul>
    <p>Note that this tool has replaced the APIs Explorer on the pages where it is available. (Each page displays a link so that you also have the option of loading the request you are working on in the APIs Explorer.)</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">Data API Code Snippets</a> tool has also been updated with a new UI that offers all of the same features described above. The major new features available on this page are:</p>
    <p><ul>
      <li>Support for API requests that write data.</li>
      <li>Support for Java samples.</li>
      <li>More flexible and comprehensive boilerplate code for authorizing users and building API requests.</li>
    </ul></p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 27, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-04-27</id>
    <updated>2017-04-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>New quickstart guides explain how to set up a simple application that makes YouTube Data API requests. Guides are currently available for <a href="https://developers.google.com/youtube/v3/quickstart/android">Android</a>, <a href="https://developers.google.com/youtube/v3/quickstart/apps-script">Apps Script</a>, <a href="https://developers.google.com/youtube/v3/quickstart/go">Go</a>, <a href="https://developers.google.com/youtube/v3/quickstart/java">Java</a>, <a href="https://developers.google.com/youtube/v3/quickstart/js">JavaScript</a>, <a href="https://developers.google.com/youtube/v3/quickstart/nodejs">Node.js</a>, <a href="https://developers.google.com/youtube/v3/quickstart/php">PHP</a>, <a href="https://developers.google.com/youtube/v3/quickstart/python">Python</a>, and <a href="https://developers.google.com/youtube/v3/quickstart/ruby">Ruby</a>.</li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 30, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-03-30</id>
    <updated>2017-03-30T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails.topicCategories[]">topicDetails.topicCategories[]</a></code> property contains a list of Wikipedia URLs that describe the channel's content. The URLs correspond to the topic IDs returned in the resource's <code>topicDetails.topicIds[]</code> property.</li>
  <li>The <code>playlistItem</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#contentDetails.videoPublishedAt">contentDetails.videoPublishedAt</a></code> property identifies the time that the video was published to YouTube. The resource already contains the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#snippet.publishedAt">snippet.publishedAt</a></code> property, which identifies the time that the item was added to the playlist.</li>
  <li>Like the <code>channel</code> resource, the <code>video</code> resource now returns the <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.topicCategories[]">topicDetails.topicCategories[]</a></code> property, which contains a list of Wikipedia URLs that describe the video's content. For <code>video</code> resources, the URLs correspond to the topic IDs returned in the resource's <code>topicDetails.relevantTopicIds[]</code> property.</li>
  <li>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mpaatRating">contentDetails.contentRating.mpaatRating</a></code> property identifies the rating that the Motion Picture Association of America gave to a movie trailer or preview.</li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>February 27, 2017</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2017-02-27</id>
    <updated>2017-02-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>As originally <a href="https://developers.google.com/youtube/v3/revision_history#topic-id-changes">announced on August 11, 2016</a>, YouTube has switched the supported list of topic IDs to a curated list. The complete list of supported topic IDs is included in the <code>topicDetails</code> properties for <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails">channel</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails">video</a></code> resources as well as in the <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#topicId">topicId</a></code> parameter.</p>

<p>Note that there are several changes to the curated list:</p>

<ul>
  <li>The following topics have been added as subtopics of <code>Society</code>:
    <table>
      <tr><th>Name</th><th>topic ID</th></tr>
      <tr><td>Business</td><td><code>/m/09s1f</code></td></tr>
      <tr><td>Health</td><td><code>/m/0kt51</code></td></tr>
      <tr><td>Military</td><td><code>/m/01h6rj</code></td></tr>
      <tr><td>Politics</td><td><code>/m/05qt0</code></td></tr>
      <tr><td>Religion</td><td><code>/m/06bvp</code></td></tr>
    </table>
  </li>
  <li>The <code>Animated cartoon</code> topic, previously a child of <code>Entertainment</code>, has been removed.</li>
  <li>The <code>Children's music</code> topic, previously a child of <code>Music</code>, has been removed.</li>
</ul>

<p>Note that as a result of this change, topics related to a video are now always returned in the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.relevantTopicIds[]">topicDetails.relevantTopicIds[]</a></code> property value.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>November 29, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-11-29</id>
    <updated>2016-11-29T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>There are three small changes to the list of topic IDs that will be supported as of February 10, 2017:</p>
    <ul>
      <li>The <code>Professional wrestling</code> category, which was previously a child of the <code>Sports</code> category, is now a child of <code>Entertainment</code>.</li>
      <li>The <code>TV shows</code> category, which is a child of <code>Entertainment</code>, is new.</li>
      <li>The <code>Health</code> category, previously a child of <code>Lifestyle</code>, has been removed.</li>
    </ul>
    <p>Also note that there are a few parent categories (<code>Entertainment</code>, <code>Gaming</code>, <code>Lifestyle</code>, <code>Music</code>, and <code>Sports</code>). Any video that is associated with a child category, like <code>Tennis</code>, will also be associated with the parent category (<code>Sports</code>).</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>November 10, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-11-10</id>
    <updated>2016-11-10T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>As <a href="https://developers.google.com/youtube/v3/revision_history#topic-id-changes">first announced on August 11, 2016</a>, the deprecation of Freebase and the Freebase API requires several changes related to topic IDs. Topic IDs identify topics associated with <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails">channel</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails">video</a></code> resources, and you can also use the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#topicId">topicId</a></code> search parameter to find channels or videos related to a particular topic.</p>
    <p>On February 10, 2017, YouTube will start returning a small set of topic IDs instead of the much more granular set of IDs returned thus far. In addition, note that channels and videos are not guaranteed to be associated with any topics, which is consistent with current API behavior.</p>
    <p>So that you can prepare your API Clients for those changes, the definitions of the following API parameters and properties have been updated to list the topic IDs that will be supported after that time. Note that the list of categories is the same for all of the properties.</p>
    <ul>
      <li>The <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails.topicIds[]">topicDetails.topicIds[]</a></code> property.</li>
      <li>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.relevantTopicIds[]">topicDetails.relevantTopicIds[]</a></code> property.</li>
      <li>The <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#topicId">topicId</a></code> parameter.</li>
    </ul>
  </li>
  <li>
    <p class="warning"><b>Note:</b> This is a deprecation announcement.</p>
    <p>The following properties are being deprecated:</p>
    <ul>
      <li>The <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails.topicIds[]">topicDetails.topicIds[]</a></code> property. This property will be supported until November 10, 2017.</li>
      <li>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.relevantTopicIds[]">topicDetails.relevantTopicIds[]</a></code> property. This property will be supported until November 10, 2017.</li>
      <li>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.topicIds[]">topicDetails.topicIds[]</a></code> property. This property will not contain values after February 10, 2017. (After that date, the <code>topicDetails.relevantTopicIds[]</code> property value will identify all of the topics associated with a video.)</p>
    </ul>
  </li>
  <li>
    <p>Since Freebase has already been deprecated, the <b>Searching with Freebase Topics</b> guide has been removed from the documentation. That guide provided code samples to show how an application would work with the Freebase API.</p>
    <p>In addition, several code samples related to topic IDs have been removed from the <code>search.list</code> method's documentation.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>November 2, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-11-02</id>
    <updated>2016-11-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><b>New properties and parameters</b></p>
    <ul>
      <li>
        <p>The <code>video</code> resource contains several new properties:</p>
        <ul>
          <li>
            <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos#player.embedHtml">player.embedHtml</a></code> property contains an <code>&lt;iframe&gt;</code> tag that you can use to embed a player that plays the video. The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#player.embedHeight">player.embedHeight</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#player.embedWidth">player.embedWidth</a></code> properties identify the dimensions of the embedded player. These properties are only returned if the API request specifies a value for at least one of the <code>maxHeight</code> or <code>maxWidth</code> parameters. Those two new parameters are explained later in this revision history entry.</p>
          </li>
          <li>
            <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.hasCustomThumbnail">hasCustomThumbnail</a></code> property indicates whether the video uploader has provided a custom thumbnail image for the video. Note that this property is only visible to the video uploader.</p>
          </li>
          <li>
            <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fpbRatingReasons[]">fpbRatingReasons[]</a></code> identifies reasons that the video received its FPB (South Africa) rating.</p>
          </li>
          <li>
            <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mcstRating">mcstRating</a></code> identifies the rating that the video received in Vietnam.</p>
          </li>
        </ul>
      </li>
      <li>
        <p>The <code>videos.list</code> method supports two new parameters, <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#maxHeight">maxHeight</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#maxWidth">maxWidth</a></code>. You can use either parameter or both parameters when retrieving the <code>player</code> part in <code>video</code> resources.</p>
        <p>By default, the height of the <code>&lt;iframe&gt;</code> returned in the <code>player.embedHtml</code> property is 360px. The width adjusts to match the video's aspect ratio, thereby ensuring that the embedded player does not have black bars framing the video. So, for example, if a video's aspect ratio is 16:9, the player's width would be 640px.</p>
        <p>With the new parameters, you can specify that instead of the default dimensions, the embed code should use a height and/or width appropriate for your application layout. The API server scales the player dimensions as appropriate to ensure that the embedded player does not have black bars framing the video. Note that both parameters specify the maximum dimensions of the embedded player. Thus, if both parameters are specified, one dimension might still be smaller than the maximum amount allowed for that dimension.</p>
        <p>For example, suppose a video has a 16:9 aspect ratio. Thus, the <code>player.embedHtml</code> tag would contain a 640x360 player if the <code>maxHeight</code> or <code>maxWidth</code> parameter is not set.</p>
        <p><ul>
          <li>If the <code>maxHeight</code> parameter is set to <code>720</code>, and the <code>maxWidth</code> parameter is not set, the API would return a 1280x720 player.</li>
          <li>If the <code>maxWidth</code> parameter is set to <code>960</code>, and the <code>maxHeight</code> parameter is not set, the API would return a 960x540 player.</li>
          <li>If the <code>maxWidth</code> parameter is set to <code>960</code>, and the <code>maxHeight</code> parameter is set to <code>450</code>, the API would return an 800x450 player.</li>
        </ul></p>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#player.embedHeight">player.embedHeight</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#player.embedWidth">player.embedWidth</a></code> properties, which are described above, identify the player's dimensions.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><b>Updates to existing methods, properties and parameters</b></p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections">channelSection</a></code> resource description has been updated to note that a channel can create a maximum of 10 shelves without setting <a href="https://developers.google.com/youtube/v3/docs/channelSections#targeting">targeting data</a> and can create a maximum of 100 shelves with targeting data.</p>
        <p>In addition, the <code>channelSection</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channelSections#targeting">targeting</a></code> property has been updated to reflect the fact that targeting options can only be set using the API. Targeting options are deleted if the channel section is modified using the user interface on the YouTube website.</p>
      </li>
      <li>
        <p>The definition of the <code>i18nLanguage</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/i18nLanguages#snippet.name">snippet.name</a></code> property has been corrected to reflect that the value represents a language's name as it is written in the language specified by the <code>i18nLanguage.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/i18nLanguages/list#hl">hl</a></code> parameter.</p>
      </li>
      <li>
        <p>The <code>playlistItem</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#contentDetails.note">contentDetails.note</a></code> property has been updated to note that the property value's maximum length is 280 characters.</p>
      </li>
      <li>
        <p>The <code>playlistItem</code> resource's <code>contentDetails.startAt</code> and <code>contentDetails.endAt</code> properties have been deprecated. These fields are ignored if they are set in <code>playlistItems.insert</code> or <code>playlistItems.update</code> requests.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/delete#params">playlistItems.delete</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update#params">playlistItems.update</a></code> methods now support the <code>onBehalfOfContentOwner</code> parameter, which is already supported for several other methods. Requests that use that method also need to be authorized with a token that provides access to the <code>https://www.googleapis.com/auth/youtubepartner</code> scope.</p>
      </li>
      <li>
        <p>The <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#publishedBefore">publishedBefore</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/search/list#publishedAfter">publishedAfter</a></code> parameters have both been updated to indicate that the parameter values are inclusive. So, for example, if the <code>publishedBefore</code> parameter is set, the API returns resources created before <em>or at</em> the specified time.</p>
      </li>
      <li>
        <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.grfilmRating">contentDetails.contentRating.grfilmRating</a></code> property supports three additional values: <code>grfilmK12</code>, <code>grfilmK15</code>, and <code>grfilmK18</code>.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method description has been updated to note that the maximum file size for uploaded videos has increased from 64GB to 128GB.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><b>New and updated errors</b></p>
    <ul>
      <li>
        <p>The API supports the following new errors:</p>
        <table class="matchpre" id="property-table">
          <thead>
            <tr>
              <th>Error type</th>
              <th>Error detail</th>
              <th>Description</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td class="error-name"><code>forbidden (403)</code></td>
              <td class="error-reason"><code>homeParameterDeprecated</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code> method returns this error to indicate that the user's home page activity data is not available through this API. This error might occur if you set the <code>home</code> parameter to <code>true</code> in an unauthorized request.</td>
            </tr>
            <tr>
              <td class="error-name"><code>invalidValue (400)</code></td>
              <td class="error-reason"><code>invalidContentDetails</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code> method returns this error to indicate that the <code>contentDetails</code> object in the request is invalid. One reason that this error occurs is that the <code>contentDetails.note</code> field is longer than 280 characters.</td>
            </tr>
            <tr>
              <td class="error-name"><code>forbidden (403)</code></td>
              <td class="error-reason"><code>watchHistoryNotAccessible</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list">playlistItems.list</a></code> method returns this error to indicate that the request tried to retrieve "watch history" playlist items, but those cannot be retrieved using the API.</td>
            </tr>
            <tr>
              <td class="error-name"><code>forbidden (403)</code></td>
              <td class="error-reason"><code>watchLaterNotAccessible</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list">playlistItems.list</a></code> method returns this error to indicate that the request tried to retrieve "watch later" playlist items, but those cannot be retrieved using the API.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>uploadLimitExceeded</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method returns this error to indicate that the channel has exceeded the number of videos that it may upload.</td>
            </tr>
            <tr>
              <td class="error-name"><code>forbidden (403)</code></td>
              <td class="error-reason"><code>forbiddenEmbedSetting</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the API request attempts to set an invalid embed setting for the video. Note that some channels may not have permission to offer embedded players for live streams. See the <a href="https://support.google.com/youtube/answer/2474026">YouTube Help Center</a> for more information.</td>
            </tr>
          </tbody>
        </table>
      </li>
      <li>
        <p>The <code>playlistItems.insert</code> method no longer returns an error if you insert a duplicate video into a playlist. That error previously occurred for some playlists, like favorite videos, that did not allow duplicates but are no longer supported. In general, playlists do allow duplicate videos.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><b>Other updates</b></p>
    <ul>
      <li>
        <p>The revision history entry for September 15, 2016, has been updated to clarify that, whenever the <code>channel</code> resource's <code>contentDetails.relatedPlaylists.watchHistory</code> and <code>contentDetails.relatedPlaylists.watchLater</code> properties are included in a response, they always contain the values <code>HL</code> and <code>WL</code>, respectively. Moreover, those properties are only included if an authorized user is retrieving data about the user's own channel.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>September 15, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-09-15</id>
    <updated>2016-09-15T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The August 11, 2016, revision history update discussed several changes related to topic IDs, including the fact that the set of supported topic IDs will change as of February 10, 2017. The list of topics that will be supported will be published by November 10, 2016.</p>
  </li>
  <li>
    <p>The following changes are now in effect. Notice of these changes was given in the revision history update on August 11, 2016:</p>
    <ul>
      <li>
        <p>If the <code>activities.list</code> method is called with the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#home">home</a></code> parameter set to <code>true</code>, the API response now contains items similar to what a logged-out YouTube user would see on the home page.
        <p>This is a slight change that is intended to provide a better user experience than the behavior described in the revision history update on August 11, 2016. That update had stated that requests using the <code>home</code> parameter would return an empty list.</p>
      </li>
      <li>
        <p>The <code>channel</code> resource's <code>contentDetails.relatedPlaylists.watchHistory</code> and <code>contentDetails.relatedPlaylists.watchLater</code> properties now contain values of <code>HL</code> and <code>WL</code>, respectively, for all channels. (The properties are only visible to an authorized user retrieving data about the user's own channel.)</p>
        <p>In addition, requests to retrieve playlist details (<code>playlists.list</code>) or playlist items (<code>playlistItems.list</code>) for a channel's watch history or watch later playlist now return empty lists. This behavior is true for the new values, <code>HL</code> and <code>WL</code>, as well as for any watch history or watch later playlist IDs that your API Client may have already stored.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resource's <code>fileDetails.recordingLocation</code> object and its child properties are no longer returned. Previously, this data (like the parent <code>fileDetails</code> object) could only be retrieved by a video's owner.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 11, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-08-11</id>
    <updated>2016-08-11T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The newly published YouTube API Services Terms of Service ("the Updated Terms"), discussed in detail on the <a href="http://youtube-eng.blogspot.com/">YouTube Engineering and Developers Blog</a>, provides a rich set of updates to the current Terms of Service. In addition to the <a href="https://developers.google.com/youtube/terms/api-services-terms-of-service">Updated Terms</a>, which will go into effect as of February 10, 2017, this update includes several supporting documents to help explain the policies that developers must follow.</p>
    <p>The full set of new documents is described in the <a href="https://developers.google.com/youtube/terms/revision-history">revision history for the Updated Terms</a>. In addition, future changes to the Updated Terms or to those supporting documents will also be explained in that revision history. You can subscribe to an RSS feed listing changes in that revision history from a link in that document.</p>
  </li>
  <li>
    <p>The deprecation of Freebase and the Freebase API is causing several changes related to topic IDs. Topic IDs are used in the following API resources and methods:</p>
    <ul>
      <li>The <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#topicDetails">topicDetails</a></code> part identifies topics associated with the channel.</li>
      <li>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails">topicDetails</a></code> part identifies topics associated with the video.</li>
      <li>The <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#topicId">topicId</a></code> parameter lets you search for videos or channels related to a particular topic.</li>
    </ul>
    <p>The changes to these features are:</p>
    <ul>
      <li>
        <p>As of February 10, 2017, YouTube will start returning a small set of topic IDs instead of the much more granular set of IDs returned thus far. That set of supported topics will identify high-level categorizations like <b>Sports</b> or <b>Basketball</b>, but, for example, they will not identify specific teams or players. We will be announcing the set of supported topics so that you have time to prepare your application for this change.</p>
      </li>
      <li>
        <p>Any Freebase topic IDs that you have already retrieved can be used to search for content until February 10, 2017. However, after that time, you will be able to use only the smaller set of topics identified in the previous item to retrieve search results by topic.</p>
      </li>
      <li>
        <p>After February 10, 2017, if you try to search for results using a topic ID that is not in the smaller set of supported topic IDs, the API will return an empty result set.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>Several API fields and parameters are being deprecated effective September 12, 2016:</p>
    <ul>
      <li>
        <p>The <code>activities.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#home">home</a></code> parameter enabled an authorized user to retrieve the activity feed that would display on the YouTube home page for that user. Requests that use this parameter after September 12, 2016, will return an empty list.</p>
      </li>
      <li>
        <p>The <code>channel</code> resource's <code>contentDetails.relatedPlaylists.watchHistory</code> and <code>contentDetails.relatedPlaylists.watchLater</code> properties are only visible to an authorized user retrieving data about the user's own channel. After September 12, 2016, the <code>contentDetails.relatedPlaylists.watchHistory</code> will return a value of <code>HL</code> and the <code>contentDetails.relatedPlaylists.watchLater</code> property will return a value of <code>WL</code> for all channels.</p>
        <p>Requests to retrieve playlist details (<code>playlists.list</code>) for a channel's watch history or watch later playlist will return an empty list after September 12, 2016. Requests to retrieve playlist items (<code>playlistItems.list</code>) in either of those playlists will also return an empty list after that time. This is true for the new values, <code>HL</code> and <code>WL</code>, as well as for any watch history or watch later playlist IDs that your API Client may have already stored.</p>
      </li>
     <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resource's <code>fileDetails.recordingLocation</code> object or any of its child properties will no longer be returned after September 12, 2016. This data can only be retrieved by a video's owner since the parent <code>fileDetails</code> object can only be retrieved by a video owner.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 13, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-06-13</id>
    <updated>2016-06-13T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channel</code> resource's <code>contentDetails.googlePlusUserId</code> property has been deprecated. Previously, the property was only present if the channel was associated with a Google+ profile. Following the deprecation, the property will no longer be included in any <code>channel</code> resources.</p>
  </li>
  <li>
    <p>The <code>comment</code> resource's <code>snippet.authorGoogleplusProfileUrl</code> property has been deprecated. Previously, the property was only present if the channel was associated with a Google+ profile. Following the deprecation, the property will no longer be included in any <code>comment</code> resources.</p>
  </li>
</ul>

<p>Since neither of these properties will be returned following the deprecation, both properties have been removed from the corresponding resource documentation.</p>

]]>
    </content>
  </entry>
  <entry>
    <title>May 31, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-05-31</id>
    <updated>2016-05-31T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>subscriptions.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#myRecentSubscribers">myRecentSubscribers</a></code> parameter retrieves a list of the subscribers of the authenticated user's channel in reverse chronological order of the time that they subscribed to the channel.</p>
    <p>Note that the new parameter only supports retrieval of the most recent 1000 subscribers to the authenticated user's channel. To retrieve a complete list of subscribers, use the <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#mySubscribers">mySubscribers</a></code> parameter. That parameter, which does not return subscribers in a particular order, does not limit the number of subscribers that can be retrieved.</p>
  </li>
  <li>
    <p>The definition of the <code>snippet.thumbnails.(key)</code> property has been updated for the <a href="https://developers.google.com/youtube/v3/docs/activities#snippet.thumbnails.(key)">activity</a>, <a href="https://developers.google.com/youtube/v3/docs/playlistItems#snippet.thumbnails.(key)">playlistItem</a>, <a href="https://developers.google.com/youtube/v3/docs/playlists#snippet.thumbnails.(key)">playlist</a>, <a href="https://developers.google.com/youtube/v3/docs/search#snippet.thumbnails.(key)">search result</a>, <a href="https://developers.google.com/youtube/v3/docs/thumbnails#snippet.thumbnails.(key)">thumbnail</a>, and <a href="https://developers.google.com/youtube/v3/docs/videos#snippet.thumbnails.(key)">video</a> resources to note that additional thumbnail image sizes are available for some videos.</p>
    <ul>
      <li>The <code>standard</code> image is 640px wide and 480px tall.</li>
      <li>The <code>maxres</code> image is 1280px wide and 720px tall.</li>
    </ul>
  </li>
  <li>
    <p>The definition of the <code>channelSection.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/list#part">part</a></code> parameter has been updated to note that the <code>targeting</code> part can be retrieved at a cost of <code>2</code> quota units.</p>
  </li>
  <li>
    <p>The <code>videos.list</code> method now returns a <a href="https://developers.google.com/youtube/v3/docs/videos/list#youtube.videos.list-forbidden-forbidden-feedback">forbidden</a> (<code>403</code>) error when an improperly authorized request tries to retrieve the <code>fileDetails</code>, <code>processingDetails</code>, or <code>suggestions</code> parts of a <code>video</code> resource. Those parts are only available to the video's owner.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 17, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-05-17</id>
    <updated>2016-05-17T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>The new <a href="https://developers.google.com/youtube/v3/code_samples/code_snippets">Data API Code Snippets</a> tool provides short code snippets for common YouTube Data API use cases. Code snippets are currently available for all read-only API methods in Apps Script, Go, JavaScript, PHP, Python, and Ruby.</p>

<p>For each method, the tool shows code samples for one or more use cases. For example, it provides five code snippets for the <code>search.list</code> method:</p>

<ul>
  <li>List videos by keyword</li>
  <li>List videos by location</li>
  <li>List live events</li>
  <li>Search for the authenticated user's videos</li>
  <li>List related videos</li>
</ul>

<p>For each use case, the tool displays the parameters used in the API request. You can modify the parameter values, in which case the tool updates the code snippets to reflect the parameter values that you provided.</p>

<p>Finally, the tool displays the API response to each request. If you have modified the request parameters, the API response is based on your provided parameter values. Note that you need to authorize the tool to submit requests on your behalf for API responses to display.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>April 28, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-04-28</id>
    <updated>2016-04-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.projection">contentDetails.projection</a></code> property specifies the video's projection format. Valid property values are <code>360</code> and <code>rectangular</code>.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location">recordingDetails.location</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails.recordingLocation">fileDetails.recordingLocation</a></code> properties have both been updated to explain the difference between the two properties:</p>
    <p><ul>
      <li>The <code>recordingDetails.location</code> property identifies the location that the video owner wants to associate with the video. This location is editable, searchable on public videos, and might be displayed to users for public videos.</li>
      <li>The <code>fileDetails.recordingLocation</code> property value is immutable and represents the location associated with the original, uploaded video file. The value is only visible to the video owner.</li>
    </ul></p>
  </li>
  <li>
    <p>The definition of the <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#contentDetails.relatedPlaylists.favorites">contentDetails.relatedPlaylists.favorites</a></code> property has been updated to note that the property value might contain a playlist ID that refers to an empty playlist and that cannot be fetched. This is due to the fact that favorite videos functionality has already been deprecated. Note that this property is <a href="https://developers.google.com/youtube/youtube-api-list">not subject to the API deprecation policy</a>.</p>
  </li>
  <li>
    <p>The definition of the <code>ineligibleAccount</code> error, which can be returned by the <code>comments.insert</code>, <code>comments.update</code>, <code>commentThreads.insert</code>, or <code>commentThreads.update</code> method, has been updated to reflect that the error occurs when the YouTube account used to authorize the API request has not been merged with the user's Google account.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 20, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-04-20</id>
    <updated>2016-04-20T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The definition of the <code>channels.update</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/channels/update#part">part</a></code> parameter has been updated to note that <code>localizations</code> is also a valid value for that parameter.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/getting-started#quota">Quota Usage</a> section of the Getting Started guide has been updated to link to the Google Developer's Console, where you can see your actual quota and quota usage.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 16, 2016</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2016-03-16</id>
    <updated>2016-03-16T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelBanners">channelBanner</a></code> resource documentation has been updated to note that the recommended size for the uploaded channel banner image is 2560px by 1440px. The minimum size (2048px by 1152px) has not changed.</p>
      </li>
      <li>
        <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#snippet.customUrl">snippet.customUrl</a></code> property identifies the custom URL associated with the channel. (Not all channels have custom URLs.) The <a href="https://support.google.com/youtube/answer/2657968">YouTube Help Center</a> explains eligibility requirements for getting a custom URL as well as how to set up the URL.</p>
      </li>
      <li>
        <p>The <code>channel</code> resource's <code>brandingSettings.watch</code> object and all of its child properties have been deprecated.</p>
      </li>
      <li>
        <p>The API response to a <code>search.list</code> request now contains a <code><a href="https://developers.google.com/youtube/v3/docs/search/list#properties">regionCode</a></code> property. The property identifies the region code that was used for the search query. The region code instructs the API to return search results for the specified country.</p><p>The property value is a two-letter ISO country code that identifies the region. The <code><a href="https://developers.google.com/youtube/v3/docs/i18nRegions/list">i18nRegions.list</a></code> method returns a list of supported regions. The default value is <code>US</code>. If a non-supported region is specified, YouTube might still select another region, rather than the default value, to handle the query.</p>
      </li>
      <li>
        <p>The definitions of the <code>videoAbuseReportReason</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons#snippet.label">snippet.label</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons#snippet.secondaryReasons[].label">snippet.secondaryReasons[].label</a></code> properties have been updated to note that the properties contain localized label text for the abuse report reasons.</p>
        <p>In addition, the <code>videoAbuseReportReasons.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons/list#params">hl</a></code> parameter, which specifies the language that should be used for label text in the API response. The default parameter value is <code>en_US</code>.</p>
      </li>
      <li>
        <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.ecbmctRating">contentDetails.contentRating.ecbmctRating</a></code> property identifies a video's rating from Turkey's Evaluation and Classification Board of the Ministry of Culture and Tourism.</p>
        <p>In addition, API properties for other rating systems support the following new property values:</p>
        <ul>
          <li><code>contentDetails.contentRating.fpbRating</code> (South Africa)<br>Rating: 10; property value: <code>fpb10</code></li>
          <li><code>contentDetails.contentRating.moctwRating</code> (Taiwan)<br>Rating: R-12; property value: <code>moctwR12</code></li>
          <li><code>contentDetails.contentRating.moctwRating</code> (Taiwan)<br>Rating: R-15; property value: <code>moctwR15</code></li>
        </ul>
      </li>
      <li>
        <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.activeLiveChatId">liveStreamingDetails.activeLiveChatId</a></code> property contains the ID of the active live chat associated with the video. The property value is only present if the video is a current live broadcast that has live chat enabled. After the broadcast ends and the live chat concludes, the property is no longer returned for the video.</p>
      </li>
      <li>
        <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.rejectionReason">status.rejectionReason</a></code> property supports the new property value <code>legal</code>.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The API supports the following new errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>notEditable</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/delete">channelSections.delete</a></code> methods return this error to indicate that the specified channel section cannot be created, updated, or deleted.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>styleRequired</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code> methods return this error to indicate that the <code>channelSection</code> resource submitted in the API request must specify a value for the <code>snippet.style</code> property.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>typeRequired</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code> methods return this error to indicate that the <code>channelSection</code> resource submitted in the API request must specify a value for the <code>snippet.type</code> property.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>processingFailure</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list">commentThreads.list</a></code> method returns this error to indicate that the API server failed to successfully process the request. While this can be a transient error, it usually indicates that the request's input is invalid. Check the structure of the <code>commentThread</code> resource in the request body to ensure that it is valid.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>commentsDisabled</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list">commentThreads.list</a></code> method returns this error to indicate that the video identified by the <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list#videoId">videoId</a></code> parameter has disabled comments.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>commentTextTooLong</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/insert">commentThreads.insert</a></code> method returns this error to indicate that the <code>comment</code> resource that is being inserted contains too many characters in the <code>snippet.topLevelComment.snippet.textOriginal</code> property.</td>
        </tr>
        <tr>
          <td class="error-name"><code>invalidValue (400)</code></td>
          <td class="error-reason"><code>videoAlreadyInAnotherSeriesPlaylist</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code> method returns this error to indicate that the video that you are trying to add to the playlist is already in another series playlist. See the <a href="https://support.google.com/youtube/answer/6084043">YouTube Help Center</a> for more information about series playlists.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>subscriptionForbidden</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert">subscriptions.insert</a></code> method returns this error to indicate that you have reached your maximum number of subscriptions or that you have created too many recent subscriptions. In the latter case, you can retry the request after a few hours.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidCategoryId</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>snippet.categoryId</code> property in the uploaded <code>video</code> resource specified an invalid category ID. Use the <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a></code> method to retrieve supported categories.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidDescription</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>snippet.description</code> property in the uploaded <code>video</code> resource specified an invalid value.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidPublishAt</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>status.publishAt</code> property in the uploaded <code>video</code> resource specified an invalid scheduled publishing time.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidRecordingDetails</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>recordingDetails</code> object in the uploaded <code>video</code> resource specified invalid recording details.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidTags</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>snippet.tags</code> property in the uploaded <code>video</code> resource specified an invalid value.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidTitle</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the <code>snippet.title</code> property in the uploaded <code>video</code> resource specified an invalid or empty video title.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidVideoMetadata</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the request metadata is invalid. This error occurs if the request updates the <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet">snippet</a></code> part of a <code>video</code> resource but does not set a value for both the <code>snippet.title</code> and <code>snippet.categoryId</code> properties.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>December 18, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-12-18</id>
    <updated>2015-12-18T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>European Union (EU) laws require that certain disclosures must be given to and consents obtained from end users in the EU.  Therefore, for end users in the European Union, you must comply with the <a href="http://www.google.com/about/company/user-consent-policy.html">EU User Consent Policy</a>. We have added a notice of this requirement in our <a href="https://developers.google.com/youtube/terms#notices-to-users">YouTube API Terms of Service</a>.</p>
]]>
    </content>
  </entry>
  <entry>
    <title>November 19, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-11-19</id>
    <updated>2015-11-19T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[

<p>The API now supports the ability to set and retrieve localized text for the <code>snippet.title</code> and <code>snippet.description</code> properties of the <code><a href="https://developers.google.com/youtube/v3/docs/playlists#snippet.localized">playlist</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.localized">video</a></code> resources, the <code>snippet.title</code> property of the <code><a href="https://developers.google.com/youtube/v3/docs/channelSections#snippet.localized">channelSection</a></code> resource, and the <code>snippet.description</code> property of the <code><a href="https://developers.google.com/youtube/v3/docs/channels#snippet.localized">channel</a></code> resource.</p>
<ul>
  <li>
    <p><b>Setting localized titles and descriptions</b></p>
    <p>You can set localized values for a resource when calling the <code>insert</code> or <code>update</code> method for that resource. To set localized values for a resource, do both of the following:</p>
    <ul>
      <li>
        <p>Ensure that a value is set for the resource's <code>snippet.defaultLanguage</code> property. That property identifies the language of the resource's <code>snippet.title</code> and <code>snippet.description</code> properties. Its value can be any <a href="https://developers.google.com/youtube/v3/docs/i18nLanguages/list">supported application language</a> or most other ISO 639-1:2002 language codes. For example, if you upload a video that has an English title and description, you would set the <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.defaultLanguage">snippet.defaultLanguage</a></code> property to <code>en</code>.</p>
        <p><b>Note for updating <code>channel</code> resources:</b> To set the <code>snippet.defaultLanguage</code> property for a <code>channel</code> resource, you actually need to update the <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.channel.defaultLanguage">brandingSettings.channel.defaultLanguage</a></code> property.</p>
      </li>
      <li>
        <p>Add the <code>localizations</code> object to the resource you are updating. Each object key is a string that identifies an application language or ISO 639-1:2002 language code, and each key maps to an object that contains the localized title (and description) for the resource.</p>
        <p>The sample snippet below sets the resource's default language to English. It also adds localized German and Spanish titles and descriptions to a video:</p>
        <pre>
{
  "kind": "youtube#video",
  ...
  "snippet": {
    "title": "Playing soccer",
    "description": "We play soccer in the park on Sundays.",
    "defaultLanguage": "en",
    ...
  },
  "localizations":
    "de": {
      "title": "Fußball spielen",
      "description": "Wir spielen Fußball im Park am Sonntag"
    },
    "es": {
      "title": "Jugar al fútbol",
      "description": "Nosotros jugamos fútbol en el parque los domingos",
    }
  }
}</pre>
      </li>
      <p class="special"><b>Important:</b> Remember that when you update the localized data for a resource, your API request must include all of the existing localized versions of the data. For example, if you sent a subsequent request to add Portuguese data to the video in the example above, the request would need to include the localized data for German, Spanish, and Portuguese.</p>
    </ul>
  </li>
  <li>
    <p><b>Retrieving localized values</b></p>
    <p>The API supports two ways to retrieve localized values for a resource:</p>
    <ul>
      <li>
        <p>Add the <code>hl</code> parameter to your <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#hl">channels.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/list#hl">channelSections.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list#hl">playlists.list</a></code>, or <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#hl">videos.list</a></code> request to retrieve localized data for a specific <a href="https://developers.google.com/youtube/v3/docs/i18nLanguages">application language that the YouTube website supports</a>. If localized resource details are available in that language, the resource's <code>snippet.localized</code> object will contain the localized values. However, if localized details are not available, the <code>snippet.localized</code> object will contain resource details in the resource's <a href="https://developers.google.com/youtube/v3/docs/videos#snippet.defaultLanguage">default language</a></code>.</p>
        <p>For example, suppose a <code>videos.list</code> request retrieved data for the video described above with localized German and Spanish data. If the <code>hl</code> parameter were set to <code>de</code>, the resource would contain the following data:</p>
        <pre>
{
  "kind": "youtube#video",
  ...
  "snippet": {
    "title": "Playing soccer",
    "description": "We play soccer in the park on Sundays.",
    "defaultLanguage": "en",
    "localized": {
      "title": "Fußball spielen",
      "description": "Wir spielen Fußball im Park am Sonntag"
    }
    ...
  }
}</pre>
        <p>However, if the <code>hl</code> parameter were set to <code>fr</code>, the <code>snippet.localized</code> object would contain the English title and description because English is the default language for the resource, and localized French details are not available.</p>
        <div class="special"><b>Important:</b> The <code>hl</code> parameter only supports values that identify application languages that the YouTube website supports. To determine whether localized text is available for other languages, you need to retrieve the <code>localizations</code> part for the resource and filter to determine whether the localized text exists.<br><br>For example, you would need to retrieve the full list of localizations to determine whether localized text is available in Appalachian English.</div><br>
      </li>
      <li>
        <p>When retrieving a resource, include <code>localizations</code> in the <code>part</code> parameter value to retrieve all of the localized details for that resource. If you are retrieving localized data for a language that is not a <a href="https://developers.google.com/youtube/v3/docs/i18Languages/list">current YouTube application language</a>, you need to use this approach to retrieve all localizations and then filter to determine whether the desired localized data exists.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><b>Errors related to localized text values</b></p>

    <p>The API also supports the following new errors for localized text values:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>defaultLanguageNotSetError</code></td>
          <td class="error-cause">This error indicates that a request that tries to insert or update the <code>localizations</code> object for a resource is failing because the <code>snippet.defaultLanguage</code> property is not set for that resource. The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert">playlists.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods support this error.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>localizationValidationError</code></td>
          <td class="error-cause">This error indicates that one of the values in a resource's <code>localizations</code> object failed to validate. For example, this error might occur if the object contains an invalid language code. The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert">playlists.insert</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code> methods support this error.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>November 4, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-11-04</id>
    <updated>2015-11-04T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#order">order</a></code> parameter has been updated to note that if you sort live broadcasts by <code>viewCount</code>, the API results are sorted by the broadcasts' number of concurrent viewers while the broadcasts are still ongoing.</p>
      </li>
      <li>
        <p>The <code>search.list</code> method's <code><a href="https://developers.google.com/youtube/v3/docs/search/list#relatedToVideoId">relatedToVideoId</a></code> parameter has been updated to note that if the parameter is set, the only other supported parameters are <code><a href="https://developers.google.com/youtube/v3/docs/search/list#part">part</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#maxResults">maxResults</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#pageToken">pageToken</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#regionCode">regionCode</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#relevanceLanguage">relevanceLanguage</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#safeSearch">safeSearch</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list#type">type</a></code> (which must be set to <code>video</code>), and <code><a href="https://developers.google.com/youtube/v3/docs/search/list#fields">fields</a></code>. This update does not reflect a change in API behavior.</td>
      </li>
      <li>
        <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.publishedAt">snippet.publishedAt</a></code> property has been updated to note that the property value, which specifies the date and time that the video was published, might be different than the time that the video was uploaded. For example, if a video is uploaded as a private video and then made public at a later time, the property value specifies the time that the video was made public. The updated definition also explains how the value is populated for private and unlisted videos.</p>
        <p>This change does not reflect a change in API behavior.</p>
      </li>
      <li>
        <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.publishAt">status.publishAt</a></code> property has been updated to note:<ul><li>If you set this property's value when calling the <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method, you must also set the <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.privacyStatus">status.privacyStatus</a></code> property value to <code>private</code> even if the video is already private.</li><li>If the request schedules a video to be published at some time in the past, it is published right away. As such, the effect of setting the <code>status.publishAt</code> property to a past date and time is the same as of changing the video's <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.privacyStatus">privacyStatus</a></code> from <code>private</code> to <code>public</code>.</li></ul></td>
      <li>
        <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cncRating">contentDetails.contentRating.cncRating</a></code> property specifies the video's rating from France's Commission de classification cinematographique. This property replaces the <code>contentDetails.contentRating.fmocRating</code> property, which is now deprecated.</p>
      </li>
      <li>
        <p>The definition of the <code>channel</code> resource's <a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.channel.keywords">brandingSettings.channel.keywords</a></code> has been updated to correctly reflect that the property value contains a space-separated list of strings and not a comma-separated list, as previously documented. This update does not reflect a change in API behavior.</p>
      </li>
      <li>
        <p>The documentation for the <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#request-body">thumbnails.set</a></code> method has been updated to accurately reflect that the body of the request contains the thumbnail image that you are uploading and associating with a video. The request body does not contain a <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails#resource-representation">thumbnail</a></code> resource. Previously, the documentation said that you should not provide a request body when calling this method. This update does not reflect a change in API behavior.</p>
      </li>
      <li>
        <p>The description of the <code><a href="https://developers.google.com/youtube/v3/docs/activities">activity</a></code> resource has been updated to reflect the fact that the <code>activities.list</code> method does not currently include resources related to new video comments. The resource's <code><a href="https://developers.google.com/youtube/v3/docs/activities#snippet.type">snippet.type</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/activities#contentDetails.comment">contentDetails.comment</a></code> have been updated as well.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><strong>New and updated errors</strong></p>
    <ul>
      <li>
        <p>The API now supports the following errors:</p>
        <table class="responsive errors">
          <thead>
            <tr>
              <th colspan="2">Error details</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/activities/insert">activities.insert</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>invalidMetadata</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The <code>kind</code> property does not match the type of ID provided.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code>commentThreads.update</code></nobr><br><nobr><code><a href="https://developers.google.com/youtube/v3/docs/comments/insert">comments.insert</a></code></nobr><br><nobr><code><a href="https://developers.google.com/youtube/v3/docs/comments/update">comments.update</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>commentTextTooLong</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The <code>comment</code> resource that is being inserted or updated contains too many characters in the <code>snippet.topLevelComment.snippet.textOriginal</code> property.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code></nobr><br><nobr><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update">playlistItems.update</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>forbidden (403)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>playlistItemsNotAccessible</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The request is not properly authorized to insert, update, or delete the specified playlist item.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/playlists/delete">playlists.delete</a></code></nobr><br><nobr><code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert">playlists.insert</a></code></nobr><br><nobr><code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>playlistForbidden</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>This operation is forbidden or the request is not properly authorized.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>invalidLocation</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The <code>location</code> and/or <code>locationRadius</code> parameter value was formatted incorrectly.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>invalidRelevanceLanguage</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The <code>relevanceLanguage</code> parameter value was formatted incorrectly.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert">subscriptions.insert</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>subscriptionForbidden</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>This error occurs when any of the following are true:<ul><li>The subscription that you are trying to create already exists</li><li>You have already reached your maximum number of subscriptions</li><li>You are trying to subscribe to your own channel, which is not supported.</li><li>You have created too many subscriptions recently and need to wait a few hours before retrying the request.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>invalidDefaultBroadcastPrivacySetting</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The request attempts to set an invalid privacy setting for the default broadcast.</td>
                  </tr>
                </table>
              </td>
            </tr>
          </tbody>
        </table>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 28, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-08-28</id>
    <updated>2015-08-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#statistics.favoriteCount">statistics.favoriteCount</a></code> property has been deprecated.</p>
        <p>In accordance with our deprecation policy, this property will continue to be included in <code>video</code> resources for at least one year after this announcement. However, the property value is now always set to <code>0</code>.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 7, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-08-07</id>
    <updated>2015-08-07T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.tags[]">snippet.tags[]</a></code> property has been updated to provide more information about how the API server calculates the length of the property's value. Note that this update does not reflect a change in the API's behavior.</p>
        <p>Specifically, the definition now explains that if a tag contains a space, the API server handles the tag value as though it were wrapped in quotation marks, and the quotation marks count toward the character limit. So, for the purposes of character limits, the tag Foo-Baz contains seven characters, but the tag Foo Baz contains nine characters.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/insert">commentThreads.insert</a></code> method no longer supports the <code>shareOnGooglePlus</code> parameter, which previously indicated whether a comment and replies to that comment should also be posted to the author's Google+ profile. If a request submits the parameter, the API server ignores the parameter but otherwise handles the request.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 18, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-06-18</id>
    <updated>2015-06-18T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The <code>commentThreads.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list#order">order</a></code> parameter specifies the order in which the API response should list comment threads. Threads can be ordered by time or relevance. The default behavior is to order them by time.</p>
      </li>
      <li>
        <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.defaultAudioLanguage">snippet.defaultAudioLanguage</a></code> property specifies the language spoken in the video's default audio track.</p>
      </li>
      <li>
        <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.licensedContent">contentDetails.licensedContent</a></code> property has been updated to clarify that the content must have been originally uploaded to a channel linked to a YouTube content partner and then claimed by that partner. This does not represent a change in actual API behavior.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/captions/delete#params">captions.delete</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/captions/download#params">captions.download</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/captions/insert#params">captions.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/captions/list#params">captions.list</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/captions/update#params">captions.update</a></code> methods now support the <code>onBehalfOfContentOwner</code> parameter, which is already supported for several other methods. Requests that use that method also need to be authorized with a token that provides access to the <code>https://www.googleapis.com/auth/youtubepartner</code> scope.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><strong>New and updated errors</strong></p>
    <ul>
      <li>
        <p>The API now supports the following errors:</p>
        <table class="responsive errors">
          <thead>
            <tr>
              <th colspan="2">Error details</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>emailNotVerified</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>The user must verify her email address prior to rating the video.</td>
                  </tr>
                </table>
              </td>
            </tr>
            <tr>
              <td><nobr><code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code></nobr></td>
              <td>
                <table>
                  <tr>
                    <td>HTTP Response Code</td><td><code>badRequest (400)</code></td>
                  </tr>
                  <tr>
                    <td>Reason</td><td><code>videoPurchaseRequired</code></td>
                  </tr>
                  <tr>
                    <td>Description</td><td>Rental videos can only be rated by users who rented them.</td>
                  </tr>
                </table>
              </td>
            </tr>
          </tbody>
        </table>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/delete#errors">subscriptions.delete</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert#errors">subscriptions.insert</a></code> methods no longer support the <code>accountClosed</code> and <code>accountSuspended</code> errors.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 27, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-04-27</id>
    <updated>2015-04-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p><strong>New resources and methods</strong></p>
    <ul>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons">videoAbuseReportReason</a></code> resource contains information about a reason that a video would be flagged for containing abusive content. The <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons/list">videoAbuseReportReasons.list</a></code> method lets you retrieve a list of all of the reasons why videos might be flagged.</p>
      </li>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos/reportAbuse">videos.reportAbuse</a></code> method provides a way to actually flag a video that contains abusive content. The body of the request contains a JSON object that specifies the video being flagged as well as the reason that the video is deemed to contain abusive content. Valid reasons can be obtained from the <code><a href="https://developers.google.com/youtube/v3/docs/videoAbuseReportReasons/list">videoAbuseReportReason.list</a></code> method described above.</p>
        <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#videos">migration guide</a> has also been updated with an example for reporting an abusive video. With this change, the v3 API now supports all of the v2 API features that it is scheduled to support. These features are also all explained in the migration guide.</p>
      </li>
    </ul>
  </li>
  <li>
    <p><strong>Updates to existing resources and methods</strong></p>
    <ul>
      <li>
        <p>The <code>search.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/search/list#forDeveloper">forDeveloper</a></code> filter parameter restricts a search to only retrieve videos uploaded via the developer's application or website. The <code>forDeveloper</code> parameter can be used in conjunction with optional search parameters like the <code>q</code> parameter.</p>
        <p>For this feature, each uploaded video is automatically tagged with the project number that is associated with the developer's application in the <a href="https://console.developers.google.com">Google Developers Console</a>.</p>
        <p>When a search request subsequently sets the <code>forDeveloper</code> parameter to <code>true</code>, the API server uses the request's authorization credentials to identify the developer. Therefore, a developer can restrict results to videos uploaded through the developer's own app or website but not to videos uploaded through other apps or sites.</p>
        <p>The new feature offers functionality that is similar, albeit not identical, to the <a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_uploading_videos#Assigning_Developer_Tags">developer tags</a> functionality that the v2 API supported.</p>
      </li>
      <li>
        <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#snippet.country">snippet.country</a></code> property lets channel owners associate their channels with a particular country.</p>
        <p><b>Note:</b> To set the <code>snippet.country</code> property for a <code>channel</code> resource, you actually need to update the <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.channel.country">brandingSettings.channel.country</a></code> property.</p>
      </li>
      <li>
        <p>The API now supports targeting for <code><a href="https://developers.google.com/youtube/v3/docs/channelSections">channelSection</a></code> resources. Channel section targeting provides a way to restrict visibility of a content section to users that match particular criteria.</p>
        <p>The API exposes three targeting options. A user must meet all of the targeting settings for a channel section to be visible.</p>
        <ul>
          <li>
            <p><code><a href="https://developers.google.com/youtube/v3/docs/channelSections#targeting.languages[]">targeting.languages[]</a></code>: A list of <a href="https://developers.google.com/youtube/v3/docs/i18nLanguages">YouTube application languages</a>. Users who have chosen one of those languages can see the corresponding channel section.</p>
          </li>
          <li>
            <p><code><a href="https://developers.google.com/youtube/v3/docs/channelSections#targeting.regions[]">targeting.regions[]</a></code>: A list of <a href="https://developers.google.com/youtube/v3/docs/i18nRegions">YouTube preferred content regions</a>. The channel section is visible to users that have selected one of those regions as well as users for whom one of those regions is automatically selected.</p>
          </li>
          <li>
            <p><code><a href="https://developers.google.com/youtube/v3/docs/channelSections#targeting.countries[]">targeting.countries[]</a></code>: A list of countries where the channel section is visible. Each value in the list is an <a href="http://www.iso.org/iso/country_codes/iso_3166_code_lists/country_names_and_code_elements.htm">ISO 3166-1 alpha-2 country code</a>.</p>
          </li>
        </ul>
      </li>
      <li>
        <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.duration">contentDetails.duration</a></code> property has been corrected to reflect that the value can reflect hours, days, and so forth.</p>
      </li>
      <li>
        <p>The documentation for the <code>channelSections.delete</code>, <code>playlistItems.delete</code>, <code>playlists.delete</code>, <code>subscriptions.delete</code>, and <code>videos.delete</code> method has been corrected to reflect that, when successful, those methods all return an HTTP <code>204</code> response code (<code>No Content</code>).</p>
      </li>
    </ul>
  </li>
  <li>
    <p><strong>New and updated errors</strong></p>
    <ul>
      <li>
        <p>The API now supports the following errors:</p>
        <table class="matchpre" id="property-table">
          <thead>
            <tr>
              <th>Error type</th>
              <th>Error detail</th>
              <th>Description</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>targetInvalidCountry</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code> methods return this error if the inserted <code>channelSection</code> resource contained an invalid value for the <code>targeting.countries[]</code> property.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>targetInvalidLanguage</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code> methods return this error if the inserted <code>channelSection</code> resource contained an invalid value for the <code>targeting.languages[]</code> property.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>targetInvalidRegion</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">channelSections.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update">channelSections.update</a></code> methods return this error if the inserted <code>channelSection</code> resource contained an invalid value for the <code>targeting.regions[]</code> property.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>operationNotSupported</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/comments/insert">comments.insert</a></code> method returns this error if the API user is not able to insert a comment in reply to the top-level comment identified by the <code>snippet.parentId</code> property. In a <code>commentThread</code> resource, the <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads#snippet.canReply">snippet.canReply</a></code> property indicates whether the current viewer can reply to the thread.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>invalidChannelId</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method returns this error if the <code>channelId</code> parameter in the request specified an invalid channel ID.</td>
            </tr>
            <tr>
              <td class="error-name"><code>badRequest (400)</code></td>
              <td class="error-reason"><code>subscriptionForbidden</code></td>
              <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert">subscriptions.insert</a></code> method returns this error if the API user tries to subscribe to the user's own channel.</td>
            </tr>
          </tbody>
        </table>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/captions/update#errors">captions.update</a></code> method no longer supports the <code>invalidMetadata</code> and <code>videoNotFound</code> errors.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 16, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-04-16</id>
    <updated>2015-04-16T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#comments">migration guide</a> has been updated to explain how to migrate applications still using comments functionality from the v2 API.</p>
    <p>The guide also calls out several commenting features that the v2 API did not support but that are <a href="https://developers.google.com/youtube/v3/migration-guide#new-in-v3">supported in the v3 API</a>. These include:</p>
    <p><ul>
      <li>Retrieving comments about a channel</li>
      <li>Retrieving all comment threads related to a channel, which means that the API response can contain comments about the channel or any of its videos.</li>
      <li>Updating the text of a comment</li>
      <li>Marking a comment as spam</li>
      <li>Setting a comment's moderation status</li>
    </ul></p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/guides/push_notifications">Subscribing to push notifications</a> guide has been updated to reflect the fact that notifications are only pushed to the Google PubSubHubBub hub and not also to the Superfeedr hub as previously indicated.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 9, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-04-09</id>
    <updated>2015-04-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API's new <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads">commentThread</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/comments">comment</a></code> resources let you retrieve, insert, update, delete, and moderate comments.</p>
    <ul>
      <li>
        <p>A <code>commentThread</code> resource contains information about a YouTube comment thread, which comprises a top-level comment and replies, if any exist, to that comment. A <code>commentThread</code> resource can represent comments about either a video or a channel.</p>
        <p>The top-level comment and the replies are actually <code>comment</code> resources that are nested inside the <code>commentThread</code> resource. It is important to note that the <code>commentThread</code> resource does not necessarily contain all replies to a comment, and you need to use the <code><a href="https://developers.google.com/youtube/v3/docs/comments/list">comments.list</a></code> method if you want to retrieve all replies for a particular comment. In addition, some comments do not have replies.</p>
        <p>The API supports the following methods for <code>commentThread</code> resources:</p>
        <p><ul>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/list">commentThreads.list</a></code> &ndash; Retrieve a list of comment threads. Use this method to retrieve comments associated with a particular video or channel.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/insert">commentThreads.insert</a></code> &ndash; Create a new top-level comment. (Use the <code><a href="https://developers.google.com/youtube/v3/docs/comments/insert">comments.insert</a></code> method to reply to an existing comment.)</li>
          <li><code>commentThreads.update</code> &ndash; Modify a top-level comment.</li>
        </ul></p>
      </li>
      <li>
        <p>A <code>comment</code> resource contains information about a single YouTube comment. A <code>comment</code> resource can represent a comment about either a video or a channel. In addition, the comment could be a top-level comment or a reply to a top-level comment.</p>
        <p>The API supports the following methods for <code>comment</code> resources:</p>
        <p><ul>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/list">comments.list</a></code> &ndash; Retrieve a list of comment. Use this method to retrieve all of the replies to a particular comment.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/insert">comments.insert</a></code> &ndash; Create a reply to an existing comment.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/update">comments.update</a></code> &ndash; Modify a comment.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/markAsSpam">comments.markAsSpam</a></code> &ndash; Flag one or more comments as spam.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/setModerationStatus">comments.setModerationStatus</a></code> &ndash; Set the moderation status of one or more comments. For example, clear a comment for public display or reject a comment as unfit for display. The API request must be authorized by the owner of the channel or video associated with the comments..</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/comments/delete">comments.delete</a></code> &ndash; Delete a comment.</li>
        </ul></p>
      </li>
    </ul>
    <p>Note that the API's new <code>https://www.googleapis.com/auth/youtube.force-ssl</code> scope, described in the <a href="#release_notes_04_02_2015">revision history for April 2, 2015</a>, is required for calls to the <code><a href="https://developers.google.com/youtube/v3/docs/comments/insert">comments.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/comments/update">comments.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/comments/markAsSpam">comments.markAsSpam</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/comments/setModerationStatus">comments.setModerationStatus</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/comments/delete">comments.delete</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/commentThreads/insert">commentThreads.insert</a></code>, and <code>commentThreads.update</code> methods.
  </li>
  <li>
    <p>The API's new <code>https://www.googleapis.com/auth/youtube.force-ssl</code> scope is now a valid scope for any API method that previously supported the <code>https://www.googleapis.com/auth/youtube</code> scope.</p>
  </li>
  <li>
    <p>The API now supports the following errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidRating</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> method returns this error if the request contained an unexpected value for the <code>rating</code> parameter.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>The <code>subscriptions.insert</code> method no longer supports the <code>subscriptionLimitExceeded</code> error, which previously indicated that the subscriber identified with the request had exceeded the subscription rate limit.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 9, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-04-09</id>
    <updated>2015-04-09T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <a href="https://developers.google.com/youtube/v3/guides/push_notifications">Subscribing to push notifications</a> guide explains the API's new support for push notifications via <a href="https://github.com/pubsubhubbub/">PubSubHubBub</a>, a server-to-server publish/subscribe protocol for Web-accessible resources. Your PubSubHubBub callback server can receive Atom feed notifications when a channel does any of the following activities:</p>
    <p><ul>
      <li>uploads a video</li>
      <li>updates a video's title</li>
      <li>updates a video's description</li>
    </ul></p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#deprecated">migration guide</a> has also been updated to note this new support. However, since the v2 API supported numerous other types of push notifications that are not supported in the v3 API, the mention of PubSubHubBub support is still listed in the <b>Deprecated</b> section of that guide.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 2, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-04-02</id>
    <updated>2015-04-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/captions">captions</a></code> resource represents a YouTube caption track. A caption track is associated with exactly one YouTube video.</p>
    <p>The API supports methods to <a href="https://developers.google.com/youtube/v3/docs/captions/list">list</a>, <a href="https://developers.google.com/youtube/v3/docs/captions/insert">insert</a>, <a href="https://developers.google.com/youtube/v3/docs/captions/update">update</a>, <a href="https://developers.google.com/youtube/v3/docs/captions/download">download</a>, and <a href="https://developers.google.com/youtube/v3/docs/captions/delete">delete</a> caption tracks.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide">migration guide</a> has also been updated to explain how to migrate applications still using captions functionality in the v2 API.</p>
  </li>
  <li>
    <p>The API's new <code>https://www.googleapis.com/auth/youtube.force-ssl</code> scope requires communication with the API server to happen over an SSL connection.</p>
    <p>This new scope grants the same access as the <code>https://www.googleapis.com/auth/youtube</code> scope. And, in fact, those two scopes are functionally identical because the YouTube API server is only available via an HTTPS endpoint. As a result, even though the <code>https://www.googleapis.com/auth/youtube</code> scope does not require an SSL connection, there is actually no other way to make an API request.</p>
    <p>The new scope is required for calls to the all of the <code>caption</code> resource's methods.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 11, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-03-11</id>
    <updated>2015-03-11T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#new-in-v3">YouTube Data API (v3) migration guide</a> contains a new tab, named <b>New in the v3 API</b>, that lists features that the v3 API does support and that the v2 API did not support. The same features were previously and are still listed in other tabs in the guide. For example, the new feature explaining how to update a channel's in-video promotional campaign data is also listed under the <b>Channels (profiles)</b> tab.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide">YouTube Data API (v3) migration guide</a> has been updated to note that the v3 API will support the following v2 API feature:</p>
    <ul>
      <li><p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_complaints">Flagging a video</a></p></li>
    </ul>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide">YouTube Data API (v3) migration guide</a> has been updated to note that the following v2 API features will not be supported in the v3 API:</p>
    <ul>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_recommendations">Retrieve video recommendations</a> &ndash; The v3 API does not retrieve a list that only contains videos recommended for the current API user. However, you can use the v3 API to find recommended videos by calling the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code> method and setting the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#home">home</a></code> parameter value to <code>true</code>.</p>
        <p>In the API response, a resource corresponds to a recommended video if the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#snippet.type">snippet.type</a></code> property's value is <code>recommendation</code>. In that case, the <code><a href="https://developers.google.com/youtube/v3/docs/activities#contentDetails.recommendation.reason">contentDetails.recommendation.reason</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/activities#contentDetails.recommendation.seedResourceId">contentDetails.recommendation.seedResourceId</a></code> properties will contain information about why the video was recommended. Note that there is no guarantee that the response will contain any particular number of recommended videos.</p>
      </li>
      <li><p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_channel_suggestions">Retrieve channel suggestions</a></p></li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_subscriptions#Retrieving_new_subscription_videos">Retrieve new subscription videos</a> &ndash; The v3 API does not retrieve a list that only contains videos that have recently been uploaded to channels that the API user subscribes to. However, you can use the v3 API to find new subscription videos by calling the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code> method and setting the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#home">home</a></code> parameter value to <code>true</code>.</p>
        <p>In the API response, a resource corresponds to a new subscription video if the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#snippet.type">snippet.type</a></code> property's value is <code>upload</code>. Note that there is no guarantee that the response will contain any particular number of new subscription videos.</p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_api_query_parameters#altsp">RSS feed support</a></p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_sup">Push notifications for feed updates</a> &ndash; The v2 API supported push notifications, using either the Simple Update Protocol (SUP) or <a href="http://youtube-eng.blogspot.ch/2010/10/pubsubhubbub-for-youtube-activities_7.html">PubSubHubbub</a>, to monitor user activity feeds for YouTube users. Notifications were provided for new channel subscriptions and when videos were rated, shared, marked as favorites, commented on, or uploaded.</p>
        <p>The v3 API will support push notifications using the <a href="https://github.com/pubsubhubbub/">PubSubHubbub protocol</a>, but the notifications will only cover video uploads and updates to video titles or video descriptions.</p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/reference#youtube_data_api_tag_yt:location">Channel location</a> &ndash; The v2 API used the <code>&lt;yt:location&gt;</code> tag to identify the user's location as entered in the channel's YouTube public profile. While some developers used this field to associate a channel with a particular country, the field's data could not consistently be used for that purpose.</p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_uploading_videos#Assigning_Developer_Tags">Set or retrieve developer tags</a> &ndash; The v2 API supported the ability to associate keywords, or developer tags, with a video at the time that the video was uploaded. Developer tags would not be displayed to YouTube users, but video owners could retrieve videos that matched a specific developer tag.</p>
        <p>The v3 API will provide a similar, but not identical, feature. Specifically, a developer will be able to search for videos uploaded by the developer's own application. For this feature, each uploaded video is automatically tagged with the project number that is associated with the developer's application in the <a href="https://console.developers.google.com">Google Developers Console</a>. The developer then uses the same project number to search for videos.</p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_api_query_parameters#orderbysp">List videos by publication date, viewcount, or rating</a> &ndash; In the v2 API, the <code>orderby</code> parameter let you sort videos in a playlist by position, duration, publication date, title, and several other values. In the v3 API, playlist items are typically sorted by position in ascending order and other sorting options are not available.</p>
        <p>There are a few exceptions. A new upload, favorite video, liked video, or recently watched video is automatically added as the first item (<code>snippet.position</code>=<code>0</code>) for the following types of playlists. So, each of these lists is effectively sorted in order of newest to oldest item based on the times that items were added to the list.</p>
        <p><ul>
          <li>user uploads</li>
          <li>favorite videos</li>
          <li>liked videos</li>
          <li>watch history</li>
        </ul></p>
        <p>Note, however, that a new item added to the "Watch later" playlist is added as the last item in that list, so that list is effectively sorted from oldest to newest item.</p>
      </li>
      <li>
        <p><a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_batch_processing">Batch processing</a> &ndash; The v3 API supports one of the batch processing use cases that the v2 API had supported. The v3 API's <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#id">channels.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/list#id">channelSections.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/guideCategories/list#id">guideCategories.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#id">playlistItems.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list#id">playlists.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#id">subscriptions.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list#id">videoCategories.list</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#id">videos.list</a></code> methods all support an <code>id</code> parameter, which can be used to specify a comma-delimited list of IDs (video IDs, channel IDs, etc.). Using those methods, you can retrieve a list of multiple resources with a single request.</p>
      </li>
    </ul>
    <p>With these changes, the guide now identifies all functionality that was supported in the old (v2) API that will be deprecated in the current API version (v3).</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 4, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-03-04</id>
    <updated>2015-03-04T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/delete#params">channelSections.delete</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/channelSections/update#params">channelSections.update</a></code> methods now support the <code>onBehalfOfContentOwner</code> parameter, which is already supported for several other methods.</p>
  </li>
  <li>
    <p>The following properties and their child properties have been deprecated:</p>
    <p><ul>
      <li><code>brandingSettings.image.backgroundImageUrl</code></li>
      <li><code>brandingSettings.image.largeBrandedBannerImageImapScript</code></li>
      <li><code>brandingSettings.image.largeBrandedBannerImageUrl</code></li>
      <li><code>brandingSettings.image.smallBrandedBannerImageImapScript</code></li>
      <li><code>brandingSettings.image.smallBrandedBannerImageUrl</code></li>
    </ul></p>
    <p class="special"><b>Note:</b> None of these properties had been subject to the API Deprecation Policy.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.djctqRatingReasons">contentDetails.contentRating.contentDetails.contentRating.djctqRatingReasons</a></code> property identifies the reasons that explain why the video received its DJCQT (Brazil) rating.</td>
  </li>
  <li>
    <p>The API now supports the following errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>notFound (404)</code></td>
          <td class="error-reason"><code>channelNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the request's <code>id</code> parameter specifies a channel that cannot be found.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>manualSortRequiredinvalidValue</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update">playlistItems.update</a></code> methods return this error if the request attempts to set the playlist item's position, but the playlist does not use manual sorting. For example, playlist items might be sorted by date or popularity. You can address this error by removing the <code>snippet.position</code> element from the resource sent in the request body. If you want the playlist item to have a specific position in the list, you need to first update the playlist's ordering setting to <strong>Manual</strong>. THis setting can be adjusted in the <a href="https://www.youtube.com/view_all_playlists">YouTube Video Manager</a>.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>channelClosed</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code> method returns this error if the request's <code>channelId</code> parameter specifies a channel that has been closed.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>channelSuspended</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code> method returns this error if the request's <code>channelId</code> parameter specifies a channel that has been suspended.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>playlistForbidden</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code> method returns this error if the request's <code>id</code> parameter does not support the request or the request is not properly authorized.</td>
        </tr>
        <tr>
          <td class="error-name"><code>notFound (404)</code></td>
          <td class="error-reason"><code>channelNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code> method returns this error if the request's <code>channelId</code> parameter specifies a channel that cannot be found.</td>
        </tr>
        <tr>
          <td class="error-name"><code>notFound (404)</code></td>
          <td class="error-reason"><code>playlistNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list">playlists.list</a></code> method returns this error if the request's <code>id</code> parameter specifies a playlist that cannot be found.</td>
        </tr>
        <tr>
          <td class="error-name"><code>notFound (404)</code></td>
          <td class="error-reason"><code>videoNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code> method returns this error if the request's <code>id</code> parameter specifies a video that cannot be found.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidRating</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> method returns this error if the request contains an unexpected value for the <code>rating</code> parameter.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 2, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-03-02</id>
    <updated>2015-03-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>search.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#relevanceLanguage">relevanceLanguage</a></code> parameter, which lets you request results that are most relevant to a particular language.</p>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#search-relevance-language">YouTube Data API (v3) migration guide</a> has also been updated to explain how to use this new parameter. The parameter addresses a feature gap that previously existed between the current API version (v3) and the previous version (v2), which has already been deprecated.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#deprecated">YouTube Data API (v3) migration guide</a> has also been updated to indicate the deprecation of the <a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_movies_and_shows">special feeds and metadata fields</a> that the v2 API provided for describing movies, trailers, television shows, television seasons, and television episodes.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>January 14, 2015</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2015-01-14</id>
    <updated>2015-01-14T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/migration-guide#videos">YouTube Data API (v3) migration guide</a> has been updated to explain how to use the v3 API to upload videos using JavaScript. (See the <b>Upload a video</b> section for details.) This functionality is comparable to the <a href="https://developers.google.com/youtube/2.0/developers_guide_protocol_browser_based_uploading">browser-based uploading</a> functionality that the v2 API supports. Note that this change to the migration guide does not reflect an actual API change but rather the availability of new sample code for uploading videos with client-side JavaScript.</p>
    <p>Given the support for uploading videos with the JavaScript client library and CORS, the migration guide no longer lists browser-based uploading as a feature that may be deprecated in the v3 API.</p>
  </li>
  <li>
    <p>The documentation for the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#examples">videos.insert</a></code> method has been updated to include the new JavaScript code sample described above. The list of <a href="https://developers.google.com/youtube/v3/code_samples/javascript#upload_video">JavaScript code samples</a> for the YouTube Data API (v3) has also been updated.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>November 11, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-11-11</id>
    <updated>2014-11-11T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The quota cost for a call to the <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method has changed to 100 units.</p>
    <p><b>Important:</b> In many cases, you can use other API methods to retrieve information at a lower quota cost. For example, consider these two ways of finding videos uploaded to the <b>GoogleDevelopers</b> channel.</p>
    <ul>
      <li>
        <p><b>Quota cost: 100 units</b></p>
        <p>Call the <code>search.list</code> method and search for <code>GoogleDevelopers</code>.</p>
      </li>
      <li>
        <p><b>Quota cost: 6 units</b></p>
        <p>Call the <code>channels.list</code> method to find the right channel ID. Set the <code>forUsername</code> parameter to <code>GoogleDevelopers</code> and the <code>part</code> parameter to <code>contentDetails</code>. In the API response, the <code>contentDetails.relatedPlaylists.uploads</code> property specifies the playlist ID for the channel's uploaded videos.</p>
        <p>Then call the <code>playlistItems.list</code> method and set the <code>playlistId</code> parameter to the captured ID and the <code>part</code> parameter to <code>snippet</code>.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 8, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-10-08</id>
    <updated>2014-10-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource contains two new properties:</p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels#status.longUploadsStatus">status.longUploadsStatus</a></code> property indicates whether the channel is eligible to upload videos that are more than 15 minutes long. This property is only returned if the channel owner authorized the API request. Valid property values are:</p>
        <p><ul>
          <li><code>allowed</code> &ndash; The channel can upload videos more than 15 minutes long.</li>
          <li><code>eligible</code> &ndash; The channel is eligible to upload videos more than 15 minutes long but must first enable the feature.</li>
          <li><code>disallowed</code> &ndash; The channel is not able or eligible to upload videos more than 15 minutes long.</li>
        </ul></p>
        <p>See the property definition for more information about these values. The <a href="https://support.google.com/youtube/answer/71673">YouTube Help Center</a> also provides more detailed information about this feature.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.useSmartTiming">invideoPromotion.useSmartTiming</a></code> property indicates whether the channel's promotional campaign uses "smart timing." This feature attempts to show promotions at a point in the video when they are more likely to be clicked and less likely to disrupt the viewing experience. This feature also picks up a single promotion to show on each video.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The definitions of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.title">snippet.title</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.categoryId">snippet.categoryId</a></code> properties have both been updated to clarify the way that API handles calls to the <code>videos.update</code> method. If you call that method to update the <code>snippet</code> part of a <code>video</code> resource, you must set a value for both of those properties.</p>
    <p>If you try to update the <code>snippet</code> part of a <code>video</code> resource and do not set a value for both of those properties, the API returns an <code><a href="https://developers.google.com/youtube/v3/docs/videos/update#errors">invalidRequest</a></code> error. That error's description has also been updated.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.oflcRating">contentDetails.contentRating.oflcRating</a></code> property, which identifies a video's rating from New Zealand's Office of Film and Literature Classification, now supports two new ratings: <code>oflcRp13</code> and <code>oflcRp16</code>. These correspond to the <code>RP13</code> and <code>RP16</code> ratings, respectively.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelBanners/insert#errors">channelBanners.insert</a></code> method now supports the following error:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>bannerAlbumFull</code></td>
          <td class="error-cause">The channel owner's YouTube Channel Art album has too many images. The channel owner should go to <a href="http://photos.google.com">http://photos.google.com</a>, navigate to the albums page, and remove some from images from that album.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>September 12, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-09-12</id>
    <updated>2014-09-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The quota cost for a call to the <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method has changed from 1 unit to 2 units in addition to the cost of the specified <a href="https://developers.google.com/youtube/v3/docs/search/list#part">resource parts</a>.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 13, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-08-13</id>
    <updated>2014-08-13T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert#errors">subscriptions.insert</a></code> method now supports the following error:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>subscriptionLimitExceeded</code></td>
          <td class="error-cause">The subscriber identified with the request has exceeded the subscription rate limit. More subscriptions can be attempted in a few hours.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 12, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-08-12</id>
    <updated>2014-08-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>A new guide, titled <a href="https://developers.google.com/youtube/v3/migration-guide">Migrating Your Application to YouTube Data API (v3)</a>, explains how to use the YouTube Data API (v3) to perform functionality available in the YouTube Data API (v2). The older API was officially deprecated as of March 4, 2014. The guide intends to help you migrate applications still using the v2 API to the most recent API version.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>July 8, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-07-08</id>
    <updated>2014-07-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#errors">playlists.insert</a></code> method now supports the following error:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>maxPlaylistExceeded</code></td>
          <td class="error-cause">This error occurs if a playlist cannot be created because the channel already has the maximum number of playlists allowed.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 18, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-06-18</id>
    <updated>2014-06-18T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The description of each API method has been updated to include the quota cost incurred by a call to that method. Similarly, the definitions of <code>part</code> parameters have been updated to specify the quota cost of each part that can be retrieved in an API call. For example, a call to the <code>subscriptions.insert</code> method has a quota cost of approximately 50 units. The <code>subscription</code> resource also contains three parts (<code>snippet</code>, <code>contentDetails</code>, and <code>subscriberSnippet</code>), and each of those has a cost of two units.</p>
    <p>Please remember that quota costs can change without warning.</p>
  </li>
  <li>
    <p>The <code>video</code> resource now supports 43 new content rating systems, which identify the ratings that videos received from various national rating agencies. The newly supported rating systems are from <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.incaaRating">Argentina</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.bmukkRating">Austria</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cicfRating">Belgium</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.nfrcRating">Bulgaria</a>, Chile (<a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.anatelRating">television</a>), Chile (<a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cccRating">film</a>), <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.czfilmRating">Czech Republic</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mocRating">Colombia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mccypRating">Denmark</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.egfilmRating">Egypt</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.eefilmRating">Estonia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mekuRating">Finland</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.csaRating">France</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.grfilmRating">Greece</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fcoRating">Hong Kong</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.smaisRating">Iceland</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.lsfRating">Indonesia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.rteRating">Ireland</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.ilfilmRating">Israel</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.agcomRating">Italy</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.kfcbRating">Kenya</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.nkclvRating">Latvia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cscfRating">Luxembourg</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fcbmRating">Malaysia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.nbcRating">Maldives</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mccaaRating">Malta</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.kijkwijzerRating">Netherlands</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.nfvcbRating">Nigeria</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.medietilsynetRating">Norway</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.pefilmRating">Peru</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mtrbcRating">Philippines</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cceRating">Portugal</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cnaRating">Romania</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mdaRating">Singapore</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.skfilmRating">Slovakia</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fpgRating">South Africa</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.smsaRating">Sweden</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.chfilmRating">Switzerland</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.moctwRating">Taiwan</a>, <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.bfvcRating">Thailand</a>, and <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.resorteviolenciaRating">Venezuela</a>.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 28, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-05-28</id>
    <updated>2014-05-28T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>search.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#location">location</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/search/list#location">locationRadius</a></code> parameters, which let you search for videos associated with a geographic location. A request must specify a value for both parameters to retrieve results based on location, and the API will return an error if a request includes only one of the two parameters.</p>
    <ul>
      <li>
        <p>The <code>location</code> parameter specifies the latitude/longitude coordinates at the center of the circular geographic area.</p>
      </li>
      <li>
        <p>The <code>locationRadius</code> parameter specifies the maximum distance that the location associated with a video can be from the center of the area for the video to still be included in search results.</p>
      </li>
    </ul>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 13, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-05-13</id>
    <updated>2014-05-13T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[]">invideoPromotion.items[]</a></code> property has been updated to note that you can typically only set one promoted item for your channel. If you try to insert too many promoted items, the API will return a <code>tooManyPromotedItems</code> error, which has an HTTP <code>400</code> status code.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelSections">channelSection</a></code> resource now can contain information about a few new types of featured content. The <code>channelSection</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channelSections#snippet.type">snippet.type</a></code> property now supports the following values:</p>
    <p><ul>
      <li><code>postedPlaylists</code> - playlists that the channel's owner posted to the channel's activity feed</li>
      <li><code>postedVideos</code> - videos that the channel's owner posted to the channel's activity feed</li>
      <li><code>subscriptions</code> - channels that the channel owner has subscribed to</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.ifcoRating">contentDetails.contentRating.ifcoRating</a></code> property identifies the rating that a video received from the Irish Film Classification Office.</p>
  </li>
  <li>
    <p>The definition of the <code>watermark</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/watermarks#position.cornerPosition">position.cornerPosition</a></code> property has been updated to note that the watermark always appear in the upper right corner of the player.</p>
  </li>
  <li>
    <p>The definition of the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#q">q</a></code> parameter for the <code>search.list</code> method has been updated to note that the query term can use the Boolean NOT (<code>-</code>) operator to exclude videos associated with a particular search term. The value can also use the Boolean OR (<code>|</code>) operator to find videos associated with one of several search terms.</p>
  </li>
  <li>
    <p>The definition of the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#pageInfo.totalResults">pageInfo.totalResults</a></code> property that is returned in an API response to a <code>search.list</code> call has been updated to note that the value is an approximation and may not represent an exact value. In addition, the maximum value is 1,000,000. You should not use this value to create pagination links. Instead, use the <code>nextPageToken</code> and <code>prevPageToken</code> property values to determine whether to show pagination links.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/watermarks/set#response">watermarks.set</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/watermarks/unset#response">watermarks.unset</a></code> methods have been updated to reflect that the API returns an HTTP <code>204</code> response code for successful requests to those methods.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 2, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-05-02</id>
    <updated>2014-05-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/i18nLanguages">i18nLanguage</a></code> resource identifies an application language that the YouTube website supports. The application language can also be referred to as a UI language. For the YouTube website, an application language could be automatically selected based on Google Account settings, browser language, or IP location, and a user could also manually select the desired UI language from the YouTube site footer.</p>
    <p>The API supports a method to <a href="https://developers.google.com/youtube/v3/docs/i18nLanguages/list">list</a> supported application languages. Supported languages can be used as the value of the <code>hl</code> parameter when calling API methods like <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/guideCategories/list">guideCategories.list</a></code>.</p>
  </li>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/i18nRegions">i18nRegion</a></code> resource identifies a geographic area that a YouTube user can select as the preferred content region. The content region can also be referred to as a content locale. For the YouTube website, a content region could be automatically selected based on heuristics like the YouTube domain or the user's IP location, and a user could also manually select the desired content region from the YouTube site footer.</p>
    <p>The API supports a method to <a href="https://developers.google.com/youtube/v3/docs/i18nLanguages/list">list</a> supported content regions. Supported region codes can be used as the value of the <code>regionCode</code> parameter when calling API methods like <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a></code>.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>April 7, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-04-07</id>
    <updated>2014-04-07T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/channelSections">channelSection</a></code> resource contains information about a set of videos that a channel has chosen to feature. For example, a section could feature a channel's latest uploads, most popular uploads, or videos from one or more playlists.</p>
    <p>The API supports methods to <a href="https://developers.google.com/youtube/v3/docs/channelSections/list">list</a>, <a href="https://developers.google.com/youtube/v3/docs/channelSections/insert">insert</a>, <a href="https://developers.google.com/youtube/v3/docs/channelSections/update">update</a>, or <a href="https://developers.google.com/youtube/v3/docs/channelSections/delete">delete</a> channel sections. You can retrieve a list of channel sections for the authenticated user's channel, by specifying a particular channel ID, or by specifying a list of unique channel section IDs.</p>
    <p>The <a href="https://developers.google.com/youtube/v3/docs/errors#channelSections">error documentation</a> has also been updated to describe the error messages that the API supports specifically for these new methods.</p>
  </li>
  <li>
    <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails">fileDetails</a></code> object has been updated to explain that that object will only be returned if the video's <code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails.fileDetailsAvailability">processingDetails.fileDetailsAvailability</a></code> property has a value of <code>available</code>.</p>
    <p>Similarly, the definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions">suggestions</a></code> object has been updated to explain that that object will only be returned if the video's <code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails.tagSuggestionsAvailability">processingDetails.tagSuggestionsAvailability</a></code> property or its <code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails.editorSuggestionsAvailability">processingDetails.editorSuggestionsAvailability</a></code> property has a value of <code>available</code>.</p>
  </li>
  <li>
    <p>The documentation for the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods has been updated to reflect that the <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.publishAt">status.publishAt</a></code> property can be set when calling those methods.</p>
  </li>
  <li>
    <p>The definition of the <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">invideoPromotion</a></code> object has been updated to explain that the object can only be retrieved by the channel's owner.</p>
  </li>
  <li>
    <p>The parameter list for the <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate#params">videos.rate</a></code> method has been updated to reflect that that method does not actually support the <code>onBehalfOfContentOwner</code> parameter. This was a documentation error as <code>videos.rate</code> requests that set this parameter return a <code>500</code> error.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 31, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-03-31</id>
    <updated>2014-03-31T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.publishAt">status.publishAt</a></code> property lets you specify the date and time when a private video is scheduled to be published. This property can only be set if the video's <a href="https://developers.google.com/youtube/v3/docs/videos#status.privacyStatus">privacy status</a> is <code>private</code> and the video has never been published. This new property is <a href="https://developers.google.com/youtube/youtube-api-list">not subject to the deprecation policy</a>.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 13, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-03-13</id>
    <updated>2014-03-13T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API now supports the <code><a href="https://developers.google.com/youtube/v3/docs/channels#contentOwnerDetails">contentOwnerDetails</a></code> part for <code>channel</code> resources. The new part contains channel data that is relevant for YouTube partners linked with the channel, including the ID of the content owner linked to the channel and the date and time when the content owner and channel were linked. Note that this new part is <a href="https://developers.google.com/youtube/youtube-api-list">not subject to the deprecation policy</a>.</p>
  </li>
  <li>
    <p>The documentation now lists the maximum supported character length for the following properties:</p>
    <table class="matchpre">
      <thead>
        <tr>
          <th>Resource</th>
          <th>Property</th>
          <th>Maximum length</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>channel</code></td>
          <td class="error-reason"><code>invideoPromotion.items[].customMessage</code></td>
          <td class="error-cause">40 characters</td>
        </tr>
        <tr>
          <td class="error-name"><code>video</code></td>
          <td class="error-reason"><code>snippet.title</code></td>
          <td class="error-cause">100 characters</td>
        </tr>
        <tr>
          <td class="error-name"><code>video</code></td>
          <td class="error-reason"><code>snippet.description</code></td>
          <td class="error-cause">5000 bytes</td>
        </tr>
        <tr>
          <td class="error-name"><code>video</code></td>
          <td class="error-reason"><code>snippet.tags</code></td>
          <td class="error-cause">500 characters. Note that the property value is a list and that commas between items in the list count toward the limit.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource's <code>brandingSettings.watch.featuredPlaylistId</code> property has been deprecated. The API will return an error if you attempt to set its value.</p>
  </li>
  <li>
    <p>The following <code>video</code> resource properties have been added to the list of values that can be set when <a href="https://developers.google.com/youtube/v3/docs/videos/insert">inserting</a> or <a href="https://developers.google.com/youtube/v3/docs/videos/update">updating</a> a video:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.locationDescription">recordingDetails.locationDescription</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.latitude">recordingDetails.location.latitude</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.longitude">recordingDetails.location.longitude</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.recordingDate">recordingDetails.recordingDate</a></code></li>
    </ul></p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a> now specifies the HTTP response code for each error type.</p>
  </li>
  <li>
    <p>The API now supports the following errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidCriteria</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method returns this error if the request specifies filter parameters that cannot be used in conjunction with each other.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>channelTitleUpdateForbidden</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if you attempt to update a channel's <code>brandingSettings</code> part and change the value of the <code>brandingSettings.channel.title</code> property. (Note that the API does not return the error if you omit the property.)</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidRecentlyUploadedBy</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.recentlyUploadedBy">invideoPromotion.items[].id.recentlyUploadedBy</a></code> property specifies an invalid channel ID.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidTimingOffset</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">invideoPromotion</a></code> part specifies an invalid timing offset.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>tooManyPromotedItems</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">invideoPromotion</a></code> part specifies more than the allowed number of promoted items.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>promotedVideoNotAllowed</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.videoId">invideoPromotion.items[].id.videoId</a></code> property specifies a video ID that either cannot be found or cannot be used as a promoted item.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden (403)</code></td>
          <td class="error-reason"><code>websiteLinkNotAllowed</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.websiteUrl">invideoPromotion.items[].id.websiteUrl</a></code> property specifies a URL that is not allowed.</td>
        </tr>
        <tr>
          <td class="error-name"><code>required (400)</code></td>
          <td class="error-reason"><code>requiredTimingType</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method returns this error if a request does not specify default timing settings for when YouTube should display a promoted item.</td>
        </tr>
        <tr>
          <td class="error-name"><code>required (400)</code></td>
          <td class="error-reason"><code>requiredTiming</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method must specify an <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].timing">invideoPromotion.items[].timing</a></code> object for each promoted item.</td>
        </tr>
        <tr>
          <td class="error-name"><code>required (400)</code></td>
          <td class="error-reason"><code>requiredWebsiteUrl</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method must specify an <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.websiteUrl">invideoPromotion.items[].id.websiteUrl</a></code> property for each promoted item.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest (400)</code></td>
          <td class="error-reason"><code>invalidPublishAt</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method returns this error if the request metadata specifies an invalid scheduled publishing time.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>March 4, 2014</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2014-03-04</id>
    <updated>2014-03-04T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The YouTube Data API, v3 is now subject to the Deprecation Policy described in the <a href="https://developers.google.com/youtube/terms">YouTube APIs Terms of Service</a>. Note that the page that lists the <a href="https://developers.google.com/youtube/youtube-api-list">APIs that are subject to the deprecation policy</a> specifically excludes some v3 API functionality from being subject to the policy.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>December 5, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-12-05</id>
    <updated>2013-12-05T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method's documentation has been updated to properly reflect that you do not need to specify a value for exactly one filter parameter when submitting a search request. Rather, you can set a value for zero filter parameters or for one filter parameter.</p>
  </li>
  <li>
    <p>The definitions for the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#params">search.list</a></code> method's parameters have been updated to note that you must set the <code>type</code> parameter's value to <code>video</code> if you also specify a value for any of the following parameters:</p>
    <p><ul>
      <li><code>eventType</code></li>
      <li><code>videoCaption</code></li>
      <li><code>videoCategoryId</code></li>
      <li><code>videoDefinition</code></li>
      <li><code>videoDimension</code></li>
      <li><code>videoDuration</code></li>
      <li><code>videoEmbeddable</code></li>
      <li><code>videoLicense</code></li>
      <li><code>videoSyndicated</code></li>
      <li><code>videoType</code></li>
    </ul></p>
  </li>
  <li>
    <p>The minimum size of uploaded channel banner images has been reduced to 2048px by 1152px. (Previously, the minimum size was 2120px by 1192px.) In addition, note that the <code>channel</code> resource documentation specifies the maximum sizes of all of the banner images served from the API. For example, the maximum size of the <code>brandingSettings.image.bannerTvImageUrl</code> image for television applications is 2120px by 1192px, but the actual image may be 2048px by 1152px. The <a href="https://support.google.com/youtube/answer/2972003">YouTube Help Center</a> provides additional guidance for optimizing channel art for display on different types of devices.</p>
  </li>
  <li>
    <p>Several <code>channel</code> resource property definitions have been updated to reflect the following information:</p>
    <p><ul>
      <li>The <code>brandingSettings.channel.description</code> property's value has a maximum length of 1000 characters.</li>
      <li>The <code>brandingSettings.channel.featuredChannelsTitle</code> property has a maximum length of 30 characters.</li>
      <li>The <code>brandingSettings.channel.featuredChannelsUrls[]</code> property can now list up to 100 channels.</li>
      <li>The <code>brandingSettings.channel.unsubscribedTrailer</code> property value, if set, must specify the YouTube video ID of a public or unlisted video that is owned by the channel owner.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method now supports updates to the <code>invideoPromotion.items[].promotedByContentOwner</code> property. That property indicates whether the content owner's name will be shown when displaying the promotion. It can only be set if the API request that sets the property value is being made on the content owner's behalf using the <code><a href="https://developers.google.com/youtube/v3/docs/channels/update#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> parameter.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#params">playlistItems.list</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert#params">playlistItems.insert</a></code> methods now support the <code>onBehalfOfContentOwner</code> parameter, which is already supported for several other methods.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.acbRating">contentDetails.contentRating.acbRating</a></code> property can now specify a rating from either the Australian Classification Board (ACB) for movies or from the Australian Communications and Media Authority (ACMA) for children's television programming.</p>
  </li>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.catvRating">contentDetails.contentRating.catvRating</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.catvfrRating">contentDetails.contentRating.catvfrRating</a></code> properties identify the ratings that a video received under the Canadian TV Classification System and the French-language R&eacute;gie du cinéma rating system, which is used in Qu&eacute;bec, respectively.</p>
  </li>
  <li>
    <p>The <code>videoCategory</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories#snippet.assignable">snippet.assignable</a></code> property indicates whether updated videos or newly uploaded videos can be associated with that video category.</p>
  </li>
  <li>
    <p>Code samples have been added for the following methods:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/activities/insert#examples">activities.insert</a></code> (Go)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/channelBanners/insert#examples">channelBanners.insert</a></code> (Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/channels/update#examples">channels.update</a></code> (Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#examples">playlistItems.list</a></code> (Go)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/search/list#examples">search.list</a></code> (Go)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#examples">thumbnails.set</a></code> (Java)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#examples">videos.insert</a></code> (Go)</li>
    </ul></p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 24, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-10-24</id>
    <updated>2013-10-24T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API includes two additional features designed to help find and feature live broadcast content:

    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/search#snippet.liveBroadcastContent">snippet.liveBroadcastContent</a></code> property in search results indicates whether a video or channel resource has live broadcast content. Valid property values are <code>upcoming</code>, <code>active</code>, and <code>none</code>.</p>
    <ul>
      <li>
        <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#snippet.liveBroadcastContent">snippet.liveBroadcastContent</a></code> property indicates whether the video is an upcoming or active live broadcast. The list below explains the property's possible values:</p>
        <p><ul>
          <li><code>upcoming</code> – The video is a live broadcast that has not yet started.</li>
          <li><code>active</code> – The video is an ongoing live broadcast.</li>
          <li><code>none</code> – The video is not an upcoming or active live broadcast. This will be the property value for completed broadcasts that are still viewable on YouTube.</li>
        </ul></p>
      </li>
      <li>
        <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails">liveStreamingDetails</a></code> property is an object that contains metadata about a live video broadcast. To retrieve this metadata, include <code>liveStreamingDetails</code> in the <code>part</code> parameter value's list of resource parts. The metadata includes the following new properties:</p>
        <p><ul>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.actualStartTime">liveStreamingDetails.actualStartTime</a></code> – The time that the broadcast actually started. (This value will be present once the broadcast's state is <code>active</code>.)</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.actualEndTime">liveStreamingDetails.actualEndTime</a></code> – The time that the broadcast actually ended. (This value will be present once the broadcast is over.)</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.scheduledStartTime">liveStreamingDetails.scheduledStartTime</a></code> – The time that the broadcast is scheduled to begin.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.scheduledEndTime">liveStreamingDetails.scheduledEndTime</a></code> – The time that the broadcast is scheduled to end. If the property value is empty or the property is not present, then the broadcast is scheduled to go on indefinitely.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#liveStreamingDetails.concurrentViewers">liveStreamingDetails.concurrentViewers</a></code> – The number of people watching the live broadcast.</li>
        </ul></p>
        <p>To retrieve this metadata, include <code>liveStreamingDetails</code> in the <code>part</code> parameter value when calling the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#part">videos.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#part">videos.insert</a></code>, or <code><a href="https://developers.google.com/youtube/v3/docs/videos/update#part">videos.update</a></code> method.</p>
      </li>
    </ul>
    <p>Note that two other features for identifying live broadcast content were released on October 1, 2013 – the <code>search.list</code> method's <code>eventType</code> parameter and the search result's <code>snippet.liveBroadcastContent</code> property.</p>
  </li>
  <li>
    <p>The <code>videos.insert</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#notifySubscribers">notifySubscribers</a></code> parameter, which indicates whether YouTube should send a notification about the new video to users who subscribe to the video's channel. The parameter's default value is <code>True</code>, which indicates that subscribers will be notified of newly uploaded videos. However, a channel owner who is uploading many videos might prefer to set the value to <code>False</code> to avoid sending a notification about each new video to the channel's subscribers.</p>
  </li>
  <li>
    <p>The list of properties that can be modified when calling the <code><a href="https://developers.google.com/youtube/v3/docs/channels/update#request_body">channels.update</a></code> method has been updated to include the <code>invideoPromotion.items[].customMessage</code> and <code>invideoPromotion.items[].websiteUrl</code> properties. In addition, the list has been modified to identify the <code>brandingSettings</code> properties that are modifiable. These <code>brandingSettings</code> properties were already modifiable, so the documentation change does not reflect a change to the API's existing functionality.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#params">playlists.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists/update#params">playlists.update</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/playlists/delete#params">playlists.delete</a></code> methods now support the <code>onBehalfOfContentOwner</code> parameter, which is already supported for several other methods.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#params">playlists.insert</a></code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#onBehalfOfContentOwnerChannel">onBehalfOfContentOwnerChannel</a></code> parameter, which is already supported for several other methods.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.tvpgRating">contentDetails.contentRating.tvpgRating</a></code> property now supports a value of <code>pg14</code>, which corresponds to a <code>TV-14</code> rating.</p>
  </li>
  <li>
    <p>The definition of the <code><a href="https://developers.google.com/youtube/v3/docs/search#snippet.liveBroadcastContent">snippet.liveBroadcastContent</a></code> property, which is part of search results, has been corrected to reflect that <code>live</code> is a valid property value, but <code>active</code> is not a valid property value.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mibacRating">contentDetails.contentRating.mibacRating</a></code> property now supports two additional ratings:</p>
    <p><ul>
      <li><code>mibacVap</code> (VAP) – Children should be accompanied by an adult.</li>
      <li><code>mibacVm12</code> (V.M.12) – Restricted to 12 and over.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].promotedByContentOwner">invideoPromotion.items[].promotedByContentOwner</a></code> property indicates whether the content owner's name will be shown when displaying the promotion. This field can only be set if the API request that sets the value is being made on the content owner's behalf. See the <code><a href="https://developers.google.com/youtube/v3/docs/channels/update#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> parameter for more information.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>October 1, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-10-01</id>
    <updated>2013-10-01T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#auditDetails">auditDetails</a></code> object contains channel data that a multichannel network (MCN) would evaluate while determining whether to accept or reject a particular channel. Note that any API request that retrieves this resource part must provide an authorization token that contains the <code>https://www.googleapis.com/auth/youtubepartner-channel-audit</code> scope. In addition, any token that uses that scope must be revoked when the MCN decides to accept or reject the channel or within two weeks of the date that the token was issued.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.type">invideoPromotion.items[].id.type</a></code> property now supports a value of <code>recentUpload</code>, which indicates that the promoted item is the most recently uploaded video from a specified channel.</p>
    <p>By default, the channel is the same as the one for which the in-video promotion data is set. However, you can promote the most recently uploaded video from another channel by setting the value of the new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.recentlyUploadedBy">invideoPromotion.items[].id.recentlyUploadedBy</a></code> property to the channel ID for that channel.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource contains three new properties &ndash; <code><a href="https://developers.google.com/youtube/v3/docs/channel#brandingSettings.image.bannerTvLowImageUrl">brandingSettings.image.bannerTvLowImageUrl</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channel#brandingSettings.image.bannerTvMediumImageUrl">brandingSettings.image.bannerTvMediumImageUrl</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channel#brandingSettings.image.bannerTvHighImageUrl">brandingSettings.image.bannerTvHighImageUrl</a></code> &ndash; that specify the URLs for the banner images that display on channel pages in television applications.</p>
  </li>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/search#snippet.liveBroadcastContent">snippet.liveBroadcastContent</a></code> property in search results indicates whether a video or channel resource has live broadcast content. Valid property values are <code>upcoming</code>, <code>live</code>, and <code>none</code>.</p>
    <p><ul>
      <li>For a <code>video</code> resource, a value of <code>upcoming</code> indicates that the video is a live broadcast that has not yet started, while a value of <code>live</code> indicates that the video is an ongoing live broadcast.</li>
      <li>For a <code>channel</code> resource, a value of <code>upcoming</code> indicates that the channel has a scheduled broadcast that has not yet started, while a value of <code>live</code> indicates that the channel has an ongoing live broadcast.</li>
    </ul></p>
  </li>
  <li>
    <p>In the <code>watermark</code> resource, the <code><a href="https://developers.google.com/youtube/v3/docs/watermarks/targetChannelId">targetChannelId</a></code> property has changed from an object to a string. Instead of containing a child property that specifies the YouTube channel ID of the channel that the watermark image links to, the <code>targetChannelId</code> property now specifies that value itself. Accordingly, the resource's <code>targetChannelId.value</code> property has been removed.</p>
  </li>
  <li>
    <p>The <code>thumbnails.set</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> parameter, which is already supported for several other methods.</p>
  </li>
  <li>
    <p>The <code>search.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/search/list#eventType">eventType</a></code> parameter, which restricts a search to only return either live, upcoming, or completed broadcast events.</p>
  </li>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mibacRating">contentDetails.contentRating.mibacRating</a></code> property identifies the rating that a video received from Italy's Ministero dei Beni e delle Attivita Culturali e del Turismo.</p>
  </li>
  <li>
    <p>The API now supports the following errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidImage</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set">thumbnails.set</a></code> method returns this error if the provided image content is invalid.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>videoRatingDisabled</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> method returns this error if the owner of the video that is being rated has disabled ratings for that video.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 27, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-08-27</id>
    <updated>2013-08-27T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/watermarks">watermark</a></code> resource identifies an image that displays during playbacks of a specified channel's videos. You can also specify a target channel to which the image will link as well as timing details that determine when the watermark appears during video playbacks and the length of time it is visible.</p>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/watermarks/set">watermarks.set</a></code> method uploads and sets a channel's watermark image. The <code><a href="https://developers.google.com/youtube/v3/docs/watermarks/unset">watermarks.unset</a></code> method deletes a channel's watermark image.</p>
    <p>The error documentation describes the error messages that the API supports specifically for the <code><a href="https://developers.google.com/youtube/v3/docs/errors#watermarks_youtube.watermarks.set">watermarks.set</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/errors#watermarks_youtube.watermarks.unset">watermarks.unset</a></code> methods.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#statistics.hiddenSubscriberCount">statistics.hiddenSubscriberCount</a></code> property contains a boolean value that indicates whether the channel's number of subscribers is hidden. As such, the property's value is <code>false</code> if the channel's subscriber count is publicly visible.</p>
  </li>
  <li>
    <p>The <code>playlists.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/playlists/list#onBehalfOfContentOwnerChannel">onBehalfOfContentOwnerChannel</a></code> parameters. Both parameters are already supported for several other methods.</p>
  </li>
  <li>
    <p>The <code>videos.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#regionCode">regionCode</a></code> parameter, which identifies the content region for which a chart should be retrieved. This parameter can only be used in conjunction with the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#chart">chart</a></code> parameter. The parameter value is an ISO 3166-1 alpha-2 country code.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a></code> describes the following new common request error, which could occur for multiple API methods:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>insufficientPermissions</code></td>
          <td class="error-cause">The scopes associated with the OAuth 2.0 token provided for the request are insufficient for accessing the requested data.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 15, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-08-15</id>
    <updated>2013-08-15T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channel</code> resource's <code>invideoPromotion</code> object has the following new and updated properties:</p>
    <ul>
      <li>
        <p>The API now supports the ability to specify a website as a promoted item. To do so, set the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.type">invideoPromotion.items[].id.type</a></code> property value to <code>website</code> and use the new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].id.websiteUrl">invideoPromotion.items[].id.websiteUrl</a></code> property to specify the URL. Also use the new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].customMessage">invideoPromotion.items[].customMessage</a></code> property to define a custom message to display for the promotion.</p>
        <p>Links can be to associated websites, merchant sites, or social networking sites. See the YouTube Help Center instructions for <a href="https://support.google.com/youtube/answer/2887282">associated websites</a> and <a href="https://support.google.com/youtube/answer/2760471">merchant sites</a> for more information about enabling links for your content.</p>
        <p>By adding promotional links, you agree that those links will not be used to redirect traffic to unauthorized sites and that those links will comply with YouTube's <a href="https://support.google.com/adwordspolicy/bin/answer.py?answer=54818">AdWords policies</a>, <a href="https://support.google.com/youtube/answer/188570?topic=30084">YouTube ad policies</a>, <a href="http://www.youtube.com/t/community_guidelines">YouTube Community Guidelines</a> and <a href="http://www.youtube.com/t/terms">YouTube Terms of Service</a>.</p>
      </li>
      <li>
        <p>The properties related to the timing settings for displaying promoted items during video playback have been restructured:</p>
        <ul>
          <li>
            <p>The <code>invideoPromotion.timing</code> object has been moved to <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].timing">invideoPromotion.items[].timing</a></code>. This object now enables you to customize the timing data for each promoted item in the <code>invideoPromotion.items[]</code> list.</p>
          </li>
          <li>
            <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.defaultTiming">invideoPromotion.defaultTiming</a></code> object specifies default timing settings for your promotion. Those settings define when a promoted item will display during playback of one of your channel's videos. You can override the default timing for any given promoted item using the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].timing">invideoPromotion.items[].timing</a></code> object.</p>
          </li>
          <li>
            <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.items[].timing.durationMs">invideoPromotion.items[].timing.durationMs</a></code> property specifies the amount of time, in milliseconds, that the promotion should display. The <code>invideoPromotion.defaultTiming</code> object also contains a <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion.defaultTiming.durationMs">durationMs</a></code> field that specifies the default amount of time that the promoted item will display.</p>
          </li>
        </ul>
      </li>
      <li>
        <p>The <code>invideoPromotion.items[].type</code> and <code>invideoPromotion.items[].videoId</code> properties both have been moved into the <code>invideoPromotion.items[].id</code> object.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code>subscriptions.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#onBehalfOfContentOwnerChannel">onBehalfOfContentOwnerChannel</a></code> parameters. Both parameters are already supported for several other methods.</p>
  </li>
  <li>
    <p>In the API response to a <code>thumbnails.set</code> request, the <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#kind">kind</a></code> property value has changed from <code>youtube#thumbnailListResponse</code> to <code>youtube#thumbnailSetResponse</code>.</p>
  </li>
  <li>
    <p>Code samples have been added for the following methods:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/channels/update#examples">channels.update</a></code> (Java, Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#examples">playlists.insert</a></code> (.NET, PHP)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert#examples">subscriptions.insert</a></code> (PHP, Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set#examples">thumbnails.set</a></code> (PHP, Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#examples">videos.insert</a></code> (PHP)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/list#examples">videos.list</a></code> (PHP)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/rate#examples">videos.rate</a></code> (Python)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/update#examples">videos.update</a></code> (Java, PHP, Python)</li>
    </ul></p>
    <p>Note that the Python example for the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert">playlistItems.insert</a></code> method was also removed since the functionality it demonstrated is now handled by the <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate#examples">videos.rate</a></code> method.
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a></code> describes the following new request context error, which could occur for any API method that supports the <code>mine</code> request parameter:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidMine</code></td>
          <td class="error-cause">The <code>mine</code> parameter cannot be used in requests where the authenticated user is a YouTube partner. You should either remove the <code>mine</code> parameter, authenticate as a YouTube user by removing the <code>onBehalfOfContentOwner</code> parameter, or act as one of the partner's channels by providing the <code>onBehalfOfContentOwnerChannel</code> parameter if available for the called method.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>August 8, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-08-08</id>
    <updated>2013-08-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/getting-started">Getting Started with the YouTube Data API</a> guide's <a href="https://developers.google.com/youtube/v3/getting-started#quota">Quota Usage</a> section has been updated to reflect a change in the quota cost of a video upload from approximately 16000 units to approximately 1600 units.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>July 30, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-07-30</id>
    <updated>2013-07-30T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>In a <code>channelBanner</code> resource, the value of the <code>kind</code> property's value has changed from <code>youtube#channelBannerInsertResponse</code> to <code>youtube#channelBannerResource</code>. This resource is returned in response to a <code><a href="https://developers.google.com/youtube/v3/docs/channelBanners/insert">channelBanners.insert</a></code> request.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.channel.profileColor">brandingSettings.channel.profileColor</a></code> property specifies a prominent color that complements the channel's content. The property value is a pound sign (<code>#</code>) followed by a six-character hexadecimal string, such as <code>#2793e6</code>.</p>
  </li>
  <li>
    <p>The API now supports the ability to specify whether a subscription is for all of a channel's activities or just for new uploads. The <code>subscription</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions#contentDetails.activityType">contentDetails.activityType</a></code> property identifies the types of activities that the subscriber will be notified about. Valid property values are <code>all</code> and <code>uploads</code>.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code> method supports new parameters for retrieving a chart of the most popular videos on YouTube:</p>
    <p><ul>
      <li>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#chart">chart</a></code> parameter identifies the chart that you want to retrieve. Currently, the only supported value is <code>mostPopular</code>. Note that the <code>chart</code> parameter is a filter parameter, which means it cannot be used in the same request as other filter parameters (<code>id</code> and <code>myRating</code>).</li>
      <li>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#videoCategoryId">videoCategoryId</a></code> parameter identifies the <a href="https://developers.google.com/youtube/v3/docs/videoCategories">video category</a> for which the chart should be retrieved. This parameter can only be used in conjunction with the <code>chart</code> parameter. By default, charts are not restricted to a particular category.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#topicDetails.relevantTopicIds[]">topicDetails.relevantTopicIds[]</a></code> property provides a list of Freebase topic IDs that are relevant to the video or its content. The subjects of these topics may be mentioned in or appear in the video.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code>recordingDetails.location.elevation</code> property has been renamed to <code>recordingDetails.location.altitude</code>, and its <code>fileDetails.recordingLocation.location.elevation</code> property has been renamed to <code>fileDetails.recordingLocation.location.altitude</code>.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos/contentDetails.contentRating">contentDetails.contentRating</a></code> object specifies the ratings that a video received under various rating schemes, including MPAA ratings, TVPG ratings, and so forth. For each rating system, the API now supports a rating value that indicates that the video has not been rated. Note that for <a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mpaaRating">MPAA ratings</a>, an "unrated" rating is frequently used to identify uncut versions of films for which the cut version of the film did receive an official rating.</p>
  </li>
  <li>
    <p>The <code>video</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.ytRating">contentDetails.contentRating.ytRating</a></code> property identifies age-restricted content. The property value will be <code>ytAgeRestricted</code> if YouTube has identified the video as containing content that is inappropriate for users less than 18 years old. If the property is absent or if the property value is empty, then the content has not been identified as age-restricted.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method's <code>mySubscribers</code> parameter has been deprecated. Use the <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list">subscriptions.list</a></code> method and its <code>mySubscribers</code> parameter to retrieve a list of subscribers to the authenticated user's channel.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channelBanners/insert">channelBanners.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/getRating">videos.getRating</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> methods all now support the <code>onBehalfOfContentOwner</code> parameter. That parameter indicates that the authenticated user is acting on behalf of the content owner specified in the parameter value.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method's documentation has been updated to reflect the fact that that method can be used to update the <code>channel</code> resource's <code>brandingSettings</code> object and its child properties. The documentation also now lists the updated list of properties that you can set for the <code>channel</code> resource's <code>invideoPromotion</code> object.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a></code> describes the following new errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>accountDelegationForbidden</code></td>
          <td class="error-cause">This error is not specific to a particular API method. It indicates that the authenticated user is not authorized to act on behalf of the specified Google account.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>authenticatedUserAccountClosed</code></td>
          <td class="error-cause">This error is not specific to a particular API method. It indicates that the authenticated user's YouTube account is closed. If the user is acting on behalf of another Google Account, then this error would indicate that that other account is closed.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>authenticatedUserAccountSuspended</code></td>
          <td class="error-cause">This error is not specific to a particular API method. It indicates that the authenticated user's YouTube account is suspended. If the user is acting on behalf of another Google Account, then this error would indicate that that other account is suspended.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>authenticatedUserNotChannel</code></td>
          <td class="error-cause">This error is not specific to a particular API method. It indicates that the API server cannot identify the channel associated with the API request. If the request is authorized and uses the <code>onBehalfOfContentOwner</code> parameter, you should also set the <code>onBehalfOfContentOwnerChannel</code> parameter.</td>
        </tr>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>cmsUserAccountNotFound</code></td>
          <td class="error-cause">This error is not specific to a particular API method. The CMS user is not allowed to act on behalf of the specified content owner.</td>
        </tr>
        <tr>
          <td class="error-name"><code>notFound</code></td>
          <td class="error-reason"><code>contentOwnerAccountNotFound</code></td>
          <td class="error-cause">This error is not specific to a particular API method. The specified content owner account was not found.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidPart</code></td>
          <td class="error-cause">This error is not specific to a particular API method. The request's <code>part</code> parameter specifies parts that cannot be written at the same time.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>videoChartNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code> method returns this error when the request specifies an unsupported or unavailable video chart.</td>
        </tr>
        <tr>
          <td class="error-name"><code>notFound</code></td>
          <td class="error-reason"><code>videoNotFound</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method returns this error to indicate that the video you are trying to update cannot be found. Check the value of the <code>id</code> property in the request body to ensure it is correct.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>June 10, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-06-10</id>
    <updated>2013-06-10T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channels.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#forUsername">forUsername</a></code> parameter enables you to retrieve information about a channel by specifying its YouTube username.</p>
  </li>
  <li>
    <p>The <code>activities.list</code> method now supports the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#regionCode">regionCode</a></code> parameter, which instructs the API to return results relevant to the specified country. YouTube uses this value when the authorized user's previous activity on YouTube does not provide enough information to generate the activity feed.</p>
  </li>
  <li>
    <p>Playlist resources now contain the <code><a href="https://developers.google.com/youtube/v3/docs/playlists#snippet.tags[]">snippet.tags</a></code> property. The property will be only be returned to authorized users who are retrieving data about their own playlists. Authorized users can also set playlist tags when calling either the <code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert">playlists.insert</a></code> or <code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code> methods.</p>
  </li>
  <li>
    <p>The <code>onBehalfOfContentOwner</code> parameter, which was previously supported for the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> and <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> methods, is now also supported for the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#onBehalfOfContentOwner">videos.insert</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/update#onBehalfOfContentOwner">videos.update</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/delete#onBehalfOfContentOwner">videos.delete</a></code> methods. Note that when this parameter is used in a call to the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method, the request must also specify a value for the new <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#onBehalfOfContentOwnerChannel">onBehalfOfContentOwnerChannel</a></code> parameter, which identifies the channel to which the video will be added. The channel must be linked to the content owner that the <code>onBehalfOfContentOwner</code> parameter specifies.</p>
    <p>The 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. The CMS account that the user authenticates with must be linked to the specified YouTube content owner.</p>
    <p>This parameter is intended for content partners that own and manage many different YouTube channels. The parameter enables those partners to authenticate once and get access to all of their video and channel data, without having to provide authentication credentials for each individual channel.</p>
    <p>Specifically in regard to this release, the parameter now enables a content partner to insert, update, or delete videos in any of the YouTube channels that the partner owns.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a></code> describes the following new errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>insufficientCapabilities</code></td>
          <td class="error-cause">This error is not specific to a particular API method. It indicates that the CMS user calling the API does not have sufficient permissions to perform the requested operation. This error is associated with the use of the <code>onBehalfOfContentOwner</code> parameter, which is supported for several API methods.</td>
        </tr>
        <tr>
          <td class="error-name"><code>unauthorized</code></td>
          <td class="error-reason"><code>authorizationRequired</code></td>
          <td class="error-cause">The <code><a href="https://developers.google.com/youtube/v3/docs/activities/list">activities.list</a></code> method returns this error when the request uses the <code><a href="https://developers.google.com/youtube/v3/docs/activities/list#home">home</a></code> parameter but is not properly authorized.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>In the <code><a href="https://developers.google.com/youtube/v3/docs/channels">channels</a></code> resource, the <code>invideoPromotion.channelId</code> property has been removed because the channel ID is already specified using the resource's <code><a href="https://developers.google.com/youtube/v3/docs/channels#id">id</a></code> property.</p>
  </li>
  <li>
    <p>The new <a href="https://developers.google.com/youtube/v3/guides/working_with_channel_ids">Working with Channel IDs</a> guide explains how the API uses channel IDs. The guide may be especially useful for developers migrating from the previous version of the API and who have applications that either request content for the <code>default</code> user or that rely on the notion that every YouTube channel has a unique username, which is no longer the case.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 22, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-05-22</id>
    <updated>2013-05-22T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/channelBanners/insert">channelBanners.insert</a></code> method enables you to upload a banner image that can subsequently be set as the banner image for a channel using the <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings.image.bannerExternalUrl">brandingSettings.image.bannerExternalUrl</a></code> property.</p>
  </li>
  <li>
    <p>The documentation for the <code><a href="https://developers.google.com/youtube/v3/docs/channels/update#request_body">channels.update</a></code> method has been updated to list the properties that can be modified when calling the method.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resource documentation no longer lists <code>unspecified</code> as a valid property value for the <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions.processingErrors[]">suggestions.processingErrors[]</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions.processingHints[]">suggestions.processingHints[]</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions.processingWarnings[]">suggestions.processingWarnings[]</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions.editorSuggestions[]">suggestions.editorSuggestions[]</a></code> properties.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code> method's <code>maxResults</code> parameter now has a default value of <code>5</code>.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a></code> now lists errors for the <code>channelBanners.insert</code> and <code>subscriptions.list</code> methods. It also lists several new errors for the <code>channels.update</code> method.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 14, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-05-14</id>
    <updated>2013-05-14T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>Standalone pages now list code samples for <a href="https://developers.google.com/youtube/v3/code_samples/java">Java</a>, <a href="https://developers.google.com/youtube/v3/code_samples/dotnet">.NET</a>, <a href="https://developers.google.com/youtube/v3/code_samples/php">PHP</a>, and <a href="https://developers.google.com/youtube/v3/code_samples/ruby">Ruby</a>.</p>
  </li>
  <li>
    <p>The page that lists <a href="https://developers.google.com/youtube/v3/code_samples/python">Python</a> code samples now includes examples for adding a subscription, creating a playlist, and updating a video.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 10, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-05-10</id>
    <updated>2013-05-10T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>YouTube no longer identifies experimental API features and services. Instead, we now provide a list of <a href="https://developers.google.com/youtube/youtube-api-list">YouTube APIs that are subject to the deprecation policy</a>.</p>
  </li>
</ul>
]]>
    </content>
  </entry>
  <entry>
    <title>May 8, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-05-08</id>
    <updated>2013-05-08T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>Channel resources now support the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">inVideoPromotion</a></code> object, which encapsulates information about a promotional campaign associated with the channel. A channel can use an in-video promotional campaign to display thumbnail images for a promoted video within the video player during playbacks of the channel's videos.</p>
    <p>You can retrieve this data by including <code>invideoPromotion</code> in the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#part">part</a></code> parameter value in a <code>channels.list</code> request.</p>
  </li>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/channels/update">channels.update</a></code> method can be used to update a channel's in-video promotional campaign data. Note that the method only supports updates to the <code><a href="https://developers.google.com/youtube/v3/docs/channels#invideoPromotion">invideoPromotion</a></code> part of the <code>channel</code> resource and does not yet support updates to other parts of that resource.</p>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>May 2, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-05-02</id>
    <updated>2013-05-02T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>Channel resources now support the <code><a href="https://developers.google.com/youtube/v3/docs/channels#status.isLinked">status.isLinked</a></code> property, which indicates whether the channel data identifies a user that is already linked to either a YouTube username or a Google+ account. A user that has one of these links already has a public YouTube identity, which is a prerequisite for several actions, such as uploading videos.</p>
  </li>
  <li>
    <p>Subscription resources now support the <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions#subscriberSnippet">subscriberSnippet</a></code> part. That object encapsulates contains snippet data for the subscriber's channel.</p>
  </li>
  <li>
    <p>The API now supports the <code><a href="https://developers.google.com/youtube/v3/docs/videos/getRating">videos.getRating</a></code> method, which retrieves the ratings that the authenticated user gave to a list of one or more videos.</p>
  </li>
  <li>
    <p>The <code>videos.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#myRating">myRating</a></code> parameter enables you to retrieve a list of videos that the authenticated user rated with a <code>like</code> or <code>dislike</code> rating.</p>
    <p>The <code>myRating</code> parameter and the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#id">id</a></code> parameter are both now considered filter parameters, which means that an API request must specify exactly one of the parameters. (Previously, the <code>id</code> parameter was a required parameter for this method.)</p>
    <p>The method returns a <code><a href=/youtube/v3/docs/videos/list#errors">forbidden</a></code> error for requests that attempt to retrieve video rating information but are not properly authorized to do so.</p>
  </li>
  <li>
    <p>With the introduction of the <code>myRating</code> parameter, the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code> method has also been updated to support pagination. Note, however, that paging parameters are only supported for requests using the <code>myRating</code> parameter. (Paging parameters and information are not supported for requests that use the <code>id</code> parameter.)</p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#maxResults">maxResults</a></code> parameter specifies the maximum number of videos that the API can return in the result set, and the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#pageToken">pageToken</a></code> parameter identifies a specific page in the result set that you want to retrieve.</p>
      </li>
      <li>
        <p>The <code>youtube#videoListResponse</code> resource, which is returned in response to a <code>videos.list</code> request, now contains the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list#pageInfo">pageInfo</a></code> object, which contains details like the total number of results and the number of results included in the current result set. The <code>youtube#videoListResponse</code> resource can also include <code>nextPageToken</code> and <code>prevPageToken</code> properties, each of which provides a token that could be used to retrieve a specific page in the result set.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#params">videos.insert</a></code> method supports the following new parameters:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#autoLevels">autoLevels</a></code> &ndash; Set this parameter value to <code>true</code> to instruct YouTube to automatically enhance the video's lighting and color.</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#stabilize">stabilize</a></code> &ndash; Set this parameter value to <code>true</code> to instruct YouTube to adjust the video by removing shakiness resulting from camera motions.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>channelTitle</code> property has been added to the <code>snippet</code> for the following resources:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#channelTitle">playlistItem</a></code> &ndash; The property specifies the name of the channel that added the playlist item.</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlists#channelTitle">playlist</a></code> &ndash; The property specifies the name of the channel that created the playlist.</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/subscriptions#channelTitle">subscription</a></code> &ndash; The property specifies the name of the channel that is subscribed to.</li>
    </ul></p>
  </li>
  <li>
    <p>Code samples have been added for the following methods:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/activities/insert#examples">activities.insert</a></code> (Ruby)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#examples">playlistItems.list</a></code> (.NET)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/search/list#examples">search.list</a></code> (.NET)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/insert#examples">subscriptions.insert</a></code> (Java, Ruby)</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#examples">videos.insert</a></code> (.NET, Ruby)</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>subscriptions.list</code> method's new <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions/list#mySubscribers">mySubscribers</a></code> parameter enables you to retrieve a list of the currently authenticated user's subscribers. This parameter can only be used in a properly authorized request.</p>
    <p><strong>Note:</strong> This functionality is intended to replace the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#mySubscribers">mySubscribers</a></code> parameter currently supported for the <code>channels.list</code> method. That parameter will be deprecated.</p>
  </li>
  <li>
    <p>In a <code>video</code> resource, the property value <code>unspecified</code> is no longer a possible value for any of the following properties:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails.fileType">fileDetails.fileType</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails.videoStreams[].rotation">fileDetails.videoStreams[].rotation</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails.processingStatus">processingDetails.processingStatus</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails.processingFailureReason">processingDetails.processingFailureReason</a></code></li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails.fileType">fileDetails.fileType</a></code></li>
    </ul></p>
  </li>
  <li>
    <p>API requests that contain an unexpected parameter now return a <code>badRequest</code> error, and the reported reason for the error is <code>unexpectedParameter</code>.</p>
  </li>
  <li>
    <p>The error that the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert#errors">playlistItems.insert</a></code> method returns when the playlist already contains the maximum number of allowed items has been updated. The error is now reported as a <code>forbidden</code> error, and the error reason is <code>playlistContainsMaximumNumberOfVideos</code>.</p>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>April 19, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-04-19</id>
    <updated>2013-04-19T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> method lets a user set a <code>like</code> or <code>dislike</code> rating on a video or remove a rating from a video.</p>
    <p>The <a href="https://developers.google.com/youtube/v3/docs/errors#videos_youtube.videos.rate">error documentation</a> has also been updated to list the errors that the API might return in response to a <code><a href="https://developers.google.com/youtube/v3/docs/videos/rate">videos.rate</a></code> method call.</p>
  </li>
  <li>
    <p>Thumbnail images are now identified in the API documentation as a <a href="https://developers.google.com/youtube/v3/docs/thumbnails">separate resource</a>, and the new <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set">thumbnails.set</a></code> method enables you to upload a custom video thumbnail to YouTube and set it for a video.</p>
    <p>The <a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a> has also been updated to list the errors that the API might return in response to a <code><a href="https://developers.google.com/youtube/v3/docs/thumbnails/set">thumbnails.set</a></code> method call.</p>
    <p>Note that this change does not really affect existing resources that return thumbnail images. Thumbnail images are returned in those resources in the same way that they were previously, though the documentation does now list the names of the different thumbnail sizes that the API might return.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#brandingSettings">brandingSettings</a></code> part identifies settings, text, and images for the channel's channel page and video watch pages.</p>
  </li>
  <li>
    <p>The <code>playlistItem</code> resource contains the following new properties:</p>
    <ul>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#status">status</a></code> object encapsulates status information about the playlist item, and the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems#status.privacyStatus">status.privacyStatus</a></code> property identifies the playlist item's privacy status.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code>video</code> resource contains the following new properties:</p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos#status.publicStatsViewable">status.publicStatsViewable</a></code> property indicates whether extended video statistics on the watch page are publicly viewable. By default, those statistics are viewable, and statistics like a video's viewcount and ratings will still be publicly visible even if this property's value is set to <code>false</code>. You can set this property's value when calling the <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> or <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> method.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating">contentDetails.contentRating</a></code> object encapsulates ratings that the video received under various rating schemes. The list below identifies the supported rating systems and provides a link to the property associated with each rating system. The property definitions identify the supported rating values for each system.</p>
        <table class="matchpre" id="property-table">
          <thead>
            <tr>
              <th>Country</th>
              <th>Rating system</th>
              <th>Property</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td>United States</code></td>
              <td>Motion Picture Association of America (MPAA)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.mpaaRating">contentDetails.contentRating.mpaaRating</a></code>
            </tr>
            <tr>
              <td>United States</code></td>
              <td>TV Parental Guidelines</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.tvpgRating">contentDetails.contentRating.tvpgRating</a></code>
            </tr>
            <tr>
              <td>Australia</code></td>
              <td>Australian Classification Board (ACB)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.acbRating">contentDetails.contentRating.acbRating</a></code>
            </tr>
            <tr>
              <td>Brazil</code></td>
              <td>Departamento de Justi&ccedil;a, Classifica&ccedil;&atilde;o, Qualifica&ccedil;&atilde;o e T&iacute;tulos</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.djctqRating">contentDetails.contentRating.djctqRating</a></code>
            </tr>
            <tr>
              <td>Canada</code></td>
              <td>Canadian Home Video Rating System (CHVRS)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.chvrsRating">contentDetails.contentRating.chvrsRating</a></code>
            </tr>
            <tr>
              <td>France</code></td>
              <td>Centre national du cin&eacute;ma et de l'image anim&eacute;e (French Ministry of Culture)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fmocRating">contentDetails.contentRating.fmocRating</a></code>
            </tr>
            <tr>
              <td>Germany</code></td>
              <td>Freiwillige Selbstkontrolle der Filmwirtschaft (FSK)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.fskRating">contentDetails.contentRating.fskRating</a></code>
            </tr>
            <tr>
              <td>Great Britain</code></td>
              <td>British Board of Film Classification (BBFC)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.bbfcRating">contentDetails.contentRating.bbfcRating</a></code>
            </tr>
            <tr>
              <td>India</code></td>
              <td>Central Board of Film Certification (CBFC)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.cbfcRating">contentDetails.contentRating.cbfcRating</a></code>
            </tr>
            <tr>
              <td>Japan</code></td>
              <td>&#26144;&#20523;&#31649;&#29702;&#22996;&#21729;&#20250; (EIRIN)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.eirinRating">contentDetails.contentRating.eirinRating</a></code>
            </tr>
            <tr>
              <td>Korea</code></td>
              <td>&#50689;&#49345;&#47932;&#46321;&#44553;&#50948;&#50896;&#54924; (KMRB)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.kmrbRating">contentDetails.contentRating.kmrbRating</a></code>
            </tr>
            <tr>
              <td>Mexico</code></td>
              <td>General Directorate of Radio, Television and Cinematography (RTC)</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.rtcRating">contentDetails.contentRating.rtcRating</a></code>
            </tr>
            <tr>
              <td>New Zealand</code></td>
              <td>Office of Film and Literature Classification</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.oflcRating">contentDetails.contentRating.oflcRating</a></code>
            </tr>
            <tr>
              <td>Russia</code></td>
              <td>National Film Registry of the Russian Federation</td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.russiaRating">contentDetails.contentRating.russiaRating</a></code>
            </tr>
            <tr>
              <td>Spain</code></td>
              <td>Instituto de la Cinematograf&iacute;a y de las Artes Audiovisuales (ICAA)</code></td>
              <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.contentRating.icaaRating">contentDetails.contentRating.icaaRating</a></code>
            </tr>
          </tbody>
        </table>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update">playlistItems.update</a></code> method's documentation has been updated to reflect the fact that the <code>snippet.resourceId</code> property must be specified in the resource sent as the request body.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method now supports the following functionality:</p>
    <ul>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/search/list#forMine">forMine</a></code> parameter restricts a search to only retrieve the authenticated user's videos.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list#order">order</a></code> parameter now supports the ability to sort results alphabetically by title (<code>order=title</code>) or by video count in descending order (<code>order=videoCount</code>).</p>
      </li>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/search/list#safeSearch">safeSearch</a></code> parameter indicates whether search results should include restricted content.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code> method supports several new errors, which are listed in the table below:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidCategoryId</code></td>
          <td class="error-cause">The <code>snippet.categoryId</code> property specifies an invalid category ID. Use the <code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a></code> method to retrieve supported categories.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidRecordingDetails</code></td>
          <td class="error-cause">The <code>metadata specifies invalid recording details.</td>
        </tr>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidVideoGameRating</code></td>
          <td class="error-cause">The request metadata specifies an invalid video game rating.</td>
        <tr>
          <td class="error-name"><code>badRequest</code></td>
          <td class="error-reason"><code>invalidVideoMetadata</code></td>
          <td class="error-cause">The request metadata is invalid.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>The <code>onBehalfOfContentOwner</code> parameter has been removed from the list of supported parameters for the <code>videos.update</code> and <code>videos.delete</code> methods.</p>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>March 12, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-03-12</id>
    <updated>2013-03-12T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The <code>channelTitle</code> property has been added to the <code>snippet</code> for the following resources:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/activity#channelTitle">activity</a></code> &ndash; The property specifies the name of the channel responsible for the activity.</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/search#channelTitle">search</a></code> &ndash; The property specifies the name of the channel associated with the resource that the search result identifies.</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/video#channelTitle">video</a></code> &ndash; The property specifies the name of the channel that uploaded the video.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code>search.list</code> method supports the following new parameters:</p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list#channelType">channelType</a></code> parameter lets you restrict a search for channels to retrieve all channels or to retrieve only shows.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list#videoType">videoType</a></code> parameter lets you restrict a search for videos to retrieve all videos or to retrieve only movies or only episodes of shows.</p>
      </li>
    </ul>
  </li>
  <li>
    <p>The definition of the <code>video</code> resource's <code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails">recordingDetails</a></code> part has been updated to note that the object will only be returned for a video if the video's geolocation data or recording time has been set.</p>
  </li>
  <li>
    <p>The <code>playlistItems.update</code> method now returns an <code><a href="https://developers.google.com/youtube/v3/docs/errors#youtube.playlistItems.update-invalidValue-invalidSnippet">invalidSnippet</a></code> error, which is returned if the API request does not specify a valid snippet.</p>
  </li>
  <li>
    <p>Several API methods support new parameters that are intended exclusively for YouTube content partners. YouTube content partners include movie and television studios, record labels, and other content creators that make their content available on YouTube.</p>
    <ul>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> 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. The CMS account that the user authenticates with must be linked to the specified YouTube content owner.</p>
        <p>This parameter is intended for content partners that own and manage many different YouTube channels. The parameter enables those partners to authenticate once and get access to all of their video and channel data, without having to provide authentication credentials for each individual channel.</p>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/delete">videos.delete</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods all support this parameter.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#managedByMe">managedByMe</a></code> parameter, which is supported by the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list">channels.list</a></code> method, instructs the API to return all channels owned by the content owner that the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> parameter specifies.</p>
      </li>
      <li>
        <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list#forContentOwner">forContentOwner</a></code> parameter, which is supported by the <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method, instructs the API to restrict search results to only include resources that are owned by the content owner that the <code><a href="https://developers.google.com/youtube/v3/docs/channels/list#onBehalfOfContentOwner">onBehalfOfContentOwner</a></code> parameter specifies.</p>
      </li>
    </ul>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>February 25, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-02-25</id>
    <updated>2013-02-25T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The API supports several new parts and properties for <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resources:</p>
    <ul>
      <li>
        <p>The new <code><a href="https://developers.google.com/youtube/v3/docs/videos#fileDetails">fileDetails</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos#processingDetails">processingDetails</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos#suggestions">suggestions</a></code> parts provide information to video owners about their uploaded videos. This data is very useful in applications that enable video uploads and includes the following:</p>
        <p><ul>
          <li>processing status and progress</li>
          <li>errors or other issues encountered while processing a video</li>
          <li>availability of thumbnail images</li>
          <li>suggestions for improving video or metadata quality</li>
          <li>details about the original file uploaded to YouTube</li>
        </ul></p>
        <p>All of these parts can only be retrieved by the video owner. The list below briefly describes the new parts, and the <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resource documentation defines all of the properties that each part contains.</p>
        <ul>
          <li>
            <p>The <code>fileDetails</code> object contains information about the video file that was uploaded to YouTube, including the file's resolution, duration, audio and video codecs, stream bitrates, and more.</p>
          </li>
          <li>
            <p>The <code>processingProgress</code> object contains information about YouTube's progress in processing the uploaded video file. The object's properties identify the current processing status and estimate the time remaining until YouTube finishes processing the video. This part also indicates whether different types of data or content, such as file details or thumbnail images, are available for the video.</p><p>This object is designed to be polled so that the video uploader can track the progress that YouTube has made in processing the uploaded video file.</p>
          </li>
          <li>
            <p>The <code>suggestions</code> object contains suggestions that identify opportunities to improve the video quality or the metadata for the uploaded video.</p>
          </li>
        </ul>
      </li>
      <li>
        <p>The <code>contentDetails</code> part contains four new properties. These properties can be retrieved with unauthenticated requests.</p>
        <p><ul>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.dimension">dimension</a></code> &ndash; Indicates whether the video is available in 2D or 3D.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.definition">definition</a></code> &ndash; Indicates whether the video is available in standard or high definition.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.caption">caption</a></code> &ndash; Indicates whether captions are available for the video.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#contentDetails.licensedContent">licensedContent</a></code> &ndash; Indicates whether the video contains content that has been claimed by a YouTube content partner.</li>
        </ul></p>
      </li>
      <li>
        <p>The <code>status</code> part contains two new properties. Video owners can set values for both properties when inserting or updating a video. These properties can also be retrieved with unauthenticated requests.</p>
        <p><ul>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#status.embeddable">embeddable</a></code> &ndash; Indicates whether the video can be embedded on another website.</li>
          <li><code><a href="https://developers.google.com/youtube/v3/docs/videos#status.license">license</a></code> &ndash; Specifies the video's license. Valid values are <code>creativeCommon</code> and <code>youtube</code>.</li>
        </ul></p>
      </li>
    </ul>
  </li>
  <li>
    <p>The definition of the <code>part</code> parameter has been updated for the <code><a href="https://developers.google.com/youtube/v3/docs/videos/list">videos.list</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/videos/insert">videos.insert</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code> methods to list the newly added parts described above as well as the <code>recordingDetails</code> part, which had been inadvertently omitted.</p>
  </li>
  <li>
    <p>The <code>channel</code> resource's new <code><a href="https://developers.google.com/youtube/v3/docs/channels#contentDetails.googlePlusUserId">contentDetails.googlePlusUserId</a></code> property specifies the Google+ profile ID associated with the channel. This value can be used to generate a link to the Google+ profile.</p>
  </li>
  <li>
    <p>Each thumbnail image object now specifies the image's width and height. Thumbnail images are currently returned in <code><a href="https://developers.google.com/youtube/v3/docs/activities">activity</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlists">playlist</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems">playlistItem</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/search">search result</a></code>, <code><a href="https://developers.google.com/youtube/v3/docs/subscriptions">subscription</a></code>, and <code><a href="https://developers.google.com/youtube/v3/docs/videos">video</a></code> resources.</p>
  </li>
  <li>
    <p>The <code>playlistItems.list</code> now supports the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#videoId">videoId</a></code> parameter, which can be used in conjunction with the <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#playlistId">playlistId</a></code> parameter to only retrieve the playlist item that represents the specified video.</p>
    <p>The API returns a <code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#youtube.playlistItems.list-notFound-videoNotFound">notFound</a></code> error if the video that the parameter identifies cannot be found in the playlist.</p>
  </li>
  <li>
    <p>The <a href="https://developers.google.com/youtube/v3/docs/errors">error documentation</a> describes a new <code><a href="https://developers.google.com/youtube/v3/docs/errors#gdata.CoreErrorDomain-forbidden-forbidden">forbidden</a></code> error, which indicates that a request is not properly authorized for the requested action.</p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/channels">channel</a></code> resource's <code>snippet.channelId</code> property has been removed. The resource's <code>id</code> property provides the same value.</p>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>January 30, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-01-30</id>
    <updated>2013-01-30T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>The new <a href="https://developers.google.com/youtube/v3/docs/errors">error</a> page lists errors that the API can return. The page includes general errors, which might occur for multiple different API methods, as well as method-specific errors.</p>
  </li>
</ul>]]>
  </content>
  </entry>
  <entry>
    <title>January 16, 2013</title>
    <id>tag:google.com,changelog:youtube-data-api-v3-revision-history#2013-01-16</id>
    <updated>2013-01-16T16:00:00:+0000</updated>
    <link rel="alternate" href="https://developers.google.com/youtube/v3/revision_history"/>
    <content type="html"><![CDATA[
<p>This update contains the following changes:</p>

<ul>
  <li>
    <p>Code samples are now available for the methods and languages shown in the list below:</p>
    <p><ul>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/activities/insert#examples">activities.insert</a></code> &ndash; Java</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/insert#examples">playlistItems.insert</a></code> &ndash; Python</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/list#examples">playlistItems.list</a></code> &ndash; Java, JavaScript, PHP, Python, Ruby</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/playlists/insert#examples">playlists.insert</a></code> &ndash; Java, JavaScript, Python</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/search/list#examples">search.list</a></code> &ndash; Java, JavaScript, Python, Ruby</li>
      <li><code><a href="https://developers.google.com/youtube/v3/docs/videos/insert#examples">videos.insert</a></code> &ndash; Java</li>
    </ul></p>
  </li>
  <li>
    <p>An <code><a href="https://developers.google.com/youtube/v3/docs/activities">activity</a></code> resource can now report a <code>channelItem</code> action, which occurs when YouTube adds a video to an <a href="http://support.google.com/youtube/bin/answer.py?answer=2579942">automatically generated YouTube channel</a>. (YouTube algorithmically identifies topics that have a significant presence on the YouTube website and automatically generates channels for those topics.)</p>
  </li>
  <li>
    <p>The following <code><a href="https://developers.google.com/youtube/v3/docs/search/list#params">search.list</a></code> parameters have been updated:</p>
    <p><ul>
      <li>The <code>q</code> parameter is no longer designated as a filter, which means ....</li>
      <li>The <code>relatedToVideo</code> parameter has been renamed <code>relatedToVideoId</code>.</li>
      <li>The <code>published</code> parameter has been replaced with two new parameters, <code>publishedAfter</code> and <code>publishedBefore</code>, which are described below.</li>
    </ul></p>
  </li>
  <li>
    <p>The <code><a href="https://developers.google.com/youtube/v3/docs/search/list">search.list</a></code> method supports the following new parameters:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Parameter name</th>
          <th>Value</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#channelId">channelId</a></code></td>
          <td><code class="apitype">string</code></td>
          <td>Return resources created by the specified channel.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#publishedAfter">publishedAfter</a></code></td>
          <td><code class="apitype">datetime</code></td>
          <td>Return resources created after the specified time.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#publishedBefore">publishedBefore</a></code></td>
          <td><code class="apitype">datetime</code></td>
          <td>Return resources created before the specified time.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#regionCode">regionCode</a></code></td>
          <td><code class="apitype">string</code></td>
          <td>Return resources for the specified country.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#videoCategoryId">videoCategoryId</a></code></td>
          <td><code class="apitype">string</code></td>
          <td>Filter video search results to only include videos associated with the specified <a href="https://developers.google.com/youtube/v3/docs/videoCategories">video category</a>.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#videoEmbeddable">videoEmbeddable</a></code></td>
          <td><code class="apitype">string</code></td>
          <td>Filter video search results to only include videos that can be played in an embedded player on a web page. Set the parameter value to <code>true</code> to only retrieve embeddable videos.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/search/list#videoSyndicated">videoSyndicated</a></code></td>
          <td><code class="apitype">string</code></td>
          <td>Filter video search results to only include videos that can be played outside of YouTube.com. Set the parameter value to <code>true</code> to only retrieve syndicated videos.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>Several API resources support new properties. The table below identifies the resources and their new properties:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Resource</th>
          <th>Property name</th>
          <th>Value</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/activities#contentDetails.playlistItem.playlistItemId">activity</a></code></td>
          <td><code>contentDetails.playlistItem.playlistItemId</code></td>
          <td><code class="apitype">string</code></td>
          <td>The playlist item ID that YouTube assigned to uniquely identify the item in the playlist.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/activities#contentDetails.channelItem">activity</a></code></td>
          <td><code>contentDetails.channelItem</code></td>
          <td><code class="apitype">object</code></td>
          <td>An object that contains information about a resource that was added to a channel. This property is only present if the <code>snippet.type</code> is <code>channelItem</code>.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/activities#/youtube/v3/docs/activities#contentDetails.channelItem.resourceId">activity</a></code></td>
          <td><code>contentDetails.channelItem.resourceId</code></td>
          <td><code class="apitype">object</code></td>
          <td>An object that identifies the resource that was added to the channel. Like other <code>resourceId</code> properties, it contains a <code>kind</code> property that specifies the resource type, such as video or playlist. It also contains exactly one of several properties &ndash; <code>videoId</code>, <code>playlistId</code>, etc. &ndash; that specifies the ID that uniquely identifies that resource.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/channels#status">channel</a></code></td>
          <td><code>status</code></td>
          <td><code class="apitype">object</code></td>
          <td>This object encapsulates information about the channel's privacy status.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/channels#status.privacyStatus">channel</a></code></td>
          <td><code>status.privacyStatus</code></td>
          <td><code class="apitype">string</code></td>
          <td>The channel's privacy status. Valid values are <code>private</code> and <code>public</code>.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlists#contentDetails">playlist</a></code></td>
          <td><code>contentDetails</code></td>
          <td><code class="apitype">object</code></td>
          <td>This object contains metadata about the playlist's content.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlists#contentDetails.itemCount">playlist</a></code></td>
          <td><code>contentDetails.itemCount</code></td>
          <td><code class="apitype">unsigned integer</code></td>
          <td>The number of videos in the playlist.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlists#player">playlist</a></code></td>
          <td><code>player</code></td>
          <td><code class="apitype">object</code></td>
          <td>This object contains information that you would use to play the playlist in an embedded player.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlists#player.embedHtml">playlist</a></code></td>
          <td><code>player.embedHtml</code></td>
          <td><code class="apitype">string</code></td>
          <td>An <code>&lt;iframe&gt;</code> tag that embeds a video player that plays the playlist.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails">video</a></code></td>
          <td><code>recordingDetails</code></td>
          <td><code class="apitype">object</code></td>
          <td>This object encapsulates information that identifies or describes the place and time that the video was recorded.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location">video</a></code></td>
          <td><code>recordingDetails.location</code></td>
          <td><code class="apitype">object</code></td>
          <td>This object contains geolocation information associated with the video.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.latitude">video</a></code></td>
          <td><code>recordingDetails.location.latitude</code></td>
          <td><code class="apitype">double</code></td>
          <td>Latitude in degrees.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.longitude">video</a></code></td>
          <td><code>recordingDetails.location.longitude</code></td>
          <td><code class="apitype">double</code></td>
          <td>Longitude in degrees.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.location.elevation">video</a></code></td>
          <td><code>recordingDetails.location.elevation</code></td>
          <td><code class="apitype">double</code></td>
          <td>Altitude above the Earth, in meters.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.locationDescription">video</a></code></td>
          <td><code>recordingDetails.locationDescription</code></td>
          <td><code class="apitype">string</code></td>
          <td>A text description of the location where the video was recorded.</td>
        </tr>
        <tr id="kind">
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos#recordingDetails.recordingDate">video</a></code></td>
          <td><code>recordingDetails.recordingDate</code></td>
          <td><code class="apitype">datetime</code></td>
          <td>The date and time when the video was recorded. The value is specified in <a href="//www.w3.org/TR/NOTE-datetime">ISO 8601</a> (<code>YYYY-MM-DDThh:mm:ss.sZ</code>) format.</td>
        </tr>
      </tbody>
    </table>
  </li>
  <li>
    <p>The documentation for several API methods now identifies properties that must be specified in the request body or that are updated based on values in the request body. The table below lists those methods as well as the required or modifiable properties.</p>
    <p class="note"><strong>Note:</strong> Documentation for other methods may already list required and modifiable properties.</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Method</th>
          <th>Properties</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/activities/insert">activities.insert</a></code></td>
          <td class="error-name"><strong>Required properties:</strong><ul><li><code>snippet.description</code></li></ul><strong>Modifiable properties:</strong><ul><li><code>snippet.description</code></li><li><code>contentDetails.bulletin.resourceId</code></li></ul></td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlists/update">playlists.update</a></code></td>
          <td class="error-name"><strong>Required properties:</strong><ul><li><code>id</code></li></ul></td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/update">playlistItems.update</a></code></td>
          <td class="error-name"><strong>Required properties:</strong><ul><li><code>id</code></li></ul></td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videos/update">videos.update</a></code></td>
          <td class="error-name"><strong>Required properties:</strong><ul><li><code>id</code></li></ul></td>
        </tr>
      </tbody>
    </table>
  </li>

  <li>
    <p>The API no longer reports a <code>playlistAlreadyExists</code> error if you try to <a href="https://developers.google.com/youtube/v3/docs/playlists/insert">create</a> or <a href="https://developers.google.com/youtube/v3/docs/playlists/update">update</a> a playlist that would have the same title as a playlist that already exists in the same channel.</p>
  </li>
  <li>
    <p>Several API methods support new error types. The table below identifies the method and the newly supported errors:</p>
    <table class="matchpre" id="property-table">
      <thead>
        <tr>
          <th>Method</th>
          <th>Error type</th>
          <th>Error detail</th>
          <th>Description</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/guideCategories/list">guideCategories.list</a></code></td>
          <td class="error-name"><code>notFound</code></td>
          <td class="error-reason"><code>notFound</code></td>
          <td class="error-cause">The guide category identified by the <code>id</code> parameter cannot be found. Use the <a href="https://developers.google.com/youtube/v3/docs/guideCategories/list">guideCategories.list</a> method to retrieve a list of valid values.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/playlistItems/delete">playlistItems.delete</a></code></td>
          <td class="error-name"><code>forbidden</code></td>
          <td class="error-reason"><code>playlistItemsNotAccessible</code></td>
          <td class="error-cause">The request is not properly authorized to delete the specified playlist item.</td>
        </tr>
        <tr>
          <td><code><a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a></code></td>
          <td class="error-name"><code>notFound</code></td>
          <td class="error-reason"><code>videoCategoryNotFound</code></td>
          <td class="error-cause">The video category identified by the <code>id</code> parameter cannot be found. Use the <a href="https://developers.google.com/youtube/v3/docs/videoCategories/list">videoCategories.list</a> method to retrieve a list of valid values.</td>
        </tr>
      </tbody>
    </table>
  </li>
</ul>]]>
  </content>
  </entry>
</feed>
