ravuthz/laravel-crud

这是一个提供CRUD操作基础控制器的Laravel包。

v1.1.0 2024-09-30 08:51 UTC

This package is auto-updated.

Last update: 2024-09-30 08:58:21 UTC


README

使用Composer安装包

composer require ravuthz/laravel-crud

使用方法

生成CRUD控制器和测试

php artisan crud --help

# Generate crud model, controller, test, request, resource
php artisan crud:generate Post --test

# Generate only crud controller
php artisan crud:controller Post

# Generate only crud controller test
php artisan crud:controller-test Post

使用示例PostController和PostControllerTest

首先创建

  • 使用php artisan make:model Post -mc命令创建控制器模型和迁移
  • 使用php artisan make:request PostRequest命令创建请求
  • 使用php artisan make:resource PostResource命令创建资源

然后,您可以使用以下示例代码将其设置为CRUD控制器和测试。

// PostController.php
<?php

namespace App\Http\Controllers\Api;

use App\Models\Post;
use App\Http\Requests\PostRequest;
use App\Http\Resources\PostResource;
use App\Http\Resources\PostCollection;
use Ravuthz\LaravelCrud\CrudController;

class PostController extends CrudController
{
    protected $model = Post::class;
    protected $resource = PostResource::class;
    // protected $collection = PostCollection::class;
    protected $storeRequest = PostRequest::class;
    protected $updateRequest = PostRequest::class;

    // Override this method to add custom logic before saving
    protected function beforeSave($request, $model, $id = null)
    {
        return $model;
    }

    // Override this method to add custom logic after saving
    protected function afterSave($request, $model, $id = null)
    {
        return $model;
    }

}
// PostControllerTest.php
<?php

namespace Tests\Feature\Http\Controllers\Api;

use Ravuthz\LaravelCrud\TestCrud;

class PostControllerTest extends TestCrud
{
    protected string $route = 'api/posts';

    protected function setUp(): void
    {
        parent::setUp();
        $this->refreshLocalDB(true);
    }

    protected function requestPayload($id = null): array
    {
        // $time = now()->format('Y-m-d_H:m:s.u');
        // some related data, attachment with some unique value with time here

        return [
            'id' => $id
            // 'name' => $this->faker->name(),
        ];
    }
}