Skip to main content

Collaborative, beautiful logging system for distributed developers

Project description

🧠 LogMachine

Collaborative, beautiful logging system for distributed developers

logmachine helps teams log smarter. It’s a fully pluggable logging system that supports colored output, JSON parsing, structured log forwarding via HTTP or Socket.IO, and log centralization — all from a standard Python logging interface.


🚀 Features

  • 🔥 Color-coded terminal logs (DEBUG, INFO, WARNING, ERROR, SUCCESS)
  • 📤 Log forwarding to a central HTTP or Socket.IO server
  • 🪵 Custom log levels (add your own with .new_level(...))
  • 👥 User identity tracking for team-based logs
  • 🧩 Pluggable backends: send logs to a central server or local files
  • 📦 Simple JSON output for web dashboards or collectors
  • 🧽 Strips ANSI escape codes from logs for clean parsing
  • 🧠 Automatically resolves usernames and saves them in ~/.cl_username

⚙️ Installation

pip install logmachine

🧰 Usage

Basic Setup

from logmachine import LogMachine

# Create a simple logger without central logging
# Providing a non-empty string initializes the logger with that name, else the root logger is used to collect every single log in the python process.
logger = LogMachine("myapp", debug_level=1)

logger.info("Hello, world!")
logger.error("An error occurred!")
logger.success("Operation completed successfully!")
logger.debug("Debugging information here.")
logger.warning("This is a warning message.")

With Central Logging (HTTP or Socket.IO)

You can use the default logger with central logging pointing to "https://logmachine.bufferpunk.com"

from logmachine import default_logger
logger = default_logger()
logger.info("This log is sent to the LogMachine default central server!")

This is the default central logging server for logmachine, and you can create your own room there for free. To use your own central logging server, provide the configuration as shown below:

logger_config = {
    "url": "https://logmachine.bufferpunk.com",  # Base server URL
    "room": "team_alpha",                # Your organization or room
    "endpoint": "/api/logs",             # Optional, defaults to /api/logs
    "headers": {"Authorization": "Bearer token"},
    "socketio": True,                    # Set False to use HTTP
    "socketio_path": "/api/socket.io/"  # Optional
}
logger = LogMachine("with_central", debug_level=0, central=logger_config, socketio=True)
logger.success("Central logging is working!")

🎨 Log Format

Every log includes:

  • ✅ Username (resolved automatically or via server)
  • 📁 Module directory
  • ⏱️ Timestamp
  • 📦 Level (INFO, ERROR, etc.)
  • 📝 Message

Sample (terminal):

(username @ myapp) 🤌 CL Timing: [ 2025-08-04T11:23:52 ]
[ INFO ] Server started on port 8000
🏁

🛠️ Advanced

Add Your Own Log Level

logger.new_level("CRITICAL_HACK", 60)
logger.new_level("CRITICAL_HACK", 60, color="\033[38;5;13m")  # Optional color... does your girlfriend love pink? Maybe you should be in a relationship with your terminal.
logger.critical_hack("Zero day found!")

📤 Parse & Export

Convert Logs to JSON

This is useful for sending logs to web dashboards or log collectors that expect JSON. It reads the your log files, parses the log entries, and outputs them as JSON objects.

json_logs = log.jsonifier()
for entry in json_logs:
    print(entry)

📡 Central Server Compatibility

To use Socket.IO, your central server must support these events:

  • log: Receives log payloads: { room: string, data: object }
  • GET /api/get_username?base=localname: Returns { "username": "..." }

🤖 Environment Variables

  • CL_USERNAME: Manually override detected username
  • Automatically stored in ~/.cl_username for persistent identity

🔐 Security

  • HTTP headers (e.g. Authorization) can be injected
  • Central log transmission is fully customizable

🔧 Configuration Summary

Param Type Description
url str Central server base URL
room str Logical group or org name
endpoint str HTTP endpoint for POST logs (default: /api/logs)
headers dict Extra headers to send (e.g. auth token)
socketio bool Whether to use Socket.IO instead of HTTP
socketio_path str Path to socket.io on the server

📄 License

MIT License


🙋‍♂️ Author

Mugabo Gusenga logmachine.bufferpunk.com GitHub


❤️ Contribute

PRs and issues are welcome! This tool is built for devs who want beautiful logs with distributed brains. Let’s make debugging fun again.

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

logmachine-2.2.0.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.

logmachine-2.2.0-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file logmachine-2.2.0.tar.gz.

File metadata

  • Download URL: logmachine-2.2.0.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for logmachine-2.2.0.tar.gz
Algorithm Hash digest
SHA256 bb0fbcdd55abb7728f27d4caaf02d0c5af3475830a8bde5fca8d572aa584cf21
MD5 acf49b97995007bbe9da252e2d69cc79
BLAKE2b-256 aa3c0c37189409af40368e21526c5cf8737cd5cce67ec393c1eb90fa1d5493f0

See more details on using hashes here.

File details

Details for the file logmachine-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: logmachine-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for logmachine-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7b6d658624a80e91d0608c72be87c4550876b99fb803ee4e3a3da5fae8d72375
MD5 10edfe5a2e2a32935ae8eafe877122dd
BLAKE2b-256 4f4ffc0754ec03a974d3bb6d28a83259433785638cb0d1df7f1ba3d8884b5ad0

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