amroboney/repository-generator

There is no license information available for the latest version (v1.0.0) of this package.

A feature-rich Laravel package to simplify and streamline the process of generating repository files using the repository pattern, promoting clean architecture and maintainable code.

Installs: 68

Dependents: 0

Suggesters: 0

Security: 0

Stars: 2

Watchers: 1

Forks: 0

Open Issues: 0

pkg:composer/amroboney/repository-generator

v1.0.0 2025-05-12 19:03 UTC

This package is auto-updated.

Last update: 2025-10-12 20:13:44 UTC


README

A Laravel package designed to streamline the implementation of the repository pattern in your projects. This tool generates a complete repository setup, including repository classes, interfaces, and service classes, helping developers maintain clean, organized, and decoupled codebases. This package is ideal for teams and individuals following Clean Architecture and Domain-Driven Design (DDD) principles, enabling faster scaffolding of repositories and services for Laravel applications.

📦 Installation

You can install the package via Composer:

composer require amroboney/repository-generator

If the package is not on Packagist and hosted on GitHub, add this to your Laravel app’s composer.json:

"repositories": [
  {
    "type": "vcs",
    "url": "https://github.com/amroboney/repository-generator"
  }
]

Then install it with:

composer require amroboney/repository-generator:dev-main

⚙️ Usage

Generate a repository, interface, and service using the artisan command:

php artisan make:repository ModelName

This will generate the following files automatically:

app/
├── Repositories
│    └── Interfaces/
│    │   └── ModelNameRepositoryInterface.php
│    └── Repositories/
│       └── ModelNameRepository.php
└── Services/
  └── ModelNameService.php

You only need to replace ModelName with the relevant name for your feature or entity (e.g., User).

🌟 Features

  • Automated File Generation: Instantly creates repository and service structures, saving significant development time.
  • Repository Pattern Support: Promotes clear separation of concerns between business logic and database operations in Laravel.
  • Configurable Structure: Adheres to Clean Architecture and Domain-Driven Design principles.
  • PHP 8.1+ Compatibility: Leverages modern PHP syntax and features for robust development.

📂 File Structure Example

If you run the command php artisan make:repository User, this is how your file structure will look:

app/
├── Repositories/
│   ├── Interfaces/
│   │   └── UserRepositoryInterface.php
│   └── Implementations/
│       └── UserRepository.php
└── Services/
    └── UserService.php
  • UserRepositoryInterface.php: Defines the contract for the repository.
  • UserRepository.php: Implements the repository logic for interacting with the database.
  • UserService.php: Contains business logic and operations for the User entity.

🤝 Contributing

Contributions are welcome! If you'd like to contribute to this package, feel free to fork the repository and submit a pull request. Please ensure that your code adheres to PSR standards and includes thorough testing.

🧑‍💻 Author

Amro Boney 📧 amroboney@gmail.com 📍 Riyadh, Saudi Arabia

License Information

This package is licensed under the MIT License, which means:

✅ Permissions:

  • Commercial Use You can use this package in commercial applications and products.
  • Modification You are allowed to modify the source code for your own use.
  • Distribution You can freely share, distribute, or resell the package (as-is or modified).
  • Private Use You can use this package in private or internal projects without any restrictions.

❌ Limitations:

  • No Liability The author is not responsible for any damages resulting from the use of this software.
  • No Warranty The software is provided "as is," without any warranty of any kind (express or implied), including but not limited to:
    • Warranties of merchantability.
    • Fitness for a particular purpose.
    • Non-infringement.

For full license details, please refer to the LICENSE file included in this repository.