Portfolio-aware crypto context for agents — holdings, market, optional allocation analysis
Project description
AllocContext
mcp-name: io.github.negillett/alloc-context
Portfolio-aware crypto context for agents — discover holdings, market, sentiment, macro, and regime; optional allocation analysis. Deterministic JSON over MCP with x402 pay-per-call on Base.
Privacy: nothing stored · one-time read-only · pass-through only — your keys and portfolio never persist on our servers. See USE.md.
Quick start (Cursor)
1. Install
pip install "alloc-context[mcp,hosted]"
# From source: pip install -e ".[mcp,hosted]"
2. User config
Copy config/user.example.yaml to
~/.config/alloc-context/user.yaml. Add read-only exchange keys for portfolio
discovery (optional) and an x402 payer for hosted market context. See
user-config.md.
3. MCP config
Add to your Cursor mcp.json (or project .cursor/mcp.json):
{
"mcpServers": {
"alloc-context": {
"command": "alloc-context",
"args": [
"mcp",
"--user-config",
"/Users/you/.config/alloc-context/user.yaml"
]
}
}
}
Use an absolute path for --user-config. Example:
cursor-mcp-bridge.example.json.
4. Ask your agent
Call get_context_bundle for a full snapshot (holdings when keys are set,
market/sentiment/macro via hosted upstream). Pure math tools
(check_allocation_band, get_rebalance_plan) work without exchange keys.
Full setup guide: cursor-mcp.md. Sample responses: examples.md.
Not financial advice.
Hosted MCP
| URL | https://mcp.alloc-context.com/mcp |
| Discovery | llms.txt, x402 manifest |
| Pricing | $0.02 cached context/math · $0.05 live ingest or portfolio |
| Payment | x402 on Base — USDC or EURC |
Agents and wallets connect directly to the hosted endpoint — see agent-integration.md. The Cursor bridge above combines local portfolio reads with this upstream for market context.
MCP tools
| Tool | Purpose |
|---|---|
get_context_bundle |
Full ContextBundle — holdings, market, sentiment, macro, delta, regime; optional allocation_analysis |
get_market_context |
Sentiment, macro, ETF, breadth, and market fields (no portfolio) |
get_context_at |
Saved snapshot from ingest history at a given as_of |
get_context_delta |
Notable shifts between two saved snapshots |
get_rebalance_plan |
USD rebalance moves from allocation, target, and NAV |
check_allocation_band |
Drift vs target and whether allocation is outside the band |
check_allocation_bands |
Batch band checks for multiple target scenarios |
get_portfolio_state |
Live NAV and holdings from Kraken or Coinbase |
See mcp.md for arguments, pricing, and resources.
Self-host and development
Run ingest and MCP entirely on your machine — no x402 upstream required.
See self-hosting.md (self_host: true in user config)
or local-dev.md for the dev stack.
git clone git@github.com:negillett/alloc-context.git
cd alloc-context
python3.11 -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]"
cp .env.example .env
cp config/config.example.yaml config/config.yaml
python -m alloccontext ingest --dry-run
python -m alloccontext rollup --scope daily --stdout
pytest
| Command | Purpose |
|---|---|
python -m alloccontext ingest |
Pull configured sources → SQLite |
python -m alloccontext rollup --scope daily --stdout |
ContextBundle JSON (facts) |
python -m alloccontext status |
Per-source ingest ages, snapshots, MCP /health |
alloc-context mcp |
MCP server (stdio or HTTP) |
HTTP MCP + x402: mcp-http.md. CLI entry point:
alloc-context (same as python -m alloccontext).
Documentation
| Document | Purpose |
|---|---|
| docs/cursor-mcp.md | Cursor stdio MCP (bridge default) |
| docs/user-config.md | Bridge user.yaml reference |
| docs/mcp.md | MCP tools and x402 |
| docs/agent-integration.md | Paid HTTP MCP + Bazaar for agents |
| docs/examples.md | Sample tool JSON (redacted) |
| docs/context-bundle.md | ContextBundle schema |
| docs/USE.md | Self-host vs hosted MCP (plain language) |
| docs/mcp-http.md | HTTP MCP + x402 setup |
| docs/mcp-discovery.md | Bazaar and agent discovery |
| docs/self-hosting.md | Optional Linux/systemd ingest + MCP |
| docs/local-dev.md | Local internal MCP + dev ingest |
| docs/architecture.md | Pipeline and trust boundaries |
| docs/data-sources.md | Ingest sources |
| docs/distribution.md | GitHub, PyPI, MCP Registry, directories |
| docs/publishing.md | Release workflow and version bumps |
| docs/security-ci.md | CI coverage, Bandit, and pip-audit gates |
Contributing
GitHub Issues are welcome for bugs, schema feedback, and MCP API suggestions. Unsolicited pull requests are not expected — see CONTRIBUTING.md.
License
Elastic License 2.0 — source-available, self-host friendly. See docs/USE.md for plain-language allowed uses.
Official hosted MCP: https://mcp.alloc-context.com/mcp
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 alloc_context-0.2.0.tar.gz.
File metadata
- Download URL: alloc_context-0.2.0.tar.gz
- Upload date:
- Size: 139.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5679476ea1f91f9688ebfcbe1915465bed15e9d0d5b1744196da7542d9cd38f0
|
|
| MD5 |
cfd73a85bc602ed3062ae2112383686f
|
|
| BLAKE2b-256 |
2097f5a597fda0c9c4fd0826efee5f49a9bedec47217b0b46b13c2735a3e51d3
|
Provenance
The following attestation bundles were made for alloc_context-0.2.0.tar.gz:
Publisher:
release.yml on negillett/alloc-context
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
alloc_context-0.2.0.tar.gz -
Subject digest:
5679476ea1f91f9688ebfcbe1915465bed15e9d0d5b1744196da7542d9cd38f0 - Sigstore transparency entry: 1685183784
- Sigstore integration time:
-
Permalink:
negillett/alloc-context@33b92d99c989f6d64872c345b6fa20960434e2ec -
Branch / Tag:
refs/heads/main - Owner: https://github.com/negillett
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@33b92d99c989f6d64872c345b6fa20960434e2ec -
Trigger Event:
push
-
Statement type:
File details
Details for the file alloc_context-0.2.0-py3-none-any.whl.
File metadata
- Download URL: alloc_context-0.2.0-py3-none-any.whl
- Upload date:
- Size: 135.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ed8805157e6fe0a143becf6f7401d198d859e4835172def6f2fdfd3638688d4
|
|
| MD5 |
54f81230cbb956f7e957e3cc8fbed9ea
|
|
| BLAKE2b-256 |
3c14cbae432b324a5f865d901efb9fc7a72a98b149cf0466d407c92a51046b40
|
Provenance
The following attestation bundles were made for alloc_context-0.2.0-py3-none-any.whl:
Publisher:
release.yml on negillett/alloc-context
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
alloc_context-0.2.0-py3-none-any.whl -
Subject digest:
9ed8805157e6fe0a143becf6f7401d198d859e4835172def6f2fdfd3638688d4 - Sigstore transparency entry: 1685183874
- Sigstore integration time:
-
Permalink:
negillett/alloc-context@33b92d99c989f6d64872c345b6fa20960434e2ec -
Branch / Tag:
refs/heads/main - Owner: https://github.com/negillett
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@33b92d99c989f6d64872c345b6fa20960434e2ec -
Trigger Event:
push
-
Statement type: