jasperreports-mcp-server

mr-wolf-gb/jasperreports-mcp-server

3.2

If you are the rightful owner of jasperreports-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

JasperReports MCP Server is a comprehensive Node.js server that integrates JasperReports Server REST API v2 with Model Context Protocol (MCP) tools, enabling seamless operations for AI assistants and developers.

Tools
5
Resources
0
Prompts
0

JasperReports MCP Server

npm version License: GPL-3.0 Node.js Version MCP Compatible CI/CD Pipeline codecov

A comprehensive Node.js Model Context Protocol (MCP) server for JasperReports Server REST API v2. This server enables AI assistants and developers to perform all major JasperReports operations including authentication, resource management, report execution, job scheduling, and administrative tasks through standardized MCP tools.

Perfect for integrating JasperReports functionality into AI-powered IDEs like Cursor, Kiro, Windsurf, Claude Desktop, and any other MCP-compatible development environment.

Features

  • ๐Ÿ”Œ MCP Compatible: Works seamlessly with Cursor, Kiro, Windsurf, and other MCP-enabled IDEs
  • ๐Ÿ” Complete JasperReports Integration: Full support for JasperReports Server REST API v2
  • ๐Ÿ”‘ Multiple Authentication Methods: Basic, login service, and argument-based authentication
  • ๐Ÿ“ Resource Management: Upload, list, update, and delete reports and resources
  • ๐Ÿ“Š Report Execution: Synchronous and asynchronous report generation in multiple formats (PDF, Excel, CSV, etc.)
  • โฐ Job Scheduling: Create and manage scheduled report jobs with cron expressions
  • ๐ŸŽ›๏ธ Input Controls: Handle report parameters and cascading controls
  • ๐Ÿ‘ฅ Administrative Tools: User, role, and permission management
  • ๐Ÿงช Test Server: HTTP endpoint for testing and validation
  • ๐Ÿ›ก๏ธ Enterprise Ready: SSL support, timeout handling, and comprehensive error management
  • ๐Ÿ“ Comprehensive Logging: Debug and production logging with configurable levels

IDE Integration

Cursor IDE

  1. Install the MCP server globally:
npm install -g jasperreports-mcp-server
  1. Add to your Cursor settings (.cursor-settings/mcp.json):
{
  "mcpServers": {
    "jasperreports-server": {
      "command": "npx",
      "args": ["jasperreports-mcp-server"],
      "env": {
        "JASPER_URL": "http://localhost:8080/jasperserver",
        "JASPER_USERNAME": "jasperadmin",
        "JASPER_PASSWORD": "jasperadmin",
        "JASPER_AUTH_TYPE": "basic"
      }
    }
  }
}

Kiro IDE

  1. Install the server:
npm install -g jasperreports-mcp-server
  1. Configure in .kiro/settings/mcp.json:
{
  "mcpServers": {
    "jasperreports-server": {
      "command": "jasperreports-mcp-server",
      "env": {
        "JASPER_URL": "http://localhost:8080/jasperserver",
        "JASPER_USERNAME": "jasperadmin",
        "JASPER_PASSWORD": "jasperadmin"
      },
      "autoApprove": [
        "jasper_authenticate",
        "jasper_test_connection",
        "jasper_list_resources"
      ]
    }
  }
}

Windsurf IDE

  1. Install globally:
npm install -g jasperreports-mcp-server
  1. Add to Windsurf MCP configuration:
{
  "mcpServers": {
    "jasperreports-server": {
      "command": "npx",
      "args": ["jasperreports-mcp-server"],
      "env": {
        "JASPER_URL": "https://your-jasper-server.com/jasperserver",
        "JASPER_USERNAME": "your-username",
        "JASPER_PASSWORD": "your-password",
        "JASPER_SSL_VERIFY": "true"
      }
    }
  }
}

Claude Desktop

  1. Install the server:
npm install -g jasperreports-mcp-server
  1. Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
  "mcpServers": {
    "jasperreports-server": {
      "command": "jasperreports-mcp-server",
      "env": {
        "JASPER_URL": "http://localhost:8080/jasperserver",
        "JASPER_USERNAME": "jasperadmin",
        "JASPER_PASSWORD": "jasperadmin"
      }
    }
  }
}

Other MCP-Compatible IDEs

For any IDE that supports the Model Context Protocol:

  1. Install the server:
npm install -g jasperreports-mcp-server
  1. Add the server configuration to your IDE's MCP settings file:
{
  "mcpServers": {
    "jasperreports-server": {
      "command": "jasperreports-mcp-server",
      "env": {
        "JASPER_URL": "your-jasper-server-url",
        "JASPER_USERNAME": "your-username",
        "JASPER_PASSWORD": "your-password"
      }
    }
  }
}

Quick Start

Local Development

  1. Clone and install:
