Spaces:
				
			
			
	
			
			
		Sleeping
		
	
	
	
			
			
	
	
	
	
		
		
		Sleeping
		
	metadata
			title: SpringGeminiChat
emoji: π’
colorFrom: purple
colorTo: yellow
sdk: docker
app_port: 7860
pinned: false
π€ Spring Gemini Chat
A modern, reactive Spring Boot application that integrates with Google's Gemini AI to provide intelligent chat capabilities. Built with Spring WebFlux for high-performance, non-blocking operations and featuring a clean, responsive web interface.
πΈ Screenshots
Chat Interface
 Modern, responsive chat UI with real-time messaging
Modern, responsive chat UI with real-time messaging
API Response Example
 JSON response structure from the Gemini integration
JSON response structure from the Gemini integration
Health Check Dashboard
β¨ Features
- π Reactive Programming - Built with Spring WebFlux for non-blocking operations
- π€ Gemini AI Integration - Powered by Google's latest Gemini AI model
- π¬ Real-time Chat - Instant responses with typing indicators
- π¨ Modern UI - Clean, responsive web interface
- π± Mobile Friendly - Works seamlessly on all devices
- π Health Monitoring - Built-in health checks and status indicators
- π‘οΈ Error Handling - Comprehensive error handling and validation
- β‘ High Performance - Optimized for speed and scalability
- π§ Easy Configuration - Environment-based configuration
- π Conversation Context - Support for contextual conversations
π οΈ Technology Stack
Backend
- Java 17 - Programming language
- Spring Boot 3.1.5 - Application framework
- Spring WebFlux - Reactive programming
- Spring Validation - Input validation
- Maven - Dependency management
- Google Gemini AI - AI language model
Frontend
- HTML5 - Structure
- CSS3 - Styling with modern animations
- Vanilla JavaScript - Interactive functionality
- Fetch API - HTTP requests
π Prerequisites
Before you begin, ensure you have the following installed:
- βοΈ Java 17 or higher
- βοΈ Maven 3.6+
- βοΈ Git
- βοΈ Google Gemini API Key (Get it here)
π Quick Start
1. Clone the Repository
git clone https://github.com/yourusername/spring-gemini-chat.git
cd spring-gemini-chat
2. Set Environment Variables
# Windows
set GEMINI_API_KEY=your_actual_gemini_api_key_here
# macOS/Linux
export GEMINI_API_KEY=your_actual_gemini_api_key_here
3. Build and Run
# Clean and install dependencies
mvn clean install
# Run the application
mvn spring-boot:run
4. Access the Application
- Backend API: http://localhost:8080
- Health Check: http://localhost:8080/api/chat/health
- Frontend UI: Open chat-ui.htmlin your browser
π API Documentation
Base URL
http://localhost:8080/api/chat
Endpoints
π¬ Send Message
POST /message
Content-Type: application/json
{
  "message": "Hello, how are you?"
}
Response:
{
  "response": "I'm doing well, thank you for asking! How can I help you today?",
  "success": true,
  "error": null,
  "timestamp": 1692994488297
}
π£οΈ Conversation with Context
POST /conversation
Content-Type: application/json
{
  "messages": [
    {
      "role": "user",
      "content": "What is Spring Boot?"
    },
    {
      "role": "assistant", 
      "content": "Spring Boot is a Java framework..."
    },
    {
      "role": "user",
      "content": "Can you give me an example?"
    }
  ]
}
π‘ Streaming Response
POST /stream
Content-Type: application/json
{
  "message": "Tell me a story"
}
π Health Check
GET /health
Response:
{
  "status": "UP",
  "service": "Chat Service", 
  "timestamp": 1692994488297
}
βοΈ Configuration
Application Properties
# Server Configuration
server.port=8080
# Gemini AI Configuration
gemini.api.key=${GEMINI_API_KEY:your-api-key-here}
gemini.api.base-url=https://generativelanguage.googleapis.com/v1beta/models
gemini.api.model=gemini-1.5-flash
gemini.api.timeout=30000
# CORS Configuration
cors.allowed-origins=http://localhost:3000,http://localhost:8080
Environment Variables
| Variable | Description | Required | Default | 
|---|---|---|---|
| GEMINI_API_KEY | Your Google Gemini API key | β Yes | - | 
| SERVER_PORT | Server port | β No | 8080 | 
| GEMINI_MODEL | Gemini model to use | β No | gemini-1.5-flash | 
π§ͺ Testing
Run Unit Tests
mvn test
Run Integration Tests
mvn verify
Manual Testing with cURL
Windows Command Prompt:
curl -X POST http://localhost:8080/api/chat/message -H "Content-Type: application/json" -d "{\"message\": \"Hello!\"}"
PowerShell/Linux/macOS:
curl -X POST http://localhost:8080/api/chat/message \
  -H "Content-Type: application/json" \
  -d '{"message": "Hello!"}'
ποΈ Project Structure
spring-gemini-chat/
βββ src/
β   βββ main/
β   β   βββ java/com/example/p1/
β   β   β   βββ P1Application.java           # Main application
β   β   β   βββ config/
β   β   β   β   βββ AiConfiguration.java     # Configuration
β   β   β   βββ controller/
β   β   β   β   βββ ChatController.java      # REST endpoints
β   β   β   βββ service/
β   β   β       βββ ChatService.java         # Business logic
β   β   βββ resources/
β   β       βββ application.properties       # Configuration
β   βββ test/
β       βββ java/com/example/p1/
β               βββ P1ApplicationTests.java 
βββ index.html                            # Frontend interface
βββ screenshots/                            # UI screenshots
βββ pom.xml                                 # Maven configuration
βββ README.md                              # This file
π Deployment
Using Docker
FROM openjdk:17-jdk-slim
COPY target/*.jar app.jar
EXPOSE 8080
ENTRYPOINT ["java","-jar","/app.jar"]
# Build the application
mvn clean package
# Build Docker image
docker build -t spring-gemini-chat .
# Run container
docker run -p 8080:8080 -e GEMINI_API_KEY=your_key spring-gemini-chat
Using JAR
# Build JAR
mvn clean package
# Run JAR
java -jar target/p1-0.0.1-SNAPSHOT.jar
π€ Contributing
We welcome contributions! Please follow these steps:
- Fork the repository
- Create a feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add some amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
Development Guidelines
- Follow Java coding conventions
- Write unit tests for new features
- Update documentation for API changes
- Use meaningful commit messages
π Troubleshooting
Common Issues
β "Connection failed" in UI
- Ensure backend is running on port 8080
- Check CORS configuration
- Verify network connectivity
β "API key not found" error
- Set GEMINI_API_KEY environment variable
- Restart the application after setting the key
- Verify the API key is valid
β Maven build fails
- Check Java version (requires Java 17+)
- Clear Maven cache: mvn clean
- Update dependencies: mvn dependency:resolve -U
β CORS errors
- Check allowed origins in AiConfiguration.java
- Verify frontend URL matches CORS settings
π License
This project is licensed under the MIT License - see the LICENSE file for details.
π Acknowledgments
- Google Gemini AI - For providing the AI capabilities
- Spring Team - For the excellent Spring Boot framework
- Contributors - Thanks to all who contribute to this project
π Support
- π§ Email: [email protected]
- π Issues: GitHub Issues
- π¬ Discussions: GitHub Discussions
