@sugarcube/plugin-youtube
v0.42.1
Published
A SugarCube plugin to fetch videos from Youtube.
Downloads
9
Maintainers
Readme
@sugarcube/plugin-youtube
A plugin for SugarCube that fetches video and channel data from youtube.
Requirements
A Youtube API key is required to use these plugins. To obtain one follow those steps:
- Use your existing Google account, or create a new account.
- Go to the Developers Console and login with your account.
- First create a new project. Click on
Select a Project
and then click onNew Project
. - Select the newly created project, and as a next step click on
Enable APIS and Services
. - Select the
Youtube Data API v3
and enable it. - On the Youtube API page click on
Create Credentials
. Select theYoutube Data API v3
to use,Other UI
to use it from and pickPublic Data
on the question what data to access. This will generate an API key for you.
Installation
npm install --save @sugarcube/plugin-youtube
Plugins
youtube_video
Fetch details for an individual video by it's id. It uses the youtube_video
query type. The query can be specified either as the video id (e.g. oMOSiag3dxg
) or as the full URL to the video (e.g. https://www.youtube.com/watch?v=oMOSiag3dxg
).
The Youtube API key must be set as well. You can do this by setting the youtube.api_key
config option:
--youtube.api_key <key>
or setting it in the JSON configuration file:
{
"youtube": {
"api_key": "<key>"
}
}
Metrics:
total
: The total number of Youtube videos fetched.fail
: The number of videos that failed.success
: The number of videos that were successfully fetched.
youtube_channel
Fetch a list of videos from a channel. A query must be configured to supply one or more channel ids.
[
{
"type": "youtube_channel",
"term": "UCJkMlOu7faDgqh4PfzbpLdg"
},
{
"type": "youtube_channel",
"term": "https://www.youtube.com/channel/UC_QIfHvN9auy2CoOdSfMWDw/featured"
}
]
The channel query can be provided either as an id (e.g. UC_QIfHvN9auy2CoOdSfMWDw
) or as the full URL to the channel (e.g. https://www.youtube.com/channel/UC_QIfHvN9auy2CoOdSfMWDw/featured
). The last segment of the channel URL (in this case featured
) is optional. The relevant part is the /channel/<channel-id>
part of the URL.
The Youtube API key must be set as well. You can do this by setting the youtube.api_key
config option:
--youtube.api_key <key>
or setting it in the JSON configuration file:
{
"youtube": {
"api_key": "<key>"
}
}
Other Possible config values are:
{
"youtube": {
"published_before": "2017-06-22",
"published_after": "2017-06-22",
"past_days": 30
}
}
Setting any of these increases performance, but is capped at around 500 video results.
The following example fetches a Youtube channel and downloads all available
videos. It uses the media_youtubedl
plugin.
$(npm bin)/sugarcube -c config.json \
-q channels.json \
-p youtube_channel,media_youtubedl
Metrics:
total
: The total number of Youtube channels queried.fail
: The number of channels that failed.success
: The number of channels that succeeded to download.fetched
: The number of videos that are fetched from the channels.
youtube_filter_failing
This plugin verifies against the Youtube API that each unit that is a Youtube video exists, and returns all failing videos as units in the envelope. It is meant as the first step in a two step process to verify the number of videos that were taken down by Youtube. The output of this plugin can be send straight to the media_youtubedl_check
plugin for a more detailed check.
This plugin doesn't collect missing videos as failures, but it counts the metric.
Configuration:
youtube.api_key
: The API key for Youtube.com. This option is required.
Example:
{
"plugins": [
"elastic_import",
"youtube_filter_failing",
"media_youtubedl_check"
],
"youtube": {
"api_key": "<key>"
},
"queries": [
{"type": "glob_pattern", "term": "./es-queries/all-youtube-videos.json"}
]
}
Metrics:
total
: The total number of Youtube videos queried.fail
: The number of videos that failed. This metric is tracked continuously as it is detected.success
: The number of videos that exist.missing
: The number of videos that failed. This metric is emitted once at the end of the plugin containing the total number of failed videos.
Feature flags
ncube
sets the new and Ncube compatible data format. This is still optional but will become the new default in the future.
$(npm bin)/sugarcube -c config.json \
-Q youtube_channel:UCaLlzGqiPE2QRj6sSOawJRg \
-p youtube_channel \
-D ncube