Skip to main content

Official Python SDK for Logwell logging platform

Project description

Logwell Python SDK

Official Python SDK for the Logwell logging platform.

Installation

pip install logwell

Quick Start

import asyncio
from logwell import Logwell

# Initialize client
client = Logwell({
    'api_key': 'lw_aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
    'endpoint': 'https://logs.example.com',
    'service': 'my-app',
})

# Log messages at different levels
client.debug('Debug message')
client.info('User logged in', {'user_id': '123'})
client.warn('Disk space low', {'available_gb': 5})
client.error('Failed to process request', {'request_id': 'abc'})
client.fatal('Database connection lost')

# Ensure logs are sent before exit
asyncio.run(client.shutdown())

Configuration

Option Type Default Description
api_key str required API key in format lw_[32 chars]
endpoint str required Logwell server URL
service str None Default service name for all logs
batch_size int 50 Number of logs to batch before auto-flush
flush_interval float 5.0 Seconds between auto-flushes
max_queue_size int 1000 Maximum queue size before dropping oldest
max_retries int 3 Retry attempts for failed requests
capture_source_location bool False Capture file/line info
on_error Callable None Error callback
on_flush Callable None Flush callback

Example with all options

from logwell import Logwell

def on_error(err):
    print(f'Logging error: {err}')

def on_flush(count):
    print(f'Flushed {count} logs')

client = Logwell({
    'api_key': 'lw_aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
    'endpoint': 'https://logs.example.com',
    'service': 'my-app',
    'batch_size': 100,
    'flush_interval': 10.0,
    'max_queue_size': 5000,
    'max_retries': 5,
    'capture_source_location': True,
    'on_error': on_error,
    'on_flush': on_flush,
})

API Reference

Logwell

The main client class.

Constructor

Logwell(config: LogwellConfig)

Methods

Method Description
debug(message, metadata=None) Log at debug level
info(message, metadata=None) Log at info level
warn(message, metadata=None) Log at warning level
error(message, metadata=None) Log at error level
fatal(message, metadata=None) Log at fatal level
log(entry) Log with explicit LogEntry
flush() Async: Flush queued logs immediately
shutdown() Async: Flush and stop the client
child(metadata=None, service=None) Create child logger with context
queue_size Property: Current queue size

Child Loggers

Create child loggers to add persistent context:

# Create child logger with request context
request_logger = client.child({'request_id': 'abc-123'})
request_logger.info('Processing request')  # Includes request_id

# Override service name
db_logger = client.child(service='my-app-db')
db_logger.info('Query executed', {'duration_ms': 45})

Log Entry

from logwell import LogLevel

# Using log() with explicit entry
client.log({
    'level': 'info',
    'message': 'Custom log',
    'metadata': {'key': 'value'},
    'service': 'override-service',
    'timestamp': '2024-01-01T00:00:00Z',  # Optional, auto-generated
})

LogLevel

Available log levels: debug, info, warn, error, fatal

LogwellConfig

TypedDict with configuration options. See Configuration section above.

IngestResponse

Response from the server after flushing logs:

{
    'accepted': 50,      # Logs accepted
    'rejected': 0,       # Logs rejected (optional)
    'errors': [],        # Error messages (optional)
}

Error Handling

LogwellError

All SDK errors are wrapped in LogwellError:

from logwell import Logwell, LogwellError, LogwellErrorCode

try:
    client = Logwell({'api_key': 'invalid', 'endpoint': 'https://example.com'})
except LogwellError as e:
    print(e.message)      # Human-readable message
    print(e.code)         # LogwellErrorCode enum
    print(e.status_code)  # HTTP status (if applicable)
    print(e.retryable)    # Whether operation can be retried

Error Codes

Code Description
INVALID_CONFIG Invalid configuration value
NETWORK_ERROR Network connectivity or timeout
UNAUTHORIZED Invalid or expired API key (401)
VALIDATION_ERROR Invalid request data
RATE_LIMITED Too many requests (429)
SERVER_ERROR Server-side error (5xx)
QUEUE_OVERFLOW Queue exceeded max size

Error Callback

Handle errors without try/catch:

def handle_error(err: Exception):
    if isinstance(err, LogwellError):
        if err.code == LogwellErrorCode.NETWORK_ERROR:
            print('Network issue, logs will be retried')
        elif err.code == LogwellErrorCode.QUEUE_OVERFLOW:
            print('Queue full, some logs dropped')

client = Logwell({
    'api_key': 'lw_aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
    'endpoint': 'https://logs.example.com',
    'on_error': handle_error,
})

Async Usage

The SDK uses async for flush and shutdown operations:

import asyncio
from logwell import Logwell

async def main():
    client = Logwell({
        'api_key': 'lw_aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
        'endpoint': 'https://logs.example.com',
    })

    client.info('Starting app')

    # Manual flush
    response = await client.flush()
    print(f'Sent {response["accepted"]} logs')

    # Shutdown gracefully
    await client.shutdown()

asyncio.run(main())

Source Location Capture

Enable automatic file/line capture:

client = Logwell({
    'api_key': 'lw_aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
    'endpoint': 'https://logs.example.com',
    'capture_source_location': True,
})

client.info('This log includes file and line number')
# Log includes: source_file='app.py', line_number=42

Requirements

  • Python 3.9+
  • httpx >= 0.25.0

License

MIT License - see LICENSE 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

logwell-0.1.4.tar.gz (87.4 kB view details)

Uploaded Source

Built Distribution

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

logwell-0.1.4-py3-none-any.whl (17.3 kB view details)

Uploaded Python 3

File details

Details for the file logwell-0.1.4.tar.gz.

File metadata

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

File hashes

Hashes for logwell-0.1.4.tar.gz
Algorithm Hash digest
SHA256 635d2244fdf9ae574f0db8f1dae4b6df190cb62e4f4c6ea86efe57667b4b6533
MD5 c58b9bc960baa70898768a6cdf94185f
BLAKE2b-256 3439775180c4cf6f08e6d1f0b007482bf8d0150ca0b46e174c5668ea715ab1b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for logwell-0.1.4.tar.gz:

Publisher: sdk-python.yml on Divkix/Logwell

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

File details

Details for the file logwell-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: logwell-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 17.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for logwell-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e683ab32c239571dfa29422a515cb7e8167891aebae82f74f5ca51b3468822f0
MD5 c6d62c9f8cf576fc0856488db290d2a9
BLAKE2b-256 8472936e61b186e15b07cc75ed55cc91e9edc3164641d4d55cc72099ed96fb2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for logwell-0.1.4-py3-none-any.whl:

Publisher: sdk-python.yml on Divkix/Logwell

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