Skip to main content

Fetches new YouTube channel playlist content from RSS with automatic fallback to the YouTube API.

Project description

youtube-notify

youtube-notify is a small Python library for fetching recent content from a YouTube channel. It prefers the channel RSS feed first and falls back to the YouTube Data API when RSS does not return content. The library returns typed Content models with channel metadata, timestamps, thumbnails, and descriptions.

Features

  • RSS-first content retrieval with YouTube API fallback
  • Optional YouTube API key and OAuth helpers
  • Pydantic models for downstream validation and serialization
  • Async-friendly public APIs
  • Mocked integration tests for deterministic CI runs

Installation

This repository uses a src/ layout, so the simplest way to work with it directly is to clone the repo, install the dependencies, and run commands with src/ on PYTHONPATH.

git clone https://github.com/jnstockley/youtube-notify.git
cd youtube-notify
uv sync
export PYTHONPATH=src

If you are using another virtual environment tool, install the dependencies from pyproject.toml and make sure the project root is on your import path in the same way.

Setup

  1. Clone the repository.
  2. Create and activate a Python 3.14 environment.
  3. Install dependencies with uv sync or your preferred environment manager.
  4. Set PYTHONPATH=src when running the library directly from the repository.
  5. If you want to use the YouTube API fallback, provide an API key or OAuth credentials in your own application code.

Usage

The main entry point is content_fetcher.get_content(channel_id, youtube=None). It tries RSS first and only uses the YouTube API client if RSS returns no content.

Basic usage

import asyncio

from content_fetcher import get_content


async def main() -> None:
    content = await get_content("UCxxxxxxxxxxxxxxxxxxxxxx")
    for item in content:
        print(item.title)


asyncio.run(main())

Using a YouTube API key

If you already have a YouTube Data API key, build a client with youtube.auth.api_key.authenticate() and pass it to content_fetcher.get_content().

import asyncio

from content_fetcher import get_content
from youtube.auth.api_key import authenticate


async def main() -> None:
    youtube = authenticate("YOUR_YOUTUBE_API_KEY")
    content = await get_content("UCxxxxxxxxxxxxxxxxxxxxxx", youtube)
    for item in content:
        print(item.title)


asyncio.run(main())

Using OAuth credentials

If you need OAuth-based access, the OAuth helper can build credentials and refresh them before creating the client.

from youtube.auth.oauth import authenticate, device_code_flow


creds = device_code_flow("YOUR_CLIENT_ID", "YOUR_CLIENT_SECRET")
youtube = authenticate(creds)

Required Environment Variables

The library itself does not require API credentials from environment variables. The only runtime environment settings used by the code are for logging:

  • LOG_LEVEL: optional, defaults to INFO
  • LOG_DIR: optional, defaults to ../logs

The repository also includes sample.env with example values for a wrapper application:

  • YOUTUBE_API_KEY
  • GOOGLE_CLIENT_ID
  • GOOGLE_CLIENT_SECRET

Those are not read automatically by the library; they are intended for your own application or deployment scripts.

If your application uses the YouTube API path through youtube.youtube.get_content() or passes a client into content_fetcher.get_content(), you must provide one of the following sets of credentials in your application layer:

  • YOUTUBE_API_KEY
  • GOOGLE_CLIENT_ID and GOOGLE_CLIENT_SECRET

Development

Common local commands:

uv run pytest
uv run pytest -m integration
uv run ruff check
uv run ruff format --check

The integration test suite is mocked and does not make live network calls.

Project Structure

  • src/content_fetcher.py: top-level RSS-first content fetcher
  • src/rss/rss.py: RSS feed fetching and parsing
  • src/youtube/youtube.py: YouTube API fetching and parsing
  • src/youtube/auth/: API key and OAuth helpers
  • src/models.py: Pydantic models used across the library

Operational Notes

  • The library writes logs to LOG_DIR/app.log.
  • If you run the code in a container or read-only environment, set LOG_DIR to a writable path.
  • The public APIs are asynchronous, so call them from asyncio code or wrap them with asyncio.run().

Contributing

Contributions are expected to keep the repository green.

Before opening a pull request:

  • All tests must pass.
  • Code coverage for updated code should be at least 90%.
  • The existing linting steps must pass.
  • Any public behavior change should include matching tests.

Recommended validation commands:

uv run pytest
uv run pytest --cov src --cov-branch --cov-report=term-missing
uv run ruff check
uv run ruff format --check

License

This project is licensed under the GNU General Public License v3.0. See the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

youtube_notify-1.0.0rc1.tar.gz (26.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

youtube_notify-1.0.0rc1-py3-none-any.whl (25.9 kB view details)

Uploaded Python 3

File details

Details for the file youtube_notify-1.0.0rc1.tar.gz.

File metadata

  • Download URL: youtube_notify-1.0.0rc1.tar.gz
  • Upload date:
  • Size: 26.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for youtube_notify-1.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 0f85460f1a597a316d87682830a44a1600c0e8c12cc71d718aa1f0998b335be2
MD5 4d7b3dc7b1b4350f4c4c4eac04707cd4
BLAKE2b-256 061cf77f8c09bd76d95d9116f46ea6bf458761333a9c80026f5d9cab1589b109

See more details on using hashes here.

Provenance

The following attestation bundles were made for youtube_notify-1.0.0rc1.tar.gz:

Publisher: ci-cd.yml on jnstockley/youtube-notify

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file youtube_notify-1.0.0rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for youtube_notify-1.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 0ae944e85d752439a06b6674cbd4842e8a2e3b666bf8295d1340cc3fb8471f4f
MD5 66a456f796ddffcb39246461a56eb3ff
BLAKE2b-256 f4b0c7d3b229a69431a8557c8257c24fd6e14e8517b20a7eb5ac1feee7b17b25

See more details on using hashes here.

Provenance

The following attestation bundles were made for youtube_notify-1.0.0rc1-py3-none-any.whl:

Publisher: ci-cd.yml on jnstockley/youtube-notify

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page