ifrc-go-admin-mcp-server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@ifrc-go-admin-mcp-serverShow me recent earthquake-related DREF operations"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
IFRC GO Admin API MCP Server
A Model Context Protocol (MCP) server that provides access to the International Federation of Red Cross and Red Crescent Societies (IFRC) GO Admin API for disaster relief emergency fund (DREF) data.
Features
DREF Operations: Access completed and ongoing disaster relief emergency fund operations
Appeals: Query humanitarian funding appeals
Emergencies: Get emergency event and disaster data
Search & Filter: Search by country, disaster type, and other criteria
Caching: Built-in response caching to reduce API load
Pagination: Handle large datasets efficiently
Related MCP server: DoorDash MCP Server
Prerequisites
Node.js 18.0.0 or higher
npm or yarn package manager
MCP-compatible client (Claude Desktop, etc.)
Installation
1. Install Dependencies
npm install2. Build the Project
npm run build3. Test the Server
npm startUsage
Configure in Claude Desktop
Add to your Claude Desktop configuration file (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"ifrc-go-admin": {
"command": "node",
"args": ["/path/to/your/ifrc-go-admin-mcp-server/dist/index.js"]
}
}
}Available Tools
get_completed_drefs: Retrieve completed DREF operations
get_ongoing_drefs: Get currently active DREF operations
get_appeals: Access humanitarian appeals for funding
get_emergencies: Query emergency events and disasters
search_drefs_by_country: Find DREF operations by country ISO code
search_drefs_by_disaster_type: Search by disaster type (flood, earthquake, etc.)
get_dref_statistics: Get summary statistics about DREF operations
Example Queries for AI Assistants
"Show me recent earthquake-related DREF operations"
"What are the ongoing emergency appeals in Bangladesh?"
"Compare funding amounts for cyclone vs flood disasters this year"
"List all completed DREF operations in West Africa"
Development
Scripts
npm run build- Compile TypeScript to JavaScriptnpm run dev- Watch mode for developmentnpm start- Start the production servernpm test- Test server startup
API Exploration
Before implementing, explore the API endpoints:
# Test basic connectivity
curl "https://goadmin.ifrc.org/api/v2/dref/?limit=1"
# Check completed DREFs
curl "https://goadmin.ifrc.org/api/v2/completed_dref/?limit=5"
# Search by country
curl "https://goadmin.ifrc.org/api/v2/dref/?country__iso=BD"Adding New Endpoints
Update Types: Add TypeScript interfaces for new data structures
Extend API Client: Add methods to
IFRCAPIClientclassRegister Tools: Add tool definitions in
ListToolsRequestSchemahandlerImplement Handlers: Add case in
CallToolRequestSchemahandler
Pagination Best Practices
Following IFRC API documentation guidelines:
Default limit is 50 records per page
Maximum limit is 1000 records per page
Stop pagination when returned records < limit
Check for empty array [] to confirm no more data
Use offset-based pagination with limit/offset parameters
Rate Limiting Considerations
The server includes basic caching (5-minute timeout) to be respectful of IFRC's infrastructure. For production use:
Implement exponential backoff for retries
Add request rate limiting
Monitor API usage and respect any documented limits
Consider using webhooks for real-time updates if available
Error Handling
The server includes comprehensive error handling:
HTTP errors from the API
Invalid parameters
Network timeouts
Cache management
Authentication
Currently, the IFRC GO Admin API appears to be publicly accessible. If authentication is required:
Add API key management to the
IFRCAPIClientclassInclude authentication headers in requests
Handle authentication errors appropriately
Data Schema Examples
DREF Operation
{
"id": 12345,
"title": "Bangladesh: Cyclone Mocha",
"country": "Bangladesh",
"disaster_type": "Cyclone",
"amount_requested": 500000,
"amount_funded": 500000,
"disaster_start_date": "2023-05-14",
"status": "completed"
}Emergency Event
{
"id": 67890,
"name": "Morocco Earthquake September 2023",
"countries": ["Morocco"],
"disaster_type": "Earthquake",
"num_affected": 300000,
"disaster_start_date": "2023-09-08"
}Project Structure
ifrc-go-admin-mcp-server/
├── src/
│ └── index.ts # Main MCP server implementation
├── dist/ # Compiled JavaScript output
├── package.json # Project configuration
├── tsconfig.json # TypeScript configuration
└── README.md # This fileContributing
Fork the repository
Create a feature branch
Make your changes
Add tests for new functionality
Submit a pull request
Humanitarian Use Guidelines
This server provides access to sensitive humanitarian data. Please:
Use responsibly and respect the humanitarian context
Don't overwhelm the IFRC API with excessive requests
Consider data privacy when analyzing beneficiary information
Contribute improvements back to the humanitarian community
Support
For issues related to:
MCP Server: Open an issue in this repository
IFRC GO API: Contact IFRC technical support
Data Questions: Refer to IFRC GO documentation
License
MIT License - See LICENSE file for details.
Acknowledgments
International Federation of Red Cross and Red Crescent Societies
Model Context Protocol development team
Open source humanitarian technology community
This server cannot be installed
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/jmesplana/ifrc-go-admin-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server