Skip to main content

A package integrating loguru and apprise for logging and notifications

Project description

Logprise

Logprise is a Python package that seamlessly integrates loguru and apprise to provide unified logging and notification capabilities. It allows you to automatically send notifications when specific log levels are triggered, making it perfect for monitoring applications and getting alerts when important events occur.

Features

  • Unified logging interface that captures both standard logging and loguru logs
  • Automatic notification delivery based on configurable log levels
  • Batched notifications to prevent notification spam
  • Flexible configuration through apprises extensive notification service support
  • Periodic flushing of log messages at configurable intervals
  • Automatic capture of uncaught exceptions
  • Easy integration with existing Python applications

Installation

pip install logprise

Or if you're using Poetry:

poetry add logprise

Quick Start

Here's a simple example of how to use Logprise:

from logprise import logger

# Your logs will automatically trigger notifications
logger.info("This won't trigger a notification")
logger.warning("This won't trigger a notification")
logger.error("This will trigger a notification")  # Default is ERROR level

# Notifications are automatically sent when your program exits
# or periodically according to the flush interval

Configuration

Notification Services

Logprise uses Apprise for notifications, which supports a wide range of notification services. You can configure these in two ways:

1. Configuration File

Create an .apprise file in one of the default configuration paths:

  • ~/.apprise [or %APPDATA%/Apprise/apprise]
  • ~/.config/apprise [or %LOCALAPPDATA%/Apprise/apprise]
  • '/etc/apprise' [or %ALLUSERSPROFILE%/Apprise/apprise]

For more possible configuration file locations, please check: DEFAULT_CONFIG_PATHS in apprises source code.

Example configuration:

mailto://user:pass@gmail.com
tgram://bot_token/chat_id
slack://tokenA/tokenB/tokenC/#channel

2. Programmatically Add Services

You can easily add more notification services programmatically:

from logprise import appriser

# Add a single URL
appriser.add("mailto://user:pass@gmail.com")

# Add multiple URLs
appriser.add(["tgram://bot_token/chat_id", "slack://tokenA/tokenB/tokenC/#channel"])

# Add URLs with tags
appriser.add("discord://webhook_id/webhook_token", tag=["critical"])

See Apprise's configuration guide for the full list of supported services and their configuration.

Notification Levels

You can set the minimum log level that triggers notifications:

from logprise import appriser, logger

# Using string level names
appriser.notification_level = "WARNING"  # or "DEBUG", "INFO", "ERROR", "CRITICAL"

# Using integer level numbers
appriser.notification_level = 30  # WARNING level

# Using loguru Level objects
appriser.notification_level = logger.level("ERROR")

Controlling Notification Timing

Logprise offers several ways to control when notifications are sent:

from logprise import appriser

# Set the flush interval for periodic notifications (in seconds)
appriser.flush_interval = 3600  # Default is hourly

# Manually send notifications immediately
appriser.send_notification()

# Clear the notification buffer
appriser.buffer.clear()

# Stop the periodic flush thread
appriser.stop_periodic_flush()

# Manually cleanup and flush pending notifications
appriser.cleanup()

Handling Uncaught Exceptions

Logprise automatically captures uncaught exceptions and sends notifications. This helps you detect and respond to unexpected application failures:

# This will be logged and trigger a notification
raise ValueError("Something went wrong")

Contributing

To contribute to the project:

# Clone the repository
git clone https://github.com/yourusername/logprise.git
cd logprise

# Install dependencies
poetry install

# Run tests
poetry run pytest

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - 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

logprise-1.3.1.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

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

logprise-1.3.1-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file logprise-1.3.1.tar.gz.

File metadata

  • Download URL: logprise-1.3.1.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for logprise-1.3.1.tar.gz
Algorithm Hash digest
SHA256 5547d8f20731c361280d6e972ff58b2d05bf8c769cbcc780392a85cd41fa51bb
MD5 897bdf5f0bf3f5563e93101f6346ee67
BLAKE2b-256 b0bf5987ff97bab5bb64d7840302ae57d7def54a02d04f0128113852662b4673

See more details on using hashes here.

Provenance

The following attestation bundles were made for logprise-1.3.1.tar.gz:

Publisher: release.yml on svaningelgem/logprise

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

File details

Details for the file logprise-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: logprise-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for logprise-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a5fe3c382c2e606a1d610010f87ce235e80dc36839dde5c3ea2f0b319bf0b35c
MD5 dfe5d5202de37bcbb57008e62d3a0604
BLAKE2b-256 1ed5c012bc67f4fd60cfb8ee9ecddd22a90051c2bd66b7ec4296fb20bc71ff3b

See more details on using hashes here.

Provenance

The following attestation bundles were made for logprise-1.3.1-py3-none-any.whl:

Publisher: release.yml on svaningelgem/logprise

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