Gemini Enterprise MCP Server
Connects AI coding assistants to Google Cloud Discovery Engine APIs for semantic search, conversational RAG, and administration of datastores, documents, and configurations.
README
๐ Gemini Enterprise MCP Server & Agent Skills
Welcome to the Gemini Enterprise MCP Server.
[!IMPORTANT] Unofficial Project: This is NOT an official Google repository or product. It is an absolutely unofficial, personal initiative created to support and facilitate the adoption of Gemini Enterprise.
This open-source project (released under the Apache 2.0 license) implements a Model Context Protocol (MCP) server in TypeScript/ESM to connect AI coding assistants and orchestration frameworks with the powerful Google Cloud Discovery Engine APIs (which power Gemini Enterprise App).
The server handles both Data Plane operations (semantic search, conversational RAG with the Answer API, document retrieval) and Control Plane operations (automated datastore creation, JSON schema management, ranking/Serving Configs tuning, and SaaS connector configurations).
๐ Key Features & API Coverage
The server provides complete (100% operational coverage) mapping to the core gRPC/REST endpoints of Google Cloud Discovery Engine:
๐ Data Plane (Semantic Search & RAG)
- Advanced Search (
gemini_enterprise_search): Executes semantic queries on datastores, returning titles, snippets, URIs, and structured data formatted in clean Markdown for your agents. - Conversational Search (
gemini_enterprise_ask): Queries the Answer API (Conversational RAG) receiving grounding answers, confidence scores, and structured references. - Document Retrieval (
gemini_enterprise_get_document): Allows the agent to download the entire contents and structured metadata of an indexed document for in-depth analysis.
โ๏ธ Control Plane (Administration & Tuning)
- App & Engine Management (
gemini_enterprise_manage_apps): Complete CRUD and IAM operations to create, configure, retrieve, and set access policies for search and chat applications. LRO is fully supported. - DataStore Management (
gemini_enterprise_manage_datastore): Instantiation and deletion of structured and unstructured Data Stores with custom industry verticals (e.g.,GENERIC,MEDIA). - Advanced Web Search (
gemini_enterprise_manage_target_sites): Management of target sites (URLs and glob patterns) for automatic website crawling. - Bulk Document Ingestion (
gemini_enterprise_manage_documents): Asynchronous ingestion and purging of documents from Cloud Storage (gs://...) or BigQuery sources. - Custom Schema Management (
gemini_enterprise_manage_schema): Upload, modification, and retrieval of JSON schemas for indexing structured documents. - Tuning & Controls (
gemini_enterprise_manage_controls): Creation of boost/bury rules, synonyms, redirects, and filters on Serving Configs. - SaaS Connectors (
gemini_enterprise_configure_connector): High-fidelity simulated flow with synchronization state management for Jira, Salesforce, and Confluence. - Agent Management (
gemini_enterprise_manage_agents): End-to-end CRUD operations (create, list, delete, update) for native, server-side Gemini Enterprise Agents. - License & Billing Management (
gemini_enterprise_manage_licenses): Programmatic management of user seats on Gemini Enterprise / Gemini Code Assist license pools.
๐ ๏ธ Installation & Setup
1. Prerequisites
- Node.js: v18.x or higher.
- Google Cloud SDK (
gcloud) installed and configured. - An active Google Cloud project with the Discovery Engine API enabled.
2. Local Authentication
Configure your local Application Default Credentials (ADC) pointing to your target GCP project:
gcloud auth application-default login
3. Environment Variables
Create a .env file in the root of the project (or set variables in your shell/IDE environment):
GCP_PROJECT=your-gcp-project-id
GCP_LOCATION=global # optional, defaults to global (supports us, eu, etc.)
GCP_COLLECTION=default_collection # optional, defaults to default_collection
# OPTIONAL BUT RECOMMENDED:
# Set this variable if you encounter a local quota/billing project mismatch error from gcloud.
GOOGLE_CLOUD_QUOTA_PROJECT=your-gcp-project-id
# SECURITY SCOPES (Enforces Least Privilege):
# Comma-separated list of allowed scopes: search, admin, billing.
# Example: Use 'search' for standard coding assistants, and 'search,admin' for SRE agents.
# Defaults to 'search,admin,billing' if not specified.
MCP_SCOPES=search,admin,billing
[!NOTE] Quota & Billing Troubleshooting: If during execution you receive an error like
7 PERMISSION_DENIED: Discovery Engine API has not been used in project..., your local user credentials are trying to attribute billing quotas to a disabled local sandbox project. SettingGOOGLE_CLOUD_QUOTA_PROJECTforces the SDK to attribute quotas to the correct project.
4. Build the Project
Install dependencies and compile TypeScript files into JavaScript ESM:
npm install
npm run build
๐งช Testing Suite
To ensure stability and facilitate onboarding, the repository includes a suite of testing scripts under the tests/ directory to validate connectivity, security, and the MCP interface:
test_mcp_client.mjs(MCP Protocol Handshake): Performs a standard handshake with the MCP server via stdio and prints the list of registered tools with their JSON schemas.node tests/test_mcp_client.mjstest_suite_readonly.mjs(GCP Read-Only Validation): Scans the available datastores in the configured GCP project, querying schemas, target sites, serving controls, and testing search queries.node tests/test_suite_readonly.mjstest_admin_write.mjs(GCP Control Plane Safe Write/Delete): Executes a complete read/write lifecycle on the Control Plane (creates a temporary synonym control, verifies its existence via list, and immediately deletes it). 100% safe with zero residue left on your Cloud project.node tests/test_admin_write.mjstest_agents_write.mjs(Native Agent Lifecycle Safe Write/Delete): Executes a complete lifecycle check on native Discovery Engine Agents (creates a temporary agent, lists and updates it, then deletes it with zero residues remaining).node tests/test_agents_write.mjstest_iam.mjs(App IAM Policy Roundtrip Validation): Verifies that retrieving and setting IAM policies on individual Engines/Apps works correctly and safely.node tests/test_iam.mjstest_mcp_scopes.mjs(Scope & Security Enforcement Suite): Validates that environment-based tool restrictions (MCP_SCOPES) work correctly. It testssearchonly,search,billing, and full scopes, verifying that unauthorized attempts to call out-of-scope tools are securely rejected with access denied responses.node tests/test_mcp_scopes.mjs
๐ Running & Installing the Server
The MCP server communicates via stdio transport. You can easily register it, compile it locally, or automate the entire setup.
โก Option A: Automatic Installation (Highly Recommended)
You can automatically add and register ge-app-mcp in your favorite AI coding assistant (Claude Desktop, Cursor, Claude Code, etc.) using the open-source add-mcp utility:
npx add-mcp ge-app-mcp --env "GCP_PROJECT=your-gcp-project-id" --env "MCP_SCOPES=search,admin,billing"
(This automatically discovers your installed AI agents, configures their configuration files, and passes the required environment variables securely.)
Option B: Manual Execution via npx
To run the server directly from npm without cloning:
npx -y ge-app-mcp
Option C: Compile and Run Locally
# Clone, install dependencies, compile and start:
npm install
npm run build
npm start
# In development with hot-reloading:
npm run dev
๐งฉ Managing Pre-Built Agent Skills
This project fully supports the open Agent Skills specification (compatible with Vercel's skills CLI and standard coding agents). You can manage them in two ways:
โก Option A: Automatic via Vercel's skills CLI (Recommended)
You can instantly install and load all our pre-built enterprise skills into your workspace using Vercel's skills CLI:
npx skills add miticojo/ge-app-mcp
Option B: Handled via the Local package CLI
If you prefer, you can use the built-in CLI utility bundled with our package to list and copy skills manually:
1. List Available Pre-Built Skills
npx ge-app-mcp skills list
2. Install a Pre-Built Skill
Copy a pre-built skill folder into your local project workspace (defaults to ./skills/ if target directory is omitted):
npx ge-app-mcp skills install <skill-id> [target-directory]
# Example:
npx ge-app-mcp skills install admin-assistant ./my-skills
๐ค AI Agents & IDE Integration (Cursor, Windsurf, Claude Desktop, etc.)
For detailed, copy-paste configurations to integrate this server into your preferred AI agent workflows, see our dedicated integration guide:
๐ [AGENTS.md](file://./AGENTS.md)
It provides comprehensive configurations for:
- Cursor / Windsurf / Claude Desktop (Direct stdio setup using
npx ge-app-mcp). - Google Agent Development Kit (ADK) (Native orchestration with
MCPToolset). - LangChain & LangGraph (Python & TypeScript integrations).
- CrewAI.
๐ Project Structure
ge-app-mcp/
โโโ LICENSE # Apache 2.0 License
โโโ README.md # This file
โโโ AGENTS.md # Integration guide for AI Agents (ADK, LangChain, Cursor)
โโโ package.json
โโโ tsconfig.json
โโโ src/
โ โโโ index.ts # MCP Server entrypoint (tool routing)
โ โโโ config.ts # GCP environment variable configuration
โ โโโ tools/
โ โโโ search.ts # Search tool implementations (Data Plane)
โ โโโ admin.ts # Admin tool implementations (Control Plane)
โ โโโ billing.ts # Billing & license management tools (Control Plane)
โโโ skills/ # Agent Skills templates conforming to Vercel Agent Skills standard
โโโ admin-assistant/
โ โโโ SKILL.md # Skill for DevOps and infrastructure orchestration
โโโ enterprise-context/
โ โโโ SKILL.md # Skill for secure zero-trust enterprise search
โโโ codebase-rag/
โโโ SKILL.md # Skill for debugging and conversational code context
๐ License
This project is licensed under the Apache License, Version 2.0. See the [LICENSE](file://./LICENSE) file for more information.
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.