Skip to main content

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 directorycd 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 the shapes below.

Encryption is optional per project. If your project has no encryption enabled, you only need AURALOGGER_PROJECT_TOKEN and you can configure without a user secret. If your project is encrypted, you’ll configure with both AURALOGGER_PROJECT_TOKEN and AURALOGGER_USER_SECRET.

No encryption (recommended first): token only

import os
from typing import Any, Dict, Literal, Optional
from auralogger import auralogger

def ensureConfigured() -> None:
    project_token = os.environ.get("AURALOGGER_PROJECT_TOKEN", "").strip()
    auralogger.configure(project_token)

def auralog(
    type: Literal["debug", "info", "warn", "error"],
    message: str,
    location: Optional[str] = None,
    data: Optional[Dict[str, Any]] = None,
) -> None:
    ensureConfigured()
    auralogger.log(type, message, location, data)

Encrypted projects: token + user secret

import os
from typing import Any, Dict, Literal, Optional
from auralogger import auralogger

def ensureConfigured() -> None:
    project_token = os.environ.get('AURALOGGER_PROJECT_TOKEN', '').strip()
    user_secret = os.environ.get('AURALOGGER_USER_SECRET', '').strip()
    auralogger.configure(project_token, user_secret)
    # auralogger.configure()  — omit credentials to print locally only (no streaming for removing network delay and cost).
   

def auralog(
    type: Literal['debug', 'info', 'warn', 'error'],
    message: str,
    location: Optional[str] = None,
    data: Optional[Dict[str, Any]] = None,
) -> None:
    ensureConfigured()
    auralogger.log(
        type,
        message,
        location,
        data,
    )
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 N
  • Missing value for field '…'
  • Invalid JSON for field '…'
  • Field '…' expects a JSON array token
  • Field 'maxcount' expects a JSON number token (and similarly for skip)
  • 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_TOKEN and AURALOGGER_USER_SECRET are set for the process (or passed explicitly in your configure step). Logs always print locally — if they're not reaching the dashboard, check credentials and network; send/socket failures surface as stderr messages.
  • **get-logs looks 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

auralogger-0.1.5.tar.gz (39.9 kB view details)

Uploaded Source

Built Distribution

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

auralogger-0.1.5-py3-none-any.whl (45.1 kB view details)

Uploaded Python 3

File details

Details for the file auralogger-0.1.5.tar.gz.

File metadata

  • Download URL: auralogger-0.1.5.tar.gz
  • Upload date:
  • Size: 39.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for auralogger-0.1.5.tar.gz
Algorithm Hash digest
SHA256 1cd43bc3f8d8fbba7fd5d0940df17d8c89717c6b998a05a8fcf771a97b7039ae
MD5 bb51cc48eb5c885fc18dccaca149c3f5
BLAKE2b-256 0244af5d8bf91a24eecd8e8943c1db9541ed82948018640ec09a4e6a021453c0

See more details on using hashes here.

File details

Details for the file auralogger-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: auralogger-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 45.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for auralogger-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 0533b4b7b58b3ed86b704923b9c4a8b69f00f6cac06a449ebd05004e5c486ca7
MD5 0d86c930cac55c9b6b0a59c813c112f8
BLAKE2b-256 536c149c0acdca29fea57de6b4684986b22c17c3c21242eef2a97e86ed4cf574

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