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_usernamefor 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file logmachine-2.3.0.tar.gz.
File metadata
- Download URL: logmachine-2.3.0.tar.gz
- Upload date:
- Size: 8.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b58efe0b62dd5eed592e56b5a7d74d01ae998526cec6b0f531a25f35e7cbdae
|
|
| MD5 |
ce70c1a160d4adb29ee1d9e1177a72db
|
|
| BLAKE2b-256 |
f369500b4199c277bd7e7f3bab23ae3ebdb381ac4e042bc9efe3524521b1baee
|
File details
Details for the file logmachine-2.3.0-py3-none-any.whl.
File metadata
- Download URL: logmachine-2.3.0-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e1817fb4d91166e4ab28e53ea100b93692597985dbc530e1eced78285845b621
|
|
| MD5 |
52025f05f1d918ab2165613fe20e8b11
|
|
| BLAKE2b-256 |
1cdfe3386f7e733f64209ef4b45eb3b2848647638f3fce6e406442c080b9026d
|