fyi-mcp
FYI request management with tools for requests, authorities, correspondence, sync, and health.
README
FYI CLI
Privacy-focused CLI tool for managing FYI.org.nz official information requests
๐ Quick Start
# Install
pip install fyi-cli
# Initialize
fyi init-db
# Create your first request
fyi register-request ministry-of-justice "OIA Request" "Request body..." --status draft
# Generate submission URL
fyi build-prefilled-url 1
# Track and manage requests
fyi list-requests
fyi dashboard --output dashboard.html
Full guide: QUICKSTART.md
โจ Features
- ๐ Privacy-First: All data stored locally, optional encryption
- ๐ Track Requests: Monitor OIA requests from creation to completion
- ๐ค Automated Monitoring: Watch FYI.org.nz for updates automatically
- ๐ Reports & Analytics: Generate dashboards, attention reports, handover docs
- ๐ Secure Storage: Encrypted credentials, OS keyring integration
- ๐ Alaveteli Compatible: Works with any Alaveteli instance (FYI, WDTK, FDS)
- ๐ป CLI + Web UI: Command-line and web interface options
- ๐ฆ Export Options: JSON, CSV, HTML, PDF export capabilities
๐ฆ Installation
From PyPI (Recommended)
pip install fyi-cli
Standalone Executables
Download from Releases:
- Windows:
fyi-cli-win.exe - macOS:
fyi-cli-macos - Linux:
fyi-cli-linux
From Source
git clone https://github.com/edithatogo/fyi-cli.git
cd fyi-cli
pip install -e ".[dev]"
Full installation guide: INSTALL.md
๐ Documentation
| Document | Description |
|---|---|
| docs/cli-entrypoints-audit.md | Canonical cross-reference for Python CLI, Rust CLI, and Rust MCP surfaces |
| QUICKSTART.md | 5-minute getting started guide |
| USER_GUIDE.md | Comprehensive user documentation |
| INSTALL.md | Installation guide (Windows/Mac/Linux) |
| API_KEY_SETUP.md | How to get and configure API key |
| CONFIGURATION.md | Configuration reference |
| TROUBLESHOOTING.md | Troubleshooting guide |
| FAQ.md | Frequently asked questions |
| CHANGELOG.md | Version history |
| CONTRIBUTING.md | How to contribute |
๐ก๏ธ Security
Reporting a Vulnerability
Please do NOT report security vulnerabilities through public GitHub issues.
Use GitHub's private vulnerability reporting: https://github.com/edithatogo/fyi-cli/security/advisories/new
Security Policy: SECURITY.md
Security Features
- โ AES-256-GCM encryption for sensitive data
- โ PBKDF2-HMAC-SHA256 key derivation
- โ OS keyring integration for credential storage
- โ Tamper-evident audit logging
- โ Secure session management
- โ Input validation and sanitization
- โ Security headers (CSP, HSTS, X-Frame-Options)
- โ Automated security scanning (CodeQL, pip-audit, bandit)
๐งช Testing
# Rust release checks used by this repository
cargo +stable-x86_64-pc-windows-gnu fmt --all -- --check
cargo +stable-x86_64-pc-windows-gnu clippy --workspace --all-targets --all-features -- -D warnings
cargo +stable-x86_64-pc-windows-gnu test --workspace --all-features
# Python legacy/support checks
.\.venv\Scripts\python.exe -m pytest tests/test_release_readiness.py
# Opt-in live smoke test
FYI_LIVE_SMOKE=1 .\.venv\Scripts\python.exe -m pytest -m smoke tests/test_discovery_smoke.py
Test Coverage: Rust workspace checks are the release gate. Python support tests remain available for legacy docs and archive tooling.
๐ค Contributing
We welcome contributions! See CONTRIBUTING.md for guidelines.
Quick Start for Contributors
# Fork and clone
git clone https://github.com/YOUR_USERNAME/fyi-cli.git
cd fyi-cli
# Set up development environment
python -m venv venv
source venv/bin/activate # or venv\Scripts\activate on Windows
pip install -e ".[dev]"
# Run tests
pytest
# Make your changes, then submit a PR
git commit -m "feat: Add awesome feature"
git push origin feature/awesome-feature
Code of Conduct
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
๐ Project Status
v1.0.0 Release Progress
| Phase | Status | Progress |
|---|---|---|
| Phase 1.1: Documentation | โ Complete | 100% |
| Phase 1.2: Packaging | โณ In Progress | 0% |
| Phase 1.3: UX Improvements | โณ Pending | 0% |
| Phase 2: Beta Release | โณ Pending | 0% |
| Phase 3: Public Release | โณ Pending | 0% |
Target Release Date: 2026-03-30
Release Plan: RELEASE_PLAN.md
๐ Compatible Platforms
FYI CLI works with any Alaveteli-based platform:
| Platform | Region | URL |
|---|---|---|
| FYI.org.nz | New Zealand | https://fyi.org.nz |
| WhatDoTheyKnow | United Kingdom | https://www.whatdotheyknow.com |
| FragDenStaat | Germany | https://fragdenstaat.de |
| Alaveteli | Any | Self-hosted instances |
๐ CLI Commands
Archive Discovery
The archive commands are read-only and do not require an API key.
# Import the official FYI authority list into the local SQLite database
fyi import-authorities
# Walk the public search feed for a date window and save discovered requests
fyi discover --date-from 2024-01-01 --date-to 2024-02-01 \
--checkpoint data/_state/discovery-2024-01.json \
--output data/_state/discovered-2024-01.jsonl
# Probe a numeric request ID range for gaps
fyi discover --backfill-ids --id-from 1 --id-to 5000 \
--output data/_state/backfill-1-5000.jsonl
# Compare feed discovery against the ID backfill
fyi discover-reconcile \
--feed data/_state/discovered-2024-01.jsonl \
--backfill data/_state/backfill-1-5000.jsonl \
--output data/_state/discovery-reconciliation.json
Discovery uses a contactable User-Agent, checks robots.txt, and backs off on
transient 429/5xx responses. Keep live runs polite: use small date windows,
resume with checkpoints, and coordinate archive work with the ethics guidance in
the sibling fyi-archive repo at docs/ethics-and-compliance.md.
For concurrent workers, point discover and backfill at the same SQLite
database with --db. That enables the shared cross-worker limiter, which
reserves one aggregate request slot across processes and records both normal
reservations and transient-failure backoff events. Inspect the current state
with fyi rate-limit-status --db fyi_system.db.
CLI and MCP surfaces
The full command and server cross-reference is maintained in docs/cli-entrypoints-audit.md. It covers the Python CLI entrypoints (fyi, fyi-cli, fyi-system), the Rust CLI binary (fyi-cli), and the Rust MCP server (fyi-mcp) with its published registry pages.
Opt-in live smoke test:
FYI_LIVE_SMOKE=1 pytest -m smoke tests/test_discovery_smoke.py
Faithful Archive Capture
fyi capture stores the public request JSON, rendered HTML, and attachments as
WARC records, deduplicates attachment bytes by SHA-256, and maintains a derived
request view for downstream dataset tooling.
fyi capture 12345 \
--data-dir data \
--dist-dir dist \
--max-bytes 500000000 \
--max-runtime-minutes 30
Capture layout:
data/
warc/<runid>-<request>.warc.gz
attachments/<sha-prefix>/<sha256>
raw/requests/<authority>/<request_id>/
request.json
page.html
attachments.json
snapshot_meta.json
dist/
site_snapshots/<YYYYMMDD>.wacz
Each daily WACZ is appendable: subsequent captures add another WARC segment under
archive/ and merge the resource metadata in datapackage.json. Replay tooling
that supports WACZ/WARC can open the package from dist/site_snapshots/; for
low-level inspection, unzip it and read the WARC segments with warcio.
# Database
fyi init-db # Initialize database
fyi config show # Show configuration
# Requests
fyi register-request ... # Create new request
fyi list-requests # List all requests
fyi request-detail <id> # View request details
fyi set-status <id> <status> # Update status
# Submission
fyi build-prefilled-url <id> # Generate submission URL
# Monitoring
fyi ingest-feed <url> # Ingest RSS/Atom feed
fyi scheduler <url> # Run continuous monitoring
fyi discover # Discover public FYI requests
fyi discover-reconcile # Compare discovery JSONL outputs
# Reports
fyi dashboard --output ... # Generate dashboard
fyi attention-report # Generate attention report
fyi handover --output ... # Generate handover document
# Export
fyi export-requests # Export all requests
fyi export-bundle <id> # Export request bundle
# Security
fyi privacy-audit # Privacy compliance check
fyi health-check # System health verification
Full CLI reference: See fyi --help or USER_GUIDE.md
๐๏ธ Architecture
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ FYI CLI โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ CLI Commands โ Web UI โ Scheduler โ Reports โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ Alaveteli API Client โ
โ (Read API + Write API support) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ SQLite Database โ
โ (tracked_requests, authorities, feed_events, etc.) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ FYI.org.nz / Alaveteli API โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- Built on the Alaveteli platform by mySociety
- Inspired by the transparency work of FYI.org.nz
- Uses cryptography for encryption
๐ Support
- Documentation: https://fyi-cli.readthedocs.io/
- Issues: https://github.com/edithatogo/fyi-cli/issues
- Discussions: https://github.com/edithatogo/fyi-cli/discussions
Made with โค๏ธ for transparency and privacy
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.