CrewAI tool for Skim — clean web reader for AI agents. Pays $0.002/call in USDC over x402. No signup, no API keys.
Project description
crewai-skim
Give your CrewAI agents the ability to read any URL — clean Markdown, no ads, no nav, no boilerplate. Pays itself per call. No signup, no API key.
crewai-skim is the official CrewAI tool for Skim — the canonical x402 clean reader API. It exposes one tool, SkimReader, that any agent in your crew can call to fetch a web page as agent-ready Markdown plus structured metadata (title, byline, published date, language, excerpt). Each call costs $0.002 in USDC on Base, paid automatically by your local wallet over HTTP 402.
Install
pip install crewai-skim
This pulls in the x402 client with EVM support, so there's nothing else to install.
Quickstart (60 seconds)
1. Fund a Base wallet with $1 of USDC
A dollar funds roughly 500 reads. Full step-by-step (with screenshots, for non-crypto-native devs): https://skim402.com/wallet.
Use a fresh wallet, not your personal one. This wallet's private key signs payment authorizations on your machine — treat it like a hot wallet for paying $0.002 tolls, not a savings account.
2. Point the tool at your wallet
export SKIM_WALLET_PRIVATE_KEY=0xYOUR_BASE_WALLET_PRIVATE_KEY
3. Use it
from crewai_skim import SkimReader
reader = SkimReader() # reads SKIM_WALLET_PRIVATE_KEY from the environment
markdown = reader.run(url="https://en.wikipedia.org/wiki/HTTP_402")
print(markdown)
The tool signs an EIP-3009 USDC authorization for $0.002, Skim returns clean Markdown, and you get back the article body with a YAML frontmatter block of metadata. The payment shows up in your wallet's transaction history on BaseScan.
Use it in a crew
SkimReader is a standard CrewAI BaseTool, so it drops straight into any agent's tool list:
from crewai import Agent, Task, Crew
from crewai_skim import SkimReader
researcher = Agent(
role="Research Analyst",
goal="Read and summarize web articles accurately",
backstory="You turn messy web pages into clean, citable notes.",
tools=[SkimReader()],
)
task = Task(
description="Read https://en.wikipedia.org/wiki/HTTP_402 and summarize it in 5 bullet points.",
expected_output="A 5-bullet summary.",
agent=researcher,
)
crew = Crew(agents=[researcher], tasks=[task])
print(crew.kickoff())
The agent decides when to call the Skim Web Reader, the wallet pays per read, and the model gets clean Markdown instead of raw HTML.
Output shape
SkimReader returns Markdown with a YAML frontmatter block of the page metadata:
---
title: Example article
byline: Jane Doe
publishedAt: 2025-01-15
lang: en
excerpt: A short summary...
---
# Example article
The cleaned article body in Markdown...
Set include_metadata=False to get just the Markdown body.
Configuration
SkimReader takes the following parameters (all optional except the wallet key):
| Parameter | Default | Notes |
|---|---|---|
private_key |
$SKIM_WALLET_PRIVATE_KEY |
Hex private key for the Base wallet that pays for reads. With or without 0x. Use a dedicated wallet — never your personal one. |
base_url |
https://skim402.com |
Override the API base URL. For self-hosting or local development. |
max_price_usd |
0.01 |
Hard cap on per-call price in USD. The wallet refuses to sign for anything above this. Skim is $0.002/call. |
include_metadata |
True |
Prepend a YAML frontmatter block of page metadata to the returned Markdown. |
timeout |
60 |
Per-request timeout in seconds. |
reader = SkimReader(
private_key="0x...", # or rely on the env var
max_price_usd=0.005,
include_metadata=False,
)
How it actually works
your agent ──► SkimReader ──► POST https://skim402.com/api/v1/read
▲ │
│ ▼
│ 402 Payment Required
│ (x402 challenge)
│ │
▼ │
x402 signs EIP-3009 USDC ◄─────────────┘
transfer authorization (locally)
│
▼
retry POST with X-PAYMENT header
│
▼
Skim verifies + settles via Coinbase CDP facilitator
│
▼
200 OK + clean Markdown
Your private key never leaves your machine — it only signs authorizations locally.
Security
- Dedicated wallet, always. Fund it with only as much USDC as you're willing to spend in a runaway loop. The
max_price_usdcap catches accidental price escalations. - No outbound telemetry from this package.
crewai-skimonly talks toskim402.com(or whatever you set asbase_url). No analytics, no error reporting, no phone-home.
Try it without an agent
Skeptical? Test the upstream endpoint directly — it'll return a 402 challenge so you can see the protocol in action:
curl -i -X POST https://skim402.com/api/v1/read \
-H 'content-type: application/json' \
-d '{"url":"https://en.wikipedia.org/wiki/HTTP_402"}'
You'll get back HTTP/1.1 402 Payment Required with the x402 challenge in the response body.
Links
- Skim website — https://skim402.com
- Wallet setup guide — https://skim402.com/wallet
- API docs — https://skim402.com/docs
- x402 protocol — https://x402.org
- GitHub — https://github.com/JessieJanie/skim402
License
MIT
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 crewai_skim-0.1.0.tar.gz.
File metadata
- Download URL: crewai_skim-0.1.0.tar.gz
- Upload date:
- Size: 8.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0f49e16d4dab58fee910a901bc6c93ce186c25086eebbdce8f64e8c7be961289
|
|
| MD5 |
54e7e0d3ecd3b7f4cdf91089411a1704
|
|
| BLAKE2b-256 |
2ce0c61cd2dc430fce1743d98937fe08e52e00d1e22ed27cf7726cd46b79ef3d
|
File details
Details for the file crewai_skim-0.1.0-py3-none-any.whl.
File metadata
- Download URL: crewai_skim-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1766eddc9f1834b1eb06893efa1d039e7c4476b1a74e8a829595bdbf784c6b3b
|
|
| MD5 |
4deba3abffc84f277939a00daf440922
|
|
| BLAKE2b-256 |
6f3ec83506026407af8052e2fc7b2e9539c575979a251d7e9cb21d115fcb1d44
|