/RealEstate-Backend-Web-Application

A robust and scalable back-end application designed for managing real estate properties, agents, and their interactions. Built with Java, Spring Boot, and MySQL, this project incorporates modern technologies to deliver a seamless experience for administrators and users.

Primary LanguageJavaGNU General Public License v3.0GPL-3.0

Real Estate Back-End Web Application

A robust and scalable back-end application designed for managing real estate properties, agents, and their interactions. Built with Java, Spring Boot, and MySQL, this project incorporates modern technologies to deliver a seamless experience for administrators and users.

Real Estate Java JWT Docker Spring Boot Spring Data JPA Spring Validation Spring Security Swagger Prometheus Spring Mail Resilience4j MySQL AWS

Table of Contents

  • Features
  • Technologies Used
  • Getting Started
  • Configuration
  • Testing
  • Contributing
  • License

Features

  • Property Management: Add, update, delete, and view property listings.
  • Agent Management: Manage agents including their bios, contact details, and licenses.
  • JWT Authentication: Secure endpoints with JSON Web Tokens.
  • Swagger API Documentation: Interactive API exploration and testing.
  • Monitoring: Built-in application metrics using Prometheus.
  • Rate Limiting: Protect endpoints with Resilience4j.
  • Email Notifications: Notify agents or clients with email integration.

Technologies Used

  • Java 17
  • Spring Boot 3
  • Spring Data JPA
  • Spring Security
  • Spring Validation
  • Spring Mail
  • MySQL for database
  • JWT for authentication
  • Swagger OpenAPI for API documentation
  • Prometheus for monitoring
  • Resilience4j for rate limiting

Getting Started

  1. Prerequisites
  • Java 17 or later
  • Maven (for dependency management)
  • MySQL (Database)
  • Postman (for API testing)
  1. Clone the Repository
git clone https://github.com/stephenombuya/RealEstate-Backend-Web-Application/tree/main
cd real-estate-backend
  1. Install Dependencies
mvn clean install
  1. Run the Application
  • Update the application.properties file with your database credentials and configuration.
  • Start the application:
mvn spring-boot:run

Configuration

Update the following in src/main/resources/application.properties:

# Database Configuration
spring.datasource.url=jdbc:mysql://localhost:3306/db_name
spring.datasource.username=your_username
spring.datasource.password=your_password

# JWT Configuration
jwt.secret=your-secret-key
jwt.expiration=86400000

# Email Configuration
spring.mail.host=smtp.gmail.com
spring.mail.port=587
spring.mail.username=your-email
spring.mail.password=your-email-password
spring.mail.properties.mail.smtp.auth=true
spring.mail.properties.mail.smtp.starttls.enable=true

Testing

  • Run the test suite with:
mvn test
  • Testing Features
    • Unit and integration tests for services and controllers.
    • Authentication and authorization tests.
    • Database validation tests.

Contributing

We welcome contributions! Follow these steps to contribute:

  1. Fork the repository.
  2. Create a feature branch:
git checkout -b feature-name
  1. Commit your changes:
git commit -m "Add new feature"
  1. Push to your branch:
git push origin feature-name
  1. Open a pull request.

License

This project is licensed under the GNU License. See the LICENSE file for details.