aws-strands-agents-mcp-demo

This project demonstrates how to build an MCP server that searches for stock photography based on current location and weather conditions. It utilizes AWS's Strands Agents to enable seamless interaction with external services, showcasing context-aware automation.

GitHub Stars

3

User Rating

Not Rated

Forks

0

Issues

0

Views

1

Favorites

0

README
AWS Strands Agents: Building and Connecting Your First Model Context Protocol (MCP) Server
Overview

Deploy an MCP server that searches for stock photography based on your current location and conditions using third-party APIs, and orchestrate it with Strands Agents and the Amazon Q Developer CLI.

The Model Context Protocol (MCP) provides a standardized interface that enables AI agents to interact seamlessly with external services. In this post, we’ll demonstrate how to build an MCP server that integrates with Shutterstock — my favorite platform for high-quality licensed images, videos, music, and creative tools — using their robust API. We’ll then show how to expose these rich media search capabilities to agents developed with Strands Agents, AWS’s code-first framework for building production-ready AI agents. By orchestrating multiple agents, we’ll enable them to access the National Weather Service (NWS) API, intelligently select contextually relevant photos based on current weather conditions, and deliver results that showcase the power of reasoning and context-aware automation.

JavaScript/Node.js MCP Servers based on: https://github.com/lucianoayres/mcp-server-node.

Prerequisites
  • Git distributed version control system
  • Node.js v22.16.01 LTS or newer (MCP servers)
  • npm, Yarn, or other Node.js package manager
  • Python 3.13.x (Strands Agents)
  • pip, Poetry, or another Python package manager
  • AWS Account (for access to Amazon Bedrock generative AI models; other model providers are also supported)
  • Free Shutterstock Test Account and Token (Register at Shutterstock Developers)
  • Optional: Amazon Q Developer CLI for last section of post
Installation
  1. Clone Repository and Install Packages
npm install -g corepack # if using yarn

git clone https://github.com/garystafford/aws-strands-agents-mcp-demo.git
cd aws-strands-agents-mcp-demo

yarn install
  1. Start MCP Servers
# terminal window 1: STDIO transport
# environment variables are set by MCP server with STDIO
export API_KEY=abc-1234567890
export SHUTTERSTOCK_API_TOKEN=<YOUR_SHUTTERSTOCK_API_TOKEN>
node mcp-server.js

# terminal window 2: Streamable HTTP transport
# environmental variables are set by agent with Streamable HTTP
node mcp-server-remote.js
  1. Install Strands Agents
python -m pip install virtualenv -Uqqq
python -m venv .venv
source .venv/bin/activate

python -m pip install pip -Uqqq
python -m pip install -r requirements.txt -Uqqq
  1. Start Strands Agents
export API_KEY=abc-1234567890
export SHUTTERSTOCK_API_TOKEN=<YOUR_SHUTTERSTOCK_API_TOKEN>

python agent_stdio_multi_agent.py

The contents of this repository represent my viewpoints and not of my past or current employers, including Amazon Web Services (AWS). All third-party libraries, modules, plugins, and SDKs are the property of their respective owners.

Author Information
Gary A. Stafford

AWS Area Principal Solutions Architect | AWS Certified Professional | Cloud | Data | Containers | Serverless | DevOps | Polyglot Developer

Amazon Web Services (AWS)New York, USA

753

Followers

206

Repositories

923

Gists

8

Total Contributions

Top Contributors

Threads