AnnasArchiveMCP
Health Warn
- No license รขโฌโ Repository has no license file
- Description รขโฌโ Repository has a description
- Active repo รขโฌโ Last push 0 days ago
- Low visibility รขโฌโ Only 5 GitHub stars
Code Pass
- Code scan รขโฌโ Scanned 1 files during light audit, no dangerous patterns found
Permissions Pass
- Permissions รขโฌโ No dangerous permissions requested
This tool is an MCP server that connects your AI coding assistant to Anna's Archive via RapidAPI. It allows you to search for books and automatically download them directly to your local machine.
Security Assessment
The overall risk is rated as Medium. The tool behaves as expected for its intended purpose but requires careful handling. It makes external network requests to the RapidAPI servers to fetch search results and download files, and it writes these files directly to your local filesystem (with configurable directories and overwrite settings).
The good news is that the automated code scan found no dangerous patterns, no hardcoded secrets, and it does not request highly dangerous system permissions. However, there are inherent risks. Because the tool downloads external files to your computer, there is always a slight risk of malicious content. Furthermore, it requires you to provide a third-party API key (`RAPIDAPI_KEY`) via environment variables, which you must protect and avoid exposing in your client configuration.
Quality Assessment
The project is very new and currently has low visibility with only 5 GitHub stars, meaning it has not been extensively peer-reviewed by the open-source community. However, it is actively maintained, with the most recent code push happening today. A major drawback is that the repository lacks a license file. This means that technically, no one has explicit legal permission to use, modify, or distribute the code, which could be a concern depending on your project's requirements.
Verdict
Use with caution: the code appears safe and standard, but the low community adoption, lack of a formal license, and inherent risks of automated external file downloads warrant careful oversight.
Rust MCP server for book search and safe downloads ๐ฆ
AnnasArchiveMCP
A Rust MCP server for searching books through Anna's Archive via RapidAPI and downloading selected results safely to your machine.
How to use
This section is a practical manual for getting AnnasArchiveMCP running and using it from an MCP client.
1. Build the server
Clone the repository and compile the binary:
git clone <your-repo-url>
cd AnnasArchiveMCP
cargo build --release
The compiled binary will be:
target/release/annas-archive-mcp
2. Get a RapidAPI key
AnnasArchiveMCP needs a RapidAPI key that has access to the Anna's Archive API.
Set it in your environment before starting the server:
export RAPIDAPI_KEY=your_api_key_here
You can also place it in a local .env file if that fits your setup better.
3. Configure optional defaults
You can run with only RAPIDAPI_KEY, but these optional variables are useful:
RAPIDAPI_HOSTโ defaults toannas-archive-api.p.rapidapi.comANNAS_ARCHIVE_MCP_DOWNLOAD_DIRโ default folder for downloaded filesANNAS_ARCHIVE_MCP_OPEN_AFTER_DOWNLOADโtrueorfalseANNAS_ARCHIVE_MCP_CREATE_SUBDIRSโtrueorfalseANNAS_ARCHIVE_MCP_OVERWRITE_DEFAULTโtrueorfalseANNAS_ARCHIVE_MCP_DEFAULT_LIMITโ default number of search resultsANNAS_ARCHIVE_MCP_MAX_LIMITโ maximum allowed search resultsRUST_LOGโ log level such asinfoordebug
Example:
RAPIDAPI_KEY=your_api_key_here
ANNAS_ARCHIVE_MCP_DOWNLOAD_DIR=~/Downloads
ANNAS_ARCHIVE_MCP_OPEN_AFTER_DOWNLOAD=false
ANNAS_ARCHIVE_MCP_CREATE_SUBDIRS=true
ANNAS_ARCHIVE_MCP_OVERWRITE_DEFAULT=false
RUST_LOG=info
4. Run the server
Run it with Cargo during development:
cargo run
Or run the compiled binary directly:
./target/release/annas-archive-mcp
The server uses stdio, so it is normally started by your MCP client instead of being used as a standalone interactive CLI.
5. Add it to your MCP client
Point your MCP client at the built binary and provide the required environment variables.
Example MCP client configuration:
{
"mcpServers": {
"annas-archive": {
"command": "/absolute/path/to/AnnasArchiveMCP/target/release/annas-archive-mcp",
"env": {
"RAPIDAPI_KEY": "your_api_key_here",
"RUST_LOG": "info"
}
}
}
}
Replace the path with the actual absolute path on your machine.
6. Search for books
Use the search_books tool first. This is the recommended workflow.
Typical search arguments:
queryโ the search text, for example a title, author, or bothformatsโ optional preferred formats such aspdforepublanguagesโ optional language filtersyearFrom/yearToโ optional year rangelimitโ maximum number of results to returnsortโrelevance,year, orsize
A typical search request would be conceptually like:
- query:
clean code - formats:
["pdf", "epub"] - limit:
5
The response includes ranked results with stable result_id values. Save the result_id for the result you want to download.
7. Download a selected book
After searching, use download_book with either:
resultIdโ recommended, because it comes directly fromsearch_booksproviderItemIdโ provider-native identifier
Optional download arguments include:
downloadDirfilenameTemplateoverwriteopenAfterDownloadcreateSubdirs
Typical workflow:
- Search with
search_books - Review the returned results
- Copy the desired
result_id - Call
download_bookwith thatresultId
The response includes the final saved path, filename, bytes written, and whether the file was opened automatically.
8. Use the compatibility workflow if you want one-call behavior
AnnasArchiveMCP also provides search_and_download_book.
This workflow:
- searches first
- returns results when manual selection is needed
- or automatically downloads the top match when selection settings allow it
Useful selectionMode values:
manualโ always return choices for you to inspectauto_if_confidentโ auto-download only when the top match is strong enoughforce_topโ always pick the top-ranked result
This mode is convenient, but the separate search_books โ download_book flow is usually easier to control.
9. Recommended everyday usage
For the safest and most predictable experience, use this routine:
- Start the MCP server through your MCP client
- Call
search_bookswith a clear query - Inspect title, author, year, language, format, and relevance
- Choose the best
result_id - Call
download_book - Confirm the returned
destination_path
10. Example real-world usage pattern
If you want an EPUB copy of a book:
- Search for the title and author together
- Pass
formats: ["epub"] - Limit results to a small number such as
5 - Inspect the best matches
- Download the result with the most accurate metadata
If you get too few results, remove format or language filters and try again.
11. What to expect in responses
search_books returns structured information such as:
- a summary
- the normalized query
- a result count
- ranked results
- warnings when relevant
download_book returns structured information such as:
- selected result identifiers
- title and authors
- file format and MIME type
- destination path
- final filename
- bytes written
- warnings
12. Troubleshooting quick guide
If the server does not start:
- confirm
RAPIDAPI_KEYis set - confirm your key has Anna's Archive API access
- confirm your MCP client points to the correct binary path
If searching returns nothing useful:
- broaden the query
- remove some filters
- verify the upstream API is available
If downloading fails:
- check destination directory permissions
- check available disk space
- verify the selected result is downloadable
- retry later if the upstream service is unavailable or rate-limited
13. Security tips
- Do not hardcode API keys in source code
- Prefer environment variables or MCP client secret storage
- Do not commit
.envfiles containing real secrets
Features
- MCP stdio server implemented in Rust
- Normalized search results with stable
result_idvalues - Separate tools for search and download
- Compatibility
search_and_download_bookworkflow - Safer path handling and filename generation
- Ranked result selection with manual and auto-selection modes
- Optional open-after-download behavior
- Structured JSON responses for MCP clients
Requirements
- Rust 1.78+ recommended
- Cargo
- A RapidAPI key with access to the Anna's Archive API
Installation
Clone the repository and build it:
git clone <your-repo-url>
cd AnnasArchiveMCP
cargo build --release
The server binary will be available at:
target/release/annas-archive-mcp
Configuration
AnnasArchiveMCP reads configuration from environment variables and optionally from a local .env file.
Required
RAPIDAPI_KEYโ your RapidAPI API key
Optional
RAPIDAPI_HOSTโ defaults toannas-archive-api.p.rapidapi.comANNAS_ARCHIVE_MCP_DEFAULT_PROVIDERโ defaults toannas_archiveANNAS_ARCHIVE_MCP_DOWNLOAD_DIRโ default download directoryANNAS_ARCHIVE_MCP_OPEN_AFTER_DOWNLOADโtrueorfalseANNAS_ARCHIVE_MCP_CREATE_SUBDIRSโtrueorfalseANNAS_ARCHIVE_MCP_OVERWRITE_DEFAULTโtrueorfalseANNAS_ARCHIVE_MCP_FILENAME_TEMPLATEโ filename template stringANNAS_ARCHIVE_MCP_MAX_FILENAME_LENGTHโ max generated filename lengthANNAS_ARCHIVE_MCP_DEFAULT_LIMITโ default search result limitANNAS_ARCHIVE_MCP_MAX_LIMITโ max allowed search result limitANNAS_ARCHIVE_MCP_ENABLE_DEBUG_FIELDSโ include provider debug fields by defaultANNAS_ARCHIVE_MCP_TIMEOUT_SECSโ HTTP timeoutANNAS_ARCHIVE_MCP_MAX_RETRIESโ provider retry countANNAS_ARCHIVE_MCP_USER_AGENTโ custom HTTP user agentRUST_LOGโ log level, for exampleinfoordebug
Example .env
RAPIDAPI_KEY=your_api_key_here
RAPIDAPI_HOST=annas-archive-api.p.rapidapi.com
ANNAS_ARCHIVE_MCP_DOWNLOAD_DIR=~/Downloads
ANNAS_ARCHIVE_MCP_OPEN_AFTER_DOWNLOAD=false
ANNAS_ARCHIVE_MCP_CREATE_SUBDIRS=true
ANNAS_ARCHIVE_MCP_OVERWRITE_DEFAULT=false
ANNAS_ARCHIVE_MCP_DEFAULT_LIMIT=10
ANNAS_ARCHIVE_MCP_MAX_LIMIT=50
RUST_LOG=info
Running the server
Run directly with Cargo:
cargo run
Or run the release binary:
./target/release/annas-archive-mcp
The server communicates over stdio and is intended to be launched by an MCP client.
MCP client configuration
Example command-based MCP configuration:
{
"mcpServers": {
"annas-archive": {
"command": "/absolute/path/to/AnnasArchiveMCP/target/release/annas-archive-mcp",
"env": {
"RAPIDAPI_KEY": "your_api_key_here",
"RUST_LOG": "info"
}
}
}
}
Adjust the path for your machine and MCP client.
Available tools
search_books
Searches for books and returns ranked normalized results.
Arguments
query(required): free-text search queryformats: array of preferred formats likepdf,epub,mobicategories: array likefiction,nonfictionlanguages: array of language codes or labelsyearFrom: lower year boundyearTo: upper year boundlimit: maximum results to returnprovider: provider hint, currentlyannas_archivesort:relevance,year, orsizedebug: include ranking/debug metadata
Returns
Structured content including:
summaryquerycountresultswarnings
Each result includes fields such as:
result_idproviderprovider_item_idtitlesubtitleauthorspublisheryearlanguageformatfile_size_bytescover_urlchecksum_md5checksum_sha1downloadablerelevance_score
download_book
Downloads a specific result using either resultId or providerItemId.
Arguments
resultId: stable result id returned fromsearch_booksproviderItemId: provider-native identifierdownloadDir: override destination directoryfilenameTemplate: override filename templateoverwrite: overwrite existing filesopenAfterDownload: open the file after downloadcreateSubdirs: create destination directory if needed
You must provide either resultId or providerItemId.
Returns
Structured content including:
summaryresult_idproviderprovider_item_idtitleauthorsformatmime_typedestination_pathfinal_file_namebytes_writtenopenedwarnings
search_and_download_book
Compatibility workflow that searches first, then either:
- returns matching results if manual selection is required, or
- auto-selects a result and downloads it
Arguments
Includes all major search and download fields plus:
selectionMode: one ofmanualauto_if_confidentforce_top
Typical workflow
Recommended flow
- Call
search_books - Inspect results
- Choose a
result_id - Call
download_book
Compatibility flow
- Call
search_and_download_book - If
selection_requiredistrue, calldownload_bookwith a chosenresultId - Otherwise use the returned download result
Behavior notes
- Automatic file opening is opt-in
- Downloads are written using safer filename/path handling
- Result ranking attempts to prefer better title/author/format matches
- The provider currently supported is Anna's Archive through RapidAPI
- If your API key is missing, startup will fail with a configuration error
Development
Build:
cargo build
Run tests:
cargo test
Run with debug logging:
RUST_LOG=debug cargo run
Format and lint:
cargo fmt
cargo clippy --all-targets --all-features
Troubleshooting
Server fails to start
Check that:
RAPIDAPI_KEYis set- your key has access to the Anna's Archive API
- the binary path in your MCP client config is correct
No results returned
Try:
- a broader query
- removing restrictive filters
- verifying the upstream API is reachable
Download fails
Check:
- destination directory permissions
- available disk space
- whether the provider result is actually downloadable
- whether the upstream API is rate-limiting or unavailable
Security notes
- Do not hardcode API keys in source files
- Prefer environment variables or MCP client-managed secrets
- Review your MCP client config so secrets are not committed to version control
Project status
This project is a Rust rewrite focused on a cleaner MCP architecture, safer downloads, and better maintainability than the legacy implementation.
Reviews (0)
Sign in to leave a review.
Leave a reviewNo results found