fluxlora-mcp
Provides tools for discovering and accessing LoRA models from the HuggingFace Hub, enabling AI agents to find and use open-source style adaptations for image generation.
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., "@fluxlora-mcpGenerate an oil painting of a mountain landscape"
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.
FluxLoRA MCP Server
An MCP (Model Context Protocol) server that lets users and autonomous agents generate high-quality images in a chosen artistic style by automatically discovering and applying open-source LoRA (Low-Rank Adaptation) models.
Features
Tool:
generate_image- Generate images with automatic LoRA selection based on styleTool:
discover_loras- Search for LoRA models from HuggingFace Hub or local directoriesTool:
save_image_to_disk- Save generated images to the local filesystemResource:
lora://{name}- Access metadata for LoRA modelsResource:
config://defaults- View effective configuration defaultsPrompts - Helper prompts for LLMs to use the tools effectively
Project Structure
fluxlora-mcp/
├── bin/ # Executable scripts
├── scripts/ # Dev utility scripts
├── src/
│ ├── config/ # Environment configuration
│ ├── mcp/ # MCP server implementation
│ ├── prompts/ # System prompts for LLMs
│ ├── resources/ # MCP resources
│ ├── services/ # External service integrations
│ │ ├── fal/ # Fal.ai client for image generation
│ │ ├── fs/ # Filesystem operations
│ │ └── hf/ # HuggingFace Hub client
│ ├── tools/ # MCP tool implementations
│ │ ├── discover_loras.ts
│ │ ├── generate_image.ts
│ │ └── save_image_to_disk.ts
│ ├── types/ # TypeScript type definitions
│ └── utils/ # Utility functions
├── IMPLEMENTATION-PLAN.md # Current status and roadmap
└── README.md # This fileTechnology Stack
TypeScript: Type-safe JavaScript for robust development
Zod: Runtime validation for input/output schemas
MCP SDK: Integration with the Model Context Protocol
Fal.ai Client: API client for image generation
HuggingFace Hub: API client for discovering LoRA models
Installation
# Clone the repository
git clone https://github.com/yourusername/fluxlora-mcp.git
cd fluxlora-mcp
# Install dependencies
npm installConfiguration
Copy the example environment file and update with your settings:
cp .env.example .envRequired environment variables:
FAL_KEY- Your Fal API key (get one from Fal.ai)HF_TOKEN- Optional Hugging Face API token for increased rate limits
Development
# Start the server in development mode
npm run dev
# Build the project with TypeScript
npm run build
# Create an optimized bundle with esbuild
npm run bundle
# Run tests
npm test
# Run the MCP Inspector with your development server
npm run inspect
# Lint and typecheck your code
npm run lint
npm run typecheckUsing the MCP Inspector
The project includes integration with the MCP Inspector, an interactive developer tool for testing and debugging MCP servers.
With the Inspector, you can:
Test your tools, resources, and prompts interactively
Inspect server responses and error handling
Subscribe to resources and observe real-time updates
Verify tool schemas and input validation
To use the Inspector:
First build your project:
npm run buildRun the inspector:
npm run inspectUse the web interface that opens automatically to interact with your server
Deployment
The project supports multiple build options:
TypeScript Build: Standard TypeScript compilation (
npm run build)Output:
dist/Usage:
node dist/index.js
Optimized Bundle: Single-file bundle with esbuild (
npm run bundle)Output:
dist/bundle/index.jsUsage:
node dist/bundle/index.jsBenefits: Faster startup, smaller deployment size, simpler dependencies
Usage
The server exposes an MCP-compatible API that can be used with any MCP client. Here are some examples:
Generate an Image
// Using an MCP client
const response = await client.invokeTool('generate_image', {
prompt: 'A watercolor portrait of a cyberpunk cat',
style: 'watercolor',
width: 512,
height: 512
});
console.log(response.image.url);Discover LoRA Models
const loras = await client.invokeTool('discover_loras', {
style: 'anime',
limit: 10
});
console.log(loras.results);Save an Image
const result = await client.invokeTool('save_image_to_disk', {
url: 'https://example.com/image.png'
});
console.log(result.filePath);Project Roadmap
Completed
✅ MCP server with protocol integration
✅ Fal.ai client implementation
✅ Image generation with parameter validation
✅ HuggingFace Hub integration for LoRA discovery
✅ Image storage utilities with security checks
✅ Configuration resource implementation
✅ System prompts for LLMs
In Progress
🔄 Testing infrastructure
🔄 Enhanced LoRA discovery with better style mapping
🔄 Local
.safetensorfile scanning
Planned
⏳ LoRA resource implementation
⏳ API response caching
⏳ Logging infrastructure
⏳ Performance optimization
⏳ Documentation site
⏳ Release automation
Future Enhancements
Batch image generation
Grid view outputs
ControlNet integration
Video and audio generation
Optional web UI
Documentation
For more detailed documentation, see:
Dependencies
MCP TypeScript SDK:
@modelcontextprotocol/sdkFal Client:
@fal-ai/clientHuggingFace Hub:
@huggingface/hubZod:
zod
License
MIT
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/darekrossman/fluxlora-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server