git clone https://github.com/mr-wolf-gb/jasperreports-mcp-server.git
cd jasperreports-mcp-server
npm install
  1. Configure environment variables:
cp .env.example .env
# Edit .env with your JasperReports Server details
  1. Start the server:
# Start the MCP server
npm start

# Start in development mode with auto-reload
npm run dev

# Start the test server for HTTP testing
npm run test-server

Production Installation

# Install globally
npm install -g jasperreports-mcp-server

# Or use with npx (recommended)
npx jasperreports-mcp-server

Development

Project Structure

src/
โ”œโ”€โ”€ config/          # Configuration management
โ”œโ”€โ”€ services/        # Business logic services
โ”œโ”€โ”€ utils/           # Utility functions
โ”œโ”€โ”€ models/          # Data models and schemas
โ”œโ”€โ”€ tools/           # MCP tool definitions
โ”œโ”€โ”€ index.js         # Main MCP server entry point
โ””โ”€โ”€ testServer.js    # Express test server

test/
โ”œโ”€โ”€ unit/            # Unit tests
โ”œโ”€โ”€ integration/     # Integration tests
โ”œโ”€โ”€ fixtures/        # Test data and fixtures
โ””โ”€โ”€ utils/           # Test utilities

docs/                # Documentation and examples

Available Scripts

  • npm start - Start the MCP server
  • npm run dev - Start with auto-reload
  • npm test - Run all tests
  • npm run test:watch - Run tests in watch mode
  • npm run test:coverage - Run tests with coverage report
  • npm run lint - Run ESLint
  • npm run lint:fix - Fix ESLint issues
  • npm run format - Format code with Prettier
  • npm run format:check - Check code formatting
  • npm run test-server - Start HTTP test server

Testing

# Run all tests
npm test

# Run tests with coverage
npm run test:coverage

# Run tests in watch mode
npm run test:watch

Configuration

Environment Variables

The server is configured through environment variables:

VariableDescriptionDefaultRequired
JASPER_URLJasperReports Server URL-โœ…
JASPER_USERNAMEUsername for authentication-โœ…
JASPER_PASSWORDPassword for authentication-โœ…
JASPER_AUTH_TYPEAuthentication method (basic/login/argument)basicโŒ
JASPER_ORGANIZATIONOrganization for multi-tenant setups-โŒ
JASPER_TIMEOUTRequest timeout in milliseconds30000โŒ
JASPER_DEBUG_MODEEnable debug loggingfalseโŒ
JASPER_SSL_VERIFYVerify SSL certificatestrueโŒ
TEST_SERVER_PORTPort for HTTP test server3000โŒ
TEST_SERVER_ENABLEDEnable HTTP test serverfalseโŒ
NODE_ENVNode.js environmentproductionโŒ
LOG_LEVELLogging level (error/warn/info/debug)infoโŒ

Configuration Examples

The config/ directory contains ready-to-use MCP configuration examples:

  • mcp-development.json: Local development with debug logging
  • mcp-production.json: Production setup with security best practices
  • mcp-docker.json: Docker-based deployment configuration

Copy the appropriate configuration to your IDE's MCP settings and customize the environment variables.

Available MCP Tools

The server provides 40+ MCP tools organized into logical categories:

๐Ÿ” Authentication & Connection

  • jasper_authenticate - Authenticate with JasperReports Server
  • jasper_test_connection - Test server connectivity and health

๐Ÿ“ Resource Management

  • jasper_upload_resource - Upload JRXML reports and resources
  • jasper_list_resources - List repository resources with filtering
  • jasper_get_resource - Retrieve resource details and content
  • jasper_update_resource - Update existing resources
  • jasper_delete_resource - Delete resources and folders

๐Ÿ“Š Report Execution

  • jasper_run_report_sync - Execute reports synchronously (PDF, Excel, CSV, etc.)
  • jasper_run_report_async - Start asynchronous execution for large reports
  • jasper_get_execution_status - Check execution status and progress
  • jasper_get_execution_result - Retrieve execution results and files
  • jasper_cancel_execution - Cancel running executions

โฐ Job Scheduling

  • jasper_create_job - Create scheduled jobs with cron expressions
  • jasper_list_jobs - List existing jobs with filtering
  • jasper_update_job - Modify job schedules and parameters
  • jasper_delete_job - Remove scheduled jobs
  • jasper_run_job_now - Execute jobs immediately

๐ŸŽ›๏ธ Input Controls & Parameters

  • jasper_get_input_controls - Get report parameters and controls
  • jasper_set_input_control_values - Set parameter values for cascading controls
  • jasper_validate_input_controls - Validate parameter values

๐Ÿ‘ฅ User & Role Management

  • jasper_create_user - Create new user accounts
  • jasper_list_users - List users with filtering
  • jasper_update_user - Update user details and roles
  • jasper_create_role - Create new roles
  • jasper_list_roles - List available roles

