Skip to main content

Centralized update checking library for HenriquesLab Python packages

Project description

henriqueslab-updater

Centralized update checking library for HenriquesLab Python packages.

Features

  • Multi-source version checking: PyPI, Homebrew, GitHub formulas
  • Installation method detection: Automatically detects Homebrew, pipx, uv, pip (user/system), and development installations
  • Smart caching: 24-hour TTL to avoid excessive network requests
  • Non-blocking: Background checks that don't disrupt CLI execution
  • Pluggable architecture: Customizable version sources, notifiers, and plugins
  • Optional changelog integration: Display changelog highlights in update notifications
  • Minimal dependencies: Only packaging required, optional rich and httpx for enhanced features

Installation

pip install henriqueslab-updater

With optional dependencies:

pip install henriqueslab-updater[all]  # includes rich and httpx
pip install henriqueslab-updater[rich]  # just rich formatting

Quick Start

from henriqueslab_updater import UpdateChecker

# Simple usage
checker = UpdateChecker(
    package_name="your-package",
    current_version="1.0.0",
)

# Start background check (non-blocking)
checker.check_async()

# Later, show notification if available
checker.show_notification()

Advanced Usage

from henriqueslab_updater import (
    UpdateChecker,
    ChangelogPlugin,
    RichNotifier,
)

checker = UpdateChecker(
    package_name="your-package",
    current_version="1.0.0",
    notifier=RichNotifier(title="Update Available"),
    plugins=[
        ChangelogPlugin(
            changelog_url="https://raw.githubusercontent.com/org/repo/main/CHANGELOG.md",
            highlights_per_version=3,
        ),
    ],
)

checker.check_async()
checker.show_notification()

Supported Installation Methods

  • Homebrew (brew)
  • pipx
  • uv tools
  • pip (user and system installs)
  • Development (git clone + editable install)

Configuration

Environment variables:

  • NO_UPDATE_NOTIFIER=1 - Disable all update checks
  • {PACKAGE}_NO_UPDATE_CHECK=1 - Disable for specific package

License

MIT License - see LICENSE file for details.

Development

git clone https://github.com/HenriquesLab/henriqueslab-updater.git
cd henriqueslab-updater
python3 -m venv .venv
source .venv/bin/activate
pip install -e ".[all,dev]"
pytest

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

henriqueslab_updater-1.1.2.tar.gz (29.5 kB view details)

Uploaded Source

Built Distribution

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

henriqueslab_updater-1.1.2-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

Details for the file henriqueslab_updater-1.1.2.tar.gz.

File metadata

  • Download URL: henriqueslab_updater-1.1.2.tar.gz
  • Upload date:
  • Size: 29.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for henriqueslab_updater-1.1.2.tar.gz
Algorithm Hash digest
SHA256 9a90e6256744cb8c718eccd9b9680d7cce345b2811e91ee49ed1205c342e1bcb
MD5 eb4933459b51b986a4670f71791a1860
BLAKE2b-256 14bac57b3e5247477c19e5515fe74c64dc5a6054c4c904b76e0a28bf45c59618

See more details on using hashes here.

Provenance

The following attestation bundles were made for henriqueslab_updater-1.1.2.tar.gz:

Publisher: publish-to-pypi.yml on HenriquesLab/henriqueslab-updater

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

File details

Details for the file henriqueslab_updater-1.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for henriqueslab_updater-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 284a63e31010768ee6861b8b2f666dc6d9f7589004a11047388138e55904006f
MD5 ae965a190eb54d8c6187ba9a5b377889
BLAKE2b-256 cab4d9638d5020a263d0163602dea92af8c857859a735321042f433d608b9579

See more details on using hashes here.

Provenance

The following attestation bundles were made for henriqueslab_updater-1.1.2-py3-none-any.whl:

Publisher: publish-to-pypi.yml on HenriquesLab/henriqueslab-updater

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