← Back to Skills Marketplace
lrg913427-dot

Agent Lens

by lrg913427-dot · GitHub ↗ · v2.15.0 · MIT-0
cross-platform ✓ Security Clean
41
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install agent-lens-tracker
Description
Track AI agent API calls, analyze token usage, and optimize costs. Use when user wants to monitor LLM spending, debug API calls, track token consumption, or...
README (SKILL.md)

Agent Lens

Track every AI API call, analyze token usage, and optimize costs.

When to Use

Activate this skill when the user:

  • Says "how much am I spending", "token usage", "API costs"
  • Wants to know which model is most expensive
  • Needs to optimize prompt costs
  • Wants to track API call latency or error rates
  • Mentions "budget", "cost optimization", or "token counting"
  • Asks "why is my API bill so high"

Quick Start

# Install
pip install git+https://github.com/lrg913427-dot/agent-lens.git

# Generate demo data and see it in action
agent-lens demo

# View stats
agent-lens stats
agent-lens cost
agent-lens recent

Three Ways to Track

1. Decorator (easiest)

from agent_lens import AgentLens

lens = AgentLens(agent_name="my-agent")

@lens.track(model="gpt-4o")
def call_api(prompt):
    return client.chat.completions.create(
        model="gpt-4o",
        messages=[{"role": "user", "content": prompt}],
    )

# Token usage is auto-extracted from OpenAI-style responses
result = call_api("Hello")

2. Context Manager (flexible)

from agent_lens import AgentLens

lens = AgentLens(agent_name="my-agent")

with lens.trace(model="claude-3.5-sonnet") as t:
    result = client.chat.completions.create(...)
    t.input_tokens = result.usage.prompt_tokens
    t.output_tokens = result.usage.completion_tokens

3. Direct Record (manual)

from agent_lens import AgentLens

lens = AgentLens(agent_name="my-agent")
lens.record(
    model="gpt-4o",
    input_tokens=1500,
    output_tokens=800,
    latency_ms=2300,
)

Global Shortcuts

from agent_lens import record, trace, track

record(model="gpt-4o", input_tokens=100, output_tokens=50)

with trace(model="gpt-4o") as t:
    ...

@track(model="gpt-4o")
def my_func():
    ...

CLI Commands

Command Description
agent-lens stats Overview: total calls, tokens, cost
agent-lens report --by model Breakdown by model/provider/agent
agent-lens cost Cost ranking with percentage bars
agent-lens recent -n 10 Latest API calls
agent-lens top Most expensive calls
agent-lens export --json Export to JSON
agent-lens export -o data.csv Export to CSV
agent-lens clean --before \x3Cts> Clean old data
agent-lens demo Generate sample data

Cost Optimization Workflow

When user asks "how can I save money":

  1. Run cost report: agent-lens cost
  2. Identify expensive models: Which models cost the most?
  3. Check token efficiency: Are prompts too long?
  4. Suggest cheaper alternatives:
    • gpt-4o → gpt-4o-mini (10x cheaper)
    • claude-3.5-sonnet → claude-3.5-haiku (4x cheaper)
    • gpt-4 → gpt-4o (2x cheaper)
  5. Check caching: Are there repeated prompts?
  6. Check error rate: agent-lens report --by status

Token Counting

import tiktoken

def count_tokens(text: str, model: str = "gpt-4o") -> int:
    """Count tokens for a given model."""
    try:
        enc = tiktoken.encoding_for_model(model)
    except KeyError:
        enc = tiktoken.get_encoding("cl100k_base")
    return len(enc.encode(text))

# Check before sending
prompt = "Your long prompt here..."
tokens = count_tokens(prompt)
print(f"Prompt: {tokens} tokens")
print(f"Estimated cost: ${tokens * 2.50 / 1_000_000:.4f}")

Supported Models

Pricing data for: OpenAI (GPT-4o, o1, o3), Anthropic (Claude 3.5/4), Google (Gemini 2.x), DeepSeek, Mistral, Qwen, GLM, MiMo.

Unknown models are tracked but cost shows "—".

Integration with Hermes

# Track Hermes agent API calls
from agent_lens import AgentLens

lens = AgentLens(agent_name="hermes-main")

# In your agent loop:
with lens.trace(model=config.model) as t:
    response = agent.run_conversation(message)
    t.input_tokens = response.get("input_tokens", 0)
    t.output_tokens = response.get("output_tokens", 0)

Data Storage

SQLite at ~/.agent-lens/traces.db. Fully local, no cloud service needed.

Pitfalls

  • Token extraction auto-works only for OpenAI-compatible response format
  • For non-OpenAI providers, manually set t.input_tokens and t.output_tokens
  • Cost estimates use list prices; actual costs may differ with discounts
  • Database grows over time; use agent-lens clean periodically

Verification

agent-lens demo        # Generate 20 sample records
agent-lens stats       # Should show 20 calls
agent-lens cost        # Should show cost breakdown by model
Usage Guidance
Reasonable to install if you want local LLM cost observability. Be aware it records API usage metadata in a local database and installs code from a GitHub repo, so review the upstream package if you will use it with sensitive workloads.
Capability Assessment
Purpose & Capability
The stated purpose is to monitor AI API calls, token usage, costs, latency, and reports; the documented capabilities fit that purpose.
Instruction Scope
Runtime instructions are user-directed examples for installing, recording traces, running reports, exporting data, and cleaning old records; no hidden prompt overrides or unrelated actions were found.
Install Mechanism
The skill tells users to install a Python package directly from the author's GitHub repository with pip, so users should trust or inspect that upstream package before installing.
Credentials
The skill stores API usage metadata locally to support cost reporting, which is proportionate to the monitoring purpose and disclosed in the artifact.
Persistence & Privilege
It persists a local SQLite database at ~/.agent-lens/traces.db and documents cleanup with agent-lens clean; no privilege escalation, background daemon, credential access, or exfiltration is described.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install agent-lens-tracker
  3. After installation, invoke the skill by name or use /agent-lens-tracker
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v2.15.0
### agent-lens-tracker 2.15.0 Changelog - Updated documentation in SKILL.md to improve clarity and usage guidance. - Expanded examples for decorators, context managers, and CLI integration. - Added details on supported models, integration with Hermes, and data storage practices. - Included troubleshooting tips and cost optimization workflow. - CLI commands documented for easier onboarding and reference.
Metadata
Slug agent-lens-tracker
Version 2.15.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Agent Lens?

Track AI agent API calls, analyze token usage, and optimize costs. Use when user wants to monitor LLM spending, debug API calls, track token consumption, or... It is an AI Agent Skill for Claude Code / OpenClaw, with 41 downloads so far.

How do I install Agent Lens?

Run "/install agent-lens-tracker" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Agent Lens free?

Yes, Agent Lens is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Agent Lens support?

Agent Lens is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Agent Lens?

It is built and maintained by lrg913427-dot (@lrg913427-dot); the current version is v2.15.0.

💬 Comments