๐Ÿ”’ Permissions & Security

  • jasper_get_permissions - Get resource permissions
  • jasper_set_permissions - Set resource permissions for users/roles

๐Ÿข Domain Management

  • jasper_list_domains - List semantic layer domains
  • jasper_get_domain - Get domain definitions
  • jasper_get_domain_schema - Get domain schema and fields

๐Ÿ› ๏ธ Utilities & Templates

  • jasper_get_report_template - Get JRXML report templates
  • jasper_get_datasource_structure - Get datasource configuration templates

๐Ÿ“Š Health & Monitoring

  • jasper_health_status - Get comprehensive health status
  • jasper_deep_health_check - Perform deep system health checks
  • jasper_performance_metrics - Get performance and memory metrics
  • jasper_component_health - Test specific system components
  • jasper_resilience_stats - Get resilience and retry statistics

Usage Examples

Basic Report Execution

// Authenticate first
await jasper_authenticate({
  username: "jasperadmin",
  password: "jasperadmin"
});

// List available reports
const reports = await jasper_list_resources({
  folderUri: "/reports",
  resourceType: "reportUnit"
});

// Execute a report
const result = await jasper_run_report_sync({
  reportUri: "/reports/SampleReport",
  outputFormat: "pdf",
  parameters: {
    "StartDate": "2024-01-01",
    "EndDate": "2024-12-31"
  }
});

Upload and Schedule Reports

// Upload a new report
await jasper_upload_resource({
  resourcePath: "/reports/MyReport",
  label: "My Custom Report",
  jrxmlContent: "<?xml version='1.0'?>...",
  resourceType: "reportUnit"
});

// Create a scheduled job
await jasper_create_job({
  label: "Daily Sales Report",
  reportUri: "/reports/MyReport",
  schedule: {
    type: "simple",
    recurrenceInterval: 1,
    recurrenceIntervalUnit: "DAY"
  },
  outputFormats: ["pdf", "xlsx"],
  recipients: ["manager@company.com"]
});

Docker Support

Quick Start with Docker

# Build the image
docker build -t jasperreports-mcp-server .

# Run with environment file
docker run -p 3000:3000 --env-file .env jasperreports-mcp-server

# Or use docker-compose for development
docker-compose up --build

Docker Configuration

Use the provided config/mcp-docker.json for Docker-based MCP setup:

{
  "mcpServers": {
    "jasperreports-server": {
      "command": "docker",
      "args": [
        "run", "--rm", "--network=host",
        "--env-file", ".env",
        "jasperreports-mcp-server"
      ]
    }
  }
}

Troubleshooting

Common Issues

Connection Refused

  • Verify JASPER_URL is correct and accessible
  • Check if JasperReports Server is running
  • Ensure network connectivity

Authentication Failed

  • Verify username and password
  • Check if the user account is enabled
  • Try different authentication methods (basic, login, argument)

SSL Certificate Errors

  • Set JASPER_SSL_VERIFY=false for development
  • Install proper SSL certificates for production
  • Use HTTP instead of HTTPS for local development

Tool Not Found

  • Ensure the MCP server is properly configured in your IDE
  • Check that the server is running and accessible
  • Verify environment variables are set correctly

Debug Mode

Enable debug logging for troubleshooting:

export JASPER_DEBUG_MODE=true
export LOG_LEVEL=debug

Health Checks

Use the built-in health check tools:

// Test basic connectivity
await jasper_test_connection();

// Comprehensive health check
await jasper_deep_health_check();

// Check specific components
await jasper_component_health({ component: "authentication" });

Documentation

  • ๐Ÿ“–
  • ๐Ÿ”ง
  • ๐Ÿš€
  • ๐Ÿ“
  • ๐Ÿ”
  • ๐Ÿ’ก

License

GPL-3.0-or-later License - see file for details.

Contributing

We welcome contributions! Please follow these steps:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Add tests for new functionality
  5. Ensure all tests pass (npm test)
  6. Run linting (npm run lint:fix)
  7. Commit your changes (git commit -m 'Add amazing feature')
  8. Push to the branch (git push origin feature/amazing-feature)
  9. Open a Pull Request

Development Setup

# Clone and install
git clone https://github.com/mr-wolf-gb/jasperreports-mcp-server.git
cd jasperreports-mcp-server
npm install

# Run tests
npm test
npm run test:coverage

# Start development server
npm run dev

Support & Community

Roadmap

  • GraphQL API support
  • WebSocket real-time updates
  • Advanced caching mechanisms
  • Multi-server load balancing
  • Enhanced security features
  • Visual report designer integration

Made with โค๏ธ by Mr-Wolf-GB for the JasperReports and MCP community