ls-apis-mcp
MCP server for searching and discovering 4,000+ public APIs
README
ls-apis
Public APIs Discovery for Humans & Agents
A curated collection of 4,000+ public APIs with a powerful CLI search tool. Discover, filter, and explore APIs by category, authentication type.
Features
- Comprehensive Dataset - 4,000+ APIs aggregated from multiple sources
- Smart Search - Filter by query, category, authentication type
- Colored Output - Syntax-highlighted results (use
--no-colorto disable) - Multiple Output Formats - Text or JSON output
- MCP Server - AI-friendly API search via Model Context Protocol
- Extensible Architecture - Pluggable fetchers for adding new API sources
- TypeScript - Fully typed for better developer experience
Installation
git clone https://github.com/koalyptus/ls-apis.git
cd ls-apis
npm install
Quick Start
npm install -g @ls-apis/cli
ls-apis -q weather
Via npm link (local development)
npm link --workspace=@ls-apis/cli
ls-apis -q weather
Usage
CLI Search
# Search by keyword
npm run ls-apis -- -q weather
# Filter by category
npm run ls-apis -- -c weather
# Filter by authentication type
npm run ls-apis -- -a apiKey
# Combine filters
npm run ls-apis -- -q weather -c data -a oauth
# Limit results
npm run ls-apis -- -q weather -l 10
# Output as JSON
npm run ls-apis -- -q weather -o json
# Sort by name
npm run ls-apis -- -q weather -s name
# List all categories
npm run ls-apis -- categories
# List categories sorted by count
npm run ls-apis -- categories --sort count
# List categories as JSON
npm run ls-apis -- categories --output json
Commands
| Command | Description |
|---|---|
categories |
List all API categories with counts |
providers |
List all data providers |
config |
Show config settings and file path |
qa |
Run QA checks (terminal summary) |
# Run QA via CLI
npm run ls-apis -- qa
# Save QA report to custom path
npm run ls-apis -- qa -f ./my-report.json
QA Options
| Flag | Alias | Description |
|---|---|---|
--sort |
-s |
Sort by: name (default), count |
--output |
-o |
Output format: text (default), json |
Providers Options
| Flag | Alias | Description |
|---|---|---|
--sort |
-s |
Sort by: name (default), count |
--output |
-o |
Output format: text (default), json |
Options
| Flag | Alias | Description |
|---|---|---|
--query |
-q |
Search query (filters name, description) |
--category |
-c |
Filter by category |
--auth |
-a |
Filter by auth type (apiKey, OAuth, no) |
--limit |
-l |
Max results to show (default: 20) |
--output |
-o |
Output format: text or json (default: text) |
--sort |
-s |
Sort results: name, category, auth |
--no-color |
Disable colors in output | |
--help |
-h |
Show help |
--version |
-V |
Show version |
Note: Colors are enabled by default. Use
--no-coloror setNO_COLOR=1environment variable to disable.
Configuration File
A config file is automatically created at ~/.ls-apis on first run. You can edit it to set personal defaults. CLI flags always override config values.
Location: ~/.ls-apis (your home directory)
{
"limit": 10,
"descriptionMaxLength": 150,
"colors": true
}
| Key | Default | Description |
|---|---|---|
limit |
20 | Default max results |
descriptionMaxLength |
250 | Max chars before truncation |
colors |
true | Enable terminal colors |
The config file is plain JSON. Edit it manually to customize defaults, or delete it to regenerate with built-in values.
Example Output
Found 2 APIs:
Weather API
Description: Get real-time weather data for any location...
Link: https://api.weather.example.com
Auth: apiKey
Categories: weather, data
Sources: apis-guru
Weather2 API
Description: Comprehensive weather forecasting service...
Link: https://api.weather2.example.com
Auth: OAuth
Categories: weather, forecast
Sources: publicapis-dev
MCP Server
ls-apis includes an MCP server for AI assistants to search and discover public APIs via natural language.
Tools
| Tool | Description |
|---|---|
search-apis |
Search public APIs by query, category, auth type, and limit |
list-categories |
List all API categories with API counts |
list-providers |
List all data providers with API counts |
Resources
| URI | Description |
|---|---|
apis://data |
Full aggregated API dataset (JSON) |
apis://categories |
All API categories with counts (JSON) |
apis://providers |
All data providers with counts (JSON) |
apis://stats |
Dataset summary statistics (JSON) |
Setup
npm install
Configuration
VS Code / GitHub Copilot
Create .vscode/mcp.json in your project root:
VS Code will ask for permission on first run — this is standard for project-local MCP servers. Approve once and it won't prompt again.
{
"servers": {
"ls-apis": {
"command": "npx",
"args": ["tsx", "packages/mcp-server/src/index.ts"],
"cwd": "/path/to/ls-apis"
}
}
}
Switch Copilot Chat to Agent mode to use MCP tools.
Claude Desktop
Edit claude_desktop_config.json (%APPDATA%\Claude\ on Windows, ~/Library/Application Support/Claude/ on macOS):
{
"mcpServers": {
"ls-apis": {
"command": "npx",
"args": ["tsx", "packages/mcp-server/src/index.ts"],
"cwd": "/path/to/ls-apis"
}
}
}
Cursor
Create .cursor/mcp.json (project) or ~/.cursor/mcp.json (global):
{
"mcpServers": {
"ls-apis": {
"command": "npx",
"args": ["tsx", "packages/mcp-server/src/index.ts"],
"cwd": "/path/to/ls-apis"
}
}
}
Verification
After configuring, the client should discover the tools and resources listed above. You can also test via CLI:
echo '{"jsonrpc":"2.0","id":1,"method":"tools/list"}' | npm run mcp
Project Structure
See AGENTS.md for the full project layout. The repo is a monorepo with four packages under packages/:
aggregator— fetches, normalizes, deduplicates API data from upstream sourcescli— command-line search tool published asls-apisshared— types, config, search logic, paths consumed by all packagesmcp-server— MCP server for AI-friendly API queries (stdio transport)
Scripts
# Install dependencies
npm install
# Run all tests with coverage
npm test
# Run specific package tests
npm run test:aggregator
npm run test:cli
npm run test:shared
npm run test:mcp
# Typecheck all workspaces
npm run typecheck
# Lint & format
npm run lint
npm run format
# Run aggregator (generates data/apis.json in CLI package)
npm run aggregate
# Run QA checks on aggregated data
npm run qa
# Run CLI directly
npm run ls-apis -- -q <query>
# Run MCP server (stdio transport for AI clients)
npm run mcp
# Build CLI to dist/ (tsc + ESM import fix)
npm run build --workspace=@ls-apis/cli
CLI Build and Publish Notes
- The published CLI entrypoint is
packages/cli/dist/index.js. packages/cli/src/contains TypeScript sources.packages/clibuild script runs:tscto compile TS intodist/tsc-esm-fix --target distto add.jsextensions required by Node ESM runtime
prepackin the CLI package runs the build before packaging, so npm publish includes ready-to-run JavaScript.
Data Schema
The packages/cli/data/apis.json file contains metadata and aggregated API data with the following structure:
interface DataFile {
timestamp: string; // ISO 8601 UTC timestamp of processing
providers: Provider[]; // Data source providers
apis: ApiEntry[]; // Aggregated API entries
}
interface Provider {
name: string; // Provider identifier (e.g., 'apis-guru')
url: string; // Data source URL
}
interface ApiEntry {
name: string;
description?: string;
link: string;
auth?: string; // apiKey, OAuth, etc.
cors?: string;
categories: string[];
openapiSpec?: string; // OpenAPI spec URL if available
sources: string[]; // Which fetchers found this API
}
Adding a New API Source
-
Create a new fetcher in
packages/aggregator/src/sources/:touch packages/aggregator/src/sources/mysource.fetcher.ts -
Implement the
SourceFetcherinterface:import type { SourceFetcher, ApiEntry } from '../types'; export const mysourceFetcher: SourceFetcher = { name: 'mysource', fetchApis: async (): Promise<ApiEntry[]> => { // Fetch and normalize APIs from your source return [ /* ApiEntry items */ ]; }, }; -
Run the aggregator to fetch and update:
npm run aggregate
Fetchers are auto-loaded via loadAllFetchers() in sources/index.ts.
Testing
Tests use Vitest with v8 coverage:
# Run all tests
npm test
# Run specific package tests
npm run test:aggregator
npm run test:cli
npm run test:shared
npm run test:mcp
# Watch mode
cd packages/cli && npm run test:watch
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
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.