Skip to main content
Glama
JZ3736

FoldRun MCP Server

by JZ3736

Bring your own MCP to Gemini Enterprise with the (Mock) FoldRun MCP Server

This repository demonstrates the "Bring Your Own MCP" capability in Gemini Enterprise.

The original FoldRun architecture is available in the Google Cloud Life Sciences repository. FoldRun is an open-source accelerator designed to automate the end-to-end scientific workflow for protein structure prediction. It runs models such as Boltz2, OpenFold3, and AlphaFold 2. It is an intelligent orchestration layer that uses multi-agent collaboration to manage the entire lifecycle from hypothesis generation to structural validation.

Spinning up the entire FoldRun agent requires costly infrastructure. To make testing accessible, this repository provides a lightweight, mock FoldRun MCP server. It exposes three core tools built in Python (using FastMCP) to demonstrate how easily you can integrate custom external agents and harvest their capabilities directly within Gemini Enterprise.

What is in this repository?

  • foldrun_mcp_demo.py: The core FastMCP server that exposes three mock AI tools (submit_protein_prediction, get_job_status, get_prediction_results).

  • Dockerfile & .dockerignore: For containerizing the server for later deployment to Cloud Run.

  • requirements.txt: Python dependencies (mcp and uvicorn).

Architecture

  1. Transport: Uses the StreamableHTTP protocol (via Server-Sent Events / /mcp) which is natively compatible with Gemini Enterprise.

  2. State: Uses an in-memory Python dictionary to simulate a remote supercomputer cluster tracking jobs.

  3. Deployment: Serverless on Google Cloud Run listening on port 8080.


Deployment Guide

Follow these steps to deploy the server to Google Cloud Run and connect it to Gemini Enterprise.

Step 1: Deploy to Google Cloud Run

  1. Clone this repository to your local machine or open it directly in Google Cloud Shell.

  2. Ensure you have the gcloud CLI installed and authenticated to your GCP project.

  3. Run the following command from the root of the repository to deploy the container:

    gcloud run deploy foldrun-mcp-demo \
      --source . \
      --region us-central1 \
      --allow-unauthenticated \
      --port 8080
  4. Copy the Service URL provided at the end of the deployment (e.g., https://foldrun-mcp-demo-xxxxx.us-central1.run.app).

Step 2: (Optional) Local Testing

You can easily test your MCP tools locally before connecting them to Gemini.

  1. Install the dependencies in a virtual environment:

    python -m venv venv
    source venv/bin/activate
    pip install -r requirements.txt
  2. Use the official MCP CLI Inspector to interact with your tools via a local web UI:

    mcp dev foldrun_mcp_demo.py
  3. Open the provided localhost URL in your browser to test the submit_protein_prediction and get_job_status tools visually.

Step 3: Configure Gemini Enterprise

Gemini Enterprise requires an OAuth authentication layer, even if your Cloud Run service is set to --allow-unauthenticated. We will use Google's native OAuth endpoints as a passthrough.

  1. Go to the Google Cloud Console -> APIs & Services -> Credentials.

  2. Click Create Credentials -> OAuth client ID.

  3. Select Web application as the application type.

  4. Set the Authorized redirect URIs to https://extensions.googleapis.com/auth.

  5. Click Create and save your Client ID and Client Secret.

Step 4: Create the Data Store in Gemini Enterprise

  1. Open Gemini Enterprise

  2. Go to Apps -> Data stores -> Create data store -> Custom MCP Server.

  3. Fill out the configuration form:

    • Data connector name: foldrun-mcp

    • MCP Server URL: Your Cloud Run Service URL from Step 1, with /mcp appended to the end. (e.g., https://foldrun-mcp-demo-xxxxx.us-central1.run.app/mcp)

    • Authentication mechanism: OAUTH

    • Authorization URL: https://accounts.google.com/o/oauth2/auth

    • Token URL: https://oauth2.googleapis.com/token

    • OAuth client ID: The Client ID from Step 3.

    • OAuth client secret: The Client Secret from Step 3.

    • OAuth scopes: email profile

  4. Click Create and follow the Google Sign-in prompt.

  5. Your connection status should turn Green (Active).

Step 5: Verify and Enable Actions

By default, newly connected MCP tools are turned off. To enable them:

  1. Click on your newly created data store and ensure the status has changed from Creating to Active.

  2. Go to the Actions tab and click Reload custom actions to fetch the available tools from your Cloud Run server.

  3. Select the checkboxes next to the retrieved tools (submit_protein_prediction, get_job_status, get_prediction_results).

  4. Click Enable actions.

Refer to this link for more details on connecting your MCP to Gemini Enterprise.

Testing Your Agent

Once your Data Store is connected to a Chat App/Agent in Gemini Enterprise, try the following prompts to verify each tool is working.

Tool 1 — submit_protein_prediction

"Submit a new AlphaFold2 prediction for the sequence MKALIVLGLVLLSVTV. Name the job my-first-test."

↳ Expected: Gemini calls the tool and returns a new job_id (e.g., foldrun-af2-a1b2c3) and an estimated runtime.

Tool 2 — get_job_status

"Check the status of the protein prediction job foldrun-af2-demo01."

↳ Expected: Gemini calls the tool and returns the current stage, progress percentage, and a status message (e.g., 35% — running MSA search).

Tool 3 — get_prediction_results

"Get the final structure results and expert analysis for the AlphaFold job foldrun-af2-demo01."

↳ Expected: Gemini calls the tool and returns quality metrics (pLDDT, pTM score), output file paths, and a detailed structural analysis paragraph.

Modifying for Production

This server returns hardcoded, mock data. To make it real:

  1. Rewrite submit_protein_prediction to make an API call to Vertex AI Pipelines or an external compute cluster to actually run AlphaFold.

  2. Rewrite get_prediction_results to download the generated .pdb files from Google Cloud Storage and parse the real scientific data.

F
license - not found
-
quality - not tested
C
maintenance

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/JZ3736/foldrun-mcp-GE-demo'

If you have feedback or need assistance with the MCP directory API, please join our Discord server