MCP-CRUD-Interview-Question

MCP-CRUD-Interview-Question

0

The project is a Spring Boot-based MCP server that manages a database of interview questions. It leverages Spring AI for tool-based interaction with data and offers features like category filtering and CRUD operations for questions.

MCP-CRUD-Interview-Question

A Spring Boot-based Model Control Protocol (MCP) server designed to manage a database of interview questions. This project leverages Spring AI's MCP capabilities to provide tool-based access to interview questions data.

Spring Boot Java Spring AI

Overview

This project serves as an MCP (Model Control Protocol) server built with Spring Boot and Spring AI. It provides a service for managing interview questions through tool-based interactions, making it easy to retrieve, create, update, and delete interview questions from a database.

Features

  • Interview Question Management: Create, read, update, and delete interview questions
  • Category-based Filtering: Retrieve questions by specific categories
  • Tool-based API: Spring AI's tool annotations for easy integration
  • MySQL Database Integration: Persistence for interview questions

Project Structure

src/
├── main/
│   ├── java/
│   │   └── io/
│   │       └── michaeljgkopp/
│   │           └── github/
│   │               ├── dao/
│   │               │   └── InterviewQuestionRepository.java
│   │               ├── entity/
│   │               │   └── InterviewQuestion.java
│   │               ├── service/
│   │               │   └── InterviewQuestionService.java
│   │               └── SpringMcpServerApplication.java
│   └── resources/
│       ├── application.properties
│       └── create_db.sql

Requirements

  • Java 24
  • MySQL Database
  • Maven 3.6+ or compatible build tool

Installation

Clone the Repository

git clone https://github.com/MichaelJGKopp/MCP-CRUD-Interview-Question.git
cd MCP-CRUD-Interview-Question

Database Setup

  1. Create the required MySQL database:
CREATE DATABASE IF NOT EXISTS mcp_interview_questions_db;
  1. Configure a MySQL user with appropriate permissions (or use existing credentials with proper access)

Configuration

The application is configured via application.properties. You can customize these settings or override them using environment variables:

spring.application.name=interview-questions-mcp-server
spring.main.web-application-type=none
spring.ai.mcp.server.name=interview-questions-mcp-server
spring.ai.mcp.server.version=0.0.1

server.port=${SERVER_PORT:3001}

spring.jpa.hibernate.ddl-auto=update

spring.datasource.url=${DB_URL:jdbc:mysql://localhost:3306/mcp_interview_questions_db}
spring.datasource.username=${DB_USERNAME:springstudent}
spring.datasource.password=${DB_PASSWORD:springstudent}

Build the Project

mvn clean package

Run the Server

java -jar target/spring-mcp-server-0.0.1-SNAPSHOT.jar

Or with custom environment variables:

SERVER_PORT=3002 DB_USERNAME=custom_user DB_PASSWORD=secure_password java -jar target/spring-mcp-server-0.0.1-SNAPSHOT.jar

Available Tools

The MCP server exposes the following tools for interaction:

Tool NameDescription
iqs_get_interview_questions_by_categoryRetrieves interview questions filtered by a specific category
iqs_get_interview_questions_allRetrieves all interview questions in the database
iqs_save_interview_questionCreates a new interview question or updates an existing one
iqs_delete_interview_question_by_idDeletes an interview question by its ID
iqs_delete_all_interview_questionsDeletes all interview questions (use with caution)

Interview Question Model

Each interview question consists of the following fields:

FieldDescription
idUnique identifier (auto-generated)
difficultyDifficulty level of the question (limited to 10 characters)
categoryCategory of the question (e.g., "Java", "SQL", "Spring")
titleBrief title for the question
questionThe interview question text (limited to 1000 characters)
answerThe answer or solution (limited to 10000 characters)

Integration with AI Models

This MCP server is designed to work with Spring AI, allowing AI models to interact with the interview questions database using the provided tools. The server does not expose a traditional web interface as indicated by spring.main.web-application-type=none in the configuration.

Development

Adding New Categories

The system supports any string-based category. To add questions in a new category, simply use that category name when creating questions.

Extending the Model

To extend the InterviewQuestion model with additional fields:

  1. Update the InterviewQuestion.java entity class
  2. Add appropriate getters and setters
  3. Restart the application (the database schema will update automatically due to spring.jpa.hibernate.ddl-auto=update)

License

This project is open source. For detailed license information, please contact the repository owner.

Contact

For questions or support, please contact Michael J.G. Kopp.