Skip to content

A management application for a farm of lemons, allowing farmers to follow the production, harvest, and sale of their products.

Notifications You must be signed in to change notification settings

Mr-AXEL01/Citronix

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Citronix πŸ‹

Java Spring Boot Tests Docker

About

Citronix is a comprehensive farm management system designed specifically for lemon farms. It enables farmers to efficiently track production, harvesting, and sales of their products while optimizing tree productivity based on age. The system provides tools for managing farms, fields, trees, harvests, and sales with a focus on maintaining strict agricultural constraints and maximizing productivity.

Features

Farm Management

  • Create, update, and view farm information (name, location, area, creation date)
  • Multi-criteria search using Criteria Builder
  • Comprehensive farm analytics and reporting

Field Management

  • Associate fields with farms with defined areas
  • Automatic area consistency validation
  • Maximum 10 fields per farm
  • Field area must be between 0.1 and 50% of farm area

Tree Management

  • Track planting date and age
  • Calculate productivity based on tree age:
    • Young trees (<3 years): 2.5 kg/season
    • Mature trees (3-10 years): 12 kg/season
    • Old trees (>10 years): 20 kg/season
  • Maximum density: 100 trees per hectare
  • Planting restricted to March-May period

Harvest Management

  • Seasonal harvest tracking (Winter, Spring, Summer, Fall)
  • One harvest per season (every 3 months)
  • Detailed tracking per tree
  • Prevention of double harvesting in the same season

Sales Management

  • Record sales with date, unit price, and customer information
  • Automatic revenue calculation (Revenue = quantity * unit price)
  • Link sales to specific harvests
  • Sales analytics and reporting

Technical Stack

  • Backend Framework: Spring Boot
  • Database: PostgreSQL
  • Architecture: Layered Architecture
    • Controllers
    • Services
    • Repositories
    • Entities
  • Data Validation: Spring Validation
  • Testing: JUnit 5 & Mockito
  • Code Generation: Lombok with Builder Pattern
  • Object Mapping: MapStruct
  • Exception Handling: Centralized exception management
  • Documentation: Swagger/OpenAPI
  • Containerization: Docker

Prerequisites

  • Docker and Docker Compose installed
  • Git (optional, for development)
  • Minimum 4GB RAM recommended
  • 10GB free disk space

Installation and Setup

1. Create Environment File

Create an .env file in your project directory:

POSTGRES_DB=your_db_name
DB_USERNAME=your_username
DB_PASSWORD=your_password
PGADMIN_DEFAULT_EMAIL=[email protected]
PGADMIN_DEFAULT_PASSWORD=your_pgadmin_password

2. Create Docker Compose File

Create a docker-compose.yml file:

version: '3.8'
services:
  app:
    image: mraxel01/citronix:latest
    ports:
      - "8080:8080"
    environment:
      SPRING_DATASOURCE_URL: jdbc:postgresql://postgres:5432/${POSTGRES_DB}
      SPRING_DATASOURCE_USERNAME: ${DB_USERNAME}
      SPRING_DATASOURCE_PASSWORD: ${DB_PASSWORD}
    depends_on:
      - postgres
    networks:
      - app-network
    restart: unless-stopped

  postgres:
    image: 'postgres:latest'
    environment:
      - POSTGRES_DB=${POSTGRES_DB}
      - POSTGRES_PASSWORD=${DB_PASSWORD}
      - POSTGRES_USER=${DB_USERNAME}
    ports:
      - "5432:5432"
    networks:
      - app-network

  pgadmin:
    image: 'dpage/pgadmin4:latest'
    environment:
      PGADMIN_DEFAULT_EMAIL: ${PGADMIN_DEFAULT_EMAIL}
      PGADMIN_DEFAULT_PASSWORD: ${PGADMIN_DEFAULT_PASSWORD}
      PGADMIN_LISTEN_PORT: 5050
    ports:
      - '5050:5050'
    networks:
      - app-network

networks:
  app-network:
    driver: bridge

3. Run the Application

# Start all services
docker-compose up -d

# Check status
docker-compose ps

# View logs
docker-compose logs -f

4. Access the Application

Project Structure

citronix/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ main/
β”‚   β”‚   β”œβ”€β”€ java/
β”‚   β”‚   β”‚   └── net/
β”‚   β”‚   β”‚       └── axel/
β”‚   β”‚   β”‚           └── citronix/
β”‚   β”‚   β”‚               β”œβ”€β”€ controller/
β”‚   β”‚   β”‚               β”œβ”€β”€ domain/
β”‚   β”‚   β”‚               β”‚   β”œβ”€β”€ dtos/
β”‚   β”‚   β”‚               β”‚   β”‚   β”œβ”€β”€ farm/
β”‚   β”‚   β”‚               β”‚   β”‚   β”œβ”€β”€ field/
β”‚   β”‚   β”‚               β”‚   β”‚   β”œβ”€β”€ harvest/
β”‚   β”‚   β”‚               β”‚   β”‚   β”œβ”€β”€ harvestDetail/
β”‚   β”‚   β”‚               β”‚   β”‚   β”œβ”€β”€ sale/
β”‚   β”‚   β”‚               β”‚   β”‚   └── tree/
β”‚   β”‚   β”‚               β”‚   β”œβ”€β”€ embeddeds/
β”‚   β”‚   β”‚               β”‚   β”œβ”€β”€ entities/
β”‚   β”‚   β”‚               β”‚   └── enums/
β”‚   β”‚   β”‚               β”œβ”€β”€ exception/
β”‚   β”‚   β”‚               β”‚   └── domains/
β”‚   β”‚   β”‚               β”œβ”€β”€ mapper/
β”‚   β”‚   β”‚               β”œβ”€β”€ repository/
β”‚   β”‚   β”‚               β”œβ”€β”€ service/
β”‚   β”‚   β”‚               β”‚   └── impl/
β”‚   β”‚   β”‚               └── validation/
β”‚   β”‚   β”‚                   └── validator/
β”‚   β”‚   └── resources/
β”‚   └── test/

Business Rules

Field Constraints

  • Minimum area: 0.1 hectare (1,000 mΒ²)
  • Maximum area: 50% of farm's total area
  • Maximum 10 fields per farm

Tree Management

  • Maximum density: 100 trees per hectare (10 trees per 1,000 mΒ²)
  • Maximum productive age: 20 years
  • Trees can only be planted between March and May
  • Productivity varies by age group:
    • Young: <3 years
    • Mature: 3-10 years
    • Old: >10 years

Harvest Rules

  • One harvest per season per field
  • No double harvesting of trees in the same season
  • Seasonal harvests: Winter, Spring, Summer, Fall
  • Each tree can only be harvested once per season

API Documentation

Complete API documentation is available through Swagger UI at http://localhost:8080/swagger-ui.html when the application is running.

Error Handling

The application implements a centralized error handling mechanism that provides:

  • Consistent error response format
  • Detailed error messages
  • Appropriate HTTP status codes
  • Validation error details

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Troubleshooting

Common Issues

  1. Port Conflicts: Ensure ports 8080, 5432, and 5050 are available
  2. Memory Issues: Ensure Docker has enough allocated memory
  3. Database Connection: Check environment variables in .env file

Solutions

# Check container logs
docker-compose logs [service_name]

# Restart services
docker-compose restart

# Reset everything
docker-compose down
docker-compose up -d --force-recreate

Contact

Feel free to reach out for any questions, suggestions, or collaboration opportunities!

About

A management application for a farm of lemons, allowing farmers to follow the production, harvest, and sale of their products.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published