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.1.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.1-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: henriqueslab_updater-1.1.1.tar.gz
  • Upload date:
  • Size: 29.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for henriqueslab_updater-1.1.1.tar.gz
Algorithm Hash digest
SHA256 b5fe6c39bb458a7c83f43c7b4402377d8f98e335486f719011b39f9518890472
MD5 aec0742794dd00f780207ce36961d643
BLAKE2b-256 f7d209e977a000a709fa3d72304675935f7b02dda931d8469f43a3a3150b002b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for henriqueslab_updater-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 007a9291d83c7ed2bdc7e20905776c0dad4219db6b9f951dd2c74981b20d736a
MD5 74469c4835559927fb4cc5fe293da430
BLAKE2b-256 f589172942818886b278efc3a20ea93d2222c42c0011ff166d70d7ccde4f8e77

See more details on using hashes here.

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