> ## Documentation Index
> Fetch the complete documentation index at: https://nango.dev/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# YouTube

> Integrate your application with the YouTube API

## 🚀 Quickstart

Connect to YouTube with Nango and see data flow in 2 minutes.

<Steps>
  <Step title="Create the integration">
    In Nango ([free signup](https://app.nango.dev)), go to [Integrations](https://app.nango.dev/dev/integrations) -> *Configure New Integration* -> *YouTube*.

    <Note>
      Nango has credentials you can use for testing. Activate them in the dashboard.
    </Note>
  </Step>

  <Step title="Authorize YouTube">
    Go to [Connections](https://app.nango.dev/dev/connections) -> *Add Test Connection* -> *Authorize*, then log in to YouTube. Later, you'll let your users do the same directly from your app.
  </Step>

  <Step title="Call the YouTube API">
    Let's make your first request to the YouTube API (fetch channel information). Replace the placeholders below with your [secret key](https://app.nango.dev/dev/environment-settings), [integration ID](https://app.nango.dev/dev/integrations), and [connection ID](https://app.nango.dev/dev/connections):

    <Tabs>
      <Tab title="cURL">
        ```bash theme={null}
        curl "https://api.nango.dev/proxy/youtube/v3/channels?part=snippet&mine=true" \
          -H "Authorization: Bearer <NANGO-SECRET-KEY>" \
          -H "Provider-Config-Key: <INTEGRATION-ID>" \
          -H "Connection-Id: <CONNECTION-ID>"
        ```
      </Tab>

      <Tab title="Node">
        Install Nango's backend SDK with `npm i @nangohq/node`. Then run:

        ```typescript theme={null}
        import { Nango } from '@nangohq/node';

        const nango = new Nango({ secretKey: '<NANGO-SECRET-KEY>' });

        const res = await nango.get({
            endpoint: '/youtube/v3/channels',
            params: { part: 'snippet', mine: true },
            providerConfigKey: '<INTEGRATION-ID>',
            connectionId: '<CONNECTION-ID>'
        });

        console.log(JSON.stringify(res.data, 2, null));
        ```
      </Tab>
    </Tabs>

    Or fetch credentials with the [Node SDK](/reference/sdks/node#get-a-connection-with-credentials) or [API](/reference/api/connection/get).

    ✅ You're connected! Check the [Logs](https://app.nango.dev/dev/logs) tab in Nango to inspect requests.
  </Step>

  <Step title="Implement Nango in your app">
    Follow our [Auth implementation guide](/guides/primitives/auth) to integrate Nango in your app.

    To obtain your own production credentials, follow the setup guide linked below.
  </Step>
</Steps>

## 📚 YouTube Integration Guides

Nango maintained guides for common use cases.

* [How to register your own YouTube OAuth app](/api-integrations/youtube/how-to-register-your-own-youtube-api-oauth-app)\
  Register an OAuth app with YouTube and obtain credentials to connect it to Nango

Official docs: [YouTube API documentation](https://developers.google.com/youtube/v3/docs)

## 🧩 Pre-built syncs & actions for YouTube

Enable them in your dashboard. Extend and customize to fit your needs.

### Captions

| Function name   | Description                              | Type                                         | Source code                                                                                                           |
| --------------- | ---------------------------------------- | -------------------------------------------- | --------------------------------------------------------------------------------------------------------------------- |
| `list-captions` | List caption tracks for a YouTube video. | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/list-captions.ts) |

### Channels

| Function name | Description                                                       | Type                                         | Source code                                                                                                         |
| ------------- | ----------------------------------------------------------------- | -------------------------------------------- | ------------------------------------------------------------------------------------------------------------------- |
| `get-channel` | Retrieve YouTube channel details by ID, handle, username, or mine | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/get-channel.ts) |

### Comments

| Function name          | Description                                                      | Type                                         | Source code                                                                                                                  |
| ---------------------- | ---------------------------------------------------------------- | -------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| `create-comment-reply` | Reply to an existing YouTube comment                             | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/create-comment-reply.ts) |
| `create-comment`       | Create a top-level comment on a YouTube video or channel thread. | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/create-comment.ts)       |
| `delete-comment`       | Delete a YouTube comment by comment ID                           | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/delete-comment.ts)       |
| `get-comment`          | Retrieve a YouTube comment by comment ID.                        | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/get-comment.ts)          |
| `list-comment-threads` | List YouTube comment threads for a video or channel.             | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/list-comment-threads.ts) |
| `update-comment`       | Update the text of a YouTube comment.                            | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/update-comment.ts)       |

### Playlists

| Function name            | Description                                              | Type                                         | Source code                                                                                                                    |
| ------------------------ | -------------------------------------------------------- | -------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ |
| `add-playlist-item`      | Add a video to a YouTube playlist                        | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/add-playlist-item.ts)      |
| `create-playlist`        | Create a YouTube playlist for the authenticated channel. | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/create-playlist.ts)        |
| `delete-playlist-item`   | Remove an item from a YouTube playlist                   | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/delete-playlist-item.ts)   |
| `delete-playlist`        | Delete a YouTube playlist by playlist ID                 | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/delete-playlist.ts)        |
| `get-playlist`           | Retrieve a YouTube playlist by playlist ID.              | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/get-playlist.ts)           |
| `list-channel-playlists` | List playlists for a YouTube channel                     | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/list-channel-playlists.ts) |
| `list-playlist-items`    | List items in a YouTube playlist                         | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/list-playlist-items.ts)    |
| `update-playlist`        | Update a YouTube playlist's metadata or privacy state    | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/update-playlist.ts)        |

### Videos

| Function name          | Description                                                    | Type                                         | Source code                                                                                                                  |
| ---------------------- | -------------------------------------------------------------- | -------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| `delete-video`         | Delete a YouTube video owned by the authenticated channel.     | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/delete-video.ts)         |
| `get-video`            | Retrieve a YouTube video by video ID                           | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/get-video.ts)            |
| `list-uploaded-videos` | List uploaded videos for a channel using its uploads playlist. | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/list-uploaded-videos.ts) |
| `update-video`         | Update YouTube video metadata for an owned video.              | [Action](/guides/functions/action-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/update-video.ts)         |

### Others

| Function name          | Description                                                  | Type                                           | Source code                                                                                                                  |
| ---------------------- | ------------------------------------------------------------ | ---------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| `update-playlist-item` | Update a playlist item's metadata or position.               | [Action](/guides/functions/action-functions)   | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/actions/update-playlist-item.ts) |
| `caption-tracks`       | Sync caption track metadata for YouTube videos in scope      | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/caption-tracks.ts)         |
| `channel-playlists`    | Sync playlists for YouTube channels in scope                 | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/channel-playlists.ts)      |
| `channels`             | Sync one or more YouTube channels in scope                   | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/channels.ts)               |
| `comment-threads`      | Sync comment threads for YouTube videos or channels in scope | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/comment-threads.ts)        |
| `playlist-items`       | Sync items from YouTube playlists in scope                   | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/playlist-items.ts)         |
| `uploaded-videos`      | Sync uploaded videos for YouTube channels in scope           | [Sync](/guides/functions/syncs/sync-functions) | [🔗 Github](https://github.com/NangoHQ/integration-templates/blob/main/integrations/youtube/syncs/uploaded-videos.ts)        |

***
