Open-Source Developer package repository for AuraLogger, a real-time logging and observability SDK and CLI for streaming, storing, searching, and filtering application logs—beautifully visualized and accessible anywhere in the world across terminal, web, and any screen.
Project description
Auralogger for Python (SDK + CLI)
a real-time logging and observability SDK and CLI for streaming, storing, searching, and filtering application logs—beautifully visualized and accessible anywhere in the world across terminal, web, and any screen.
Quick start
Run CLI commands from the directory that contains your .env or .env.local (or wherever you export AURALOGGER_* in the shell or CI). The CLI loads .env files from the current working directory — cd into the app first.
Use a project virtualenv (python -m venv .venv) so the CLI and library version match the repo you are in. Auralogger is project-scoped (credentials per app), not a global “install once and forget which folder you are in” tool.
1) Install
From PyPI:
pip install auralogger
auralogger
2) Run init (credentials + server snippet)
Get private credentials from auralogger.com, then run this in your app repo (where .env should live):
auralogger init
auralogger init walks you through anything missing, prints a copy-paste block for your .env (project token, user secret, session — each line skipped if already set), then prints a small Python module you can drop into your repo (for example your_auralog_file.py) with a ready-made auralog(...) helper .
3) Sanity-check connectivity
Before you sprinkle auralog everywhere, confirm the path works:
auralogger server-check
Optional: send a handful of test logs through the same path your app uses:
auralogger test-serverlog
If token or user secret is missing after .env is loaded, the CLI will prompt before running checks.
4) Send logs from code
Run auralogger init once and paste the printed module, or follow this shape: configure once (reads AURALOGGER_PROJECT_TOKEN and AURALOGGER_USER_SECRET from the environment), then call your helper.
from your_auralog_file import auralog
auralog(
"info",
"Request completed",
"api/orders#create",
{"order_id": "ord_123", "status": 201},
)
# expected: [info] Request completed @ api/orders#create {"order_id": "ord_123", "status": 201}
auralog("warn", "Cache miss")
# expected: [warn] Cache miss
auralog("error", "Payment gateway timeout", data={"provider": "stripe"})
# expected: [error] Payment gateway timeout {"provider": "stripe"}
Important: the logging helper reads **os.environ only** — it does not load .env files by itself. In Django, FastAPI, Celery, etc., load env in your normal startup path (or rely on your host injecting variables).
5) Fetch logs in the terminal
auralogger get-logs -maxcount 20
Each run performs one HTTP request and prints the logs array from that response. Use **-maxcount** (capped at 100 in the CLI) and **-skip** to page manually across separate runs or a small script. Full filter grammar, every field, and examples are in CLI commands (reference) below.
CLI commands (reference)
Subcommands for the auralogger entrypoint, then **get-logs** filters (same grammar as the Node CLI). Environment variable spellings: [user-docs/environment.md](user-docs/environment.md).
Invocation
auralogger <command> [arguments...]
Run auralogger --help to see all commands and options.
Commands (only get-logs takes extra filter tokens)
| Command | Arguments | What it does |
|---|---|---|
init |
— | Prompts for missing AURALOGGER_PROJECT_TOKEN / AURALOGGER_USER_SECRET, prints copy-paste .env lines (token, user secret, session), then a Python server integration snippet with sync_from_secret and auralog(...). |
server-check |
— | One server-side test log over WebSocket; prompts for missing token or user secret if needed. |
test-serverlog |
— | Calls sync_from_secret, sends 5 logs via aura_log, then closes the cached socket. |
get-logs |
[filters...] |
POST to project logs with token + user secret (env or prompt). If styles are not in env, the CLI resolves them for that run so terminal colors match the dashboard when possible. |
get-logs filter grammar
-<field> [--<operator>] <json-value>
- The token after the field name must be valid JSON.
**maxcount** and**skip**: value must be a JSON number.- All other fields: value must be a JSON array.
Paging: one CLI invocation → one request → one page of logs. There is no automatic multi-page loop inside the CLI.
Fields and operators
| Field | Allowed operators | Default operator | Value shape |
|---|---|---|---|
type |
in, not-in |
in |
JSON array of type strings |
message |
contains, not-contains |
contains |
JSON array of substrings |
location |
in, not-in |
in |
JSON array of location strings |
time |
since, from-to |
since |
JSON array (e.g. ["10m"] for since; use from-to with a pair when supported) |
order |
eq |
eq |
JSON array: ["newest-first"] or ["oldest-first"] |
maxcount |
eq |
eq |
JSON number, clamped to 0..100 |
skip |
eq |
eq |
JSON number, floored, minimum 0 |
session |
eq |
eq |
JSON array of session strings. If AURALOGGER_PROJECT_SESSION is set and you omit -session, the CLI prepends this filter for you. |
data.<path> |
eq |
eq |
JSON array — filter on nested data using a dot path (e.g. data.userId) |
If you omit --<operator>, the default operator for that field is used (for example -type '["error"]' is the same as -type --in '["error"]').
Examples
auralogger get-logs -type '["error","warn"]' -maxcount 50
auralogger get-logs -message '["timeout"]' -skip 20 -maxcount 30
auralogger get-logs -type --not-in '["info","debug"]' -time --since '["10m"]'
auralogger get-logs -data.userId '["06431f39-55e2-4289-80c8-5d0340a8b66e"]'
auralogger get-logs -order '["oldest-first"]' -maxcount 25
Common parse errors (filters)
Expected 'get-logs'Expected field at position NMissing value for field '…'Invalid JSON for field '…'Field '…' expects a JSON array tokenField 'maxcount' expects a JSON number token(and similarly forskip)Invalid op '…' for field '…'Unknown filter field: …
Browser and frontends
This package is for Python on the server. For React, Vue, Next, Vite, or any code bundled for the browser, use the **auralogger-cli** npm package and its client entry — project token only there, never AURALOGGER_USER_SECRET in frontend bundles.
When something does not work
- Wrong directory — Run the CLI from the folder that contains
.env, or export variables in the shell. - Logs never reach the dashboard — Confirm
AURALOGGER_PROJECT_TOKENandAURALOGGER_USER_SECRETare set for the process (or passed explicitly in your configure step). Successful sends are quiet locally; problems may show as a one-time message on stderr. **get-logslooks plain** — Optional style env vars are documented in[user-docs/environment.md](user-docs/environment.md); the CLI can still resolve styling for a run when those are unset.
Requirements
Python 3.8+.
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
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 auralogger-0.1.0.tar.gz.
File metadata
- Download URL: auralogger-0.1.0.tar.gz
- Upload date:
- Size: 37.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d8d0baed522bc4aaa18fbba3ffea621f0ff5502ec327138af862d4a3977be0e4
|
|
| MD5 |
40532c83566f2d1e152598956a53479d
|
|
| BLAKE2b-256 |
fc3b198b4f61b64555a509d9ac9fe8f7fbe35cebc4e9eca87ff22cc99a33caef
|
File details
Details for the file auralogger-0.1.0-py3-none-any.whl.
File metadata
- Download URL: auralogger-0.1.0-py3-none-any.whl
- Upload date:
- Size: 39.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a195a894ee878fe4cd4bd663b1600b2f3130dba211e814a07249881ba61a4bc6
|
|
| MD5 |
8a5837d55afa7e71cc2324bb81bd3181
|
|
| BLAKE2b-256 |
627d7cded7a5d9ccbd9004ecb8916db474c653ea787259088fc8988f9d17f7d8
|