承接 raviyatechnical/laravel-repository-generator 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

raviyatechnical/laravel-repository-generator

Composer 安装命令:

composer require raviyatechnical/laravel-repository-generator

包简介

Generate Laravel Repositories | Laravel Dependency Injection

README 文档

README


Logo

Laravel Repository Generator

Quickly generate repositories for your projects!



Table of Contents

  1. Features
  2. Getting started
  3. Usage
  4. Manual binding
  5. More generator packages
  6. Contributing
  7. License

Features

With this package you can generate repositories with the artisan make:repository command. The generator will generate the repository, repository interface and will bind them automatically (can be changed to manual binding) to the Service Container so you can inject the interface into your controllers.

Installation

Require the Laravel Repository Generator with composer.

composer require raviyatechnical/laravel-repository-generator:dev-master --dev

Publish config (optional)

php artisan vendor:publish --provider="RaviyaTechnical\RepositoryGenerator\RepositoryGeneratorServiceProvider" --tag="config"

Usage

For usage take the following steps. Generate the repository and then inject it into a controller or service.

Generating repositories

Run the following command.

php artisan make:repository UserRepository

This example will generate the following files:

app\Repositories\Eloquent\UserRepository
app\Repositories\UserRepositoryInterface

Dependency Injection

Next we have to inject the interface into the constructor our controller or service. For this example we will use the UserController.

<?php

namespace App\Http\Controllers;

use App\Repositories\UserRepositoryInterface;

class UserController extends Controller
{
    private $user;

    public function __construct(UserRepositoryInterface $userRepository)
    {
        $this->user = $userRepository;
    }
    
    // your controller functions
}

By default you will be able to use Eloquent methods like all() and find(). You can extend this in your repository. Now you will be able to use your repository in your methods like this.

public function index()
{
    return $this->user->all();
}

Manual binding

By default the package will automatically bind the repository interfaces for you with the repositories so you can inject the interface into your controllers. If you want to bind manually you can disable this behaviour by setting the auto_bind_interfaces option to false in config\repository-generator.php. If the config is not there make sure to publish it first as described in the Installation chapter.

You can add your bindings to your AppServiceProvider or you can a create a new provider with php artisan make:provider RepositoryServiceProvider (don't forget to add it in config\app.php) and add the bindings in the register() method, see the example below.

<?php 

namespace App\Providers; 

use App\Repositories\Eloquent\UserRepository;
use App\Repositories\UserRepositoryInterface;
use Illuminate\Support\ServiceProvider; 

/** 
* Class RepositoryServiceProvider 
* @package App\Providers 
*/ 
class RepositoryServiceProvider extends ServiceProvider 
{ 
   /** 
    * Register services. 
    * 
    * @return void  
    */ 
   public function register() 
   { 
       $this->app->bind(UserRepositoryInterface::class, UserRepository::class);
   }
}

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  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

First Inspiration Package

https://github.com/timwassenburg/laravel-repository-generator

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 8
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 4
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-02-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固