Я новичок в php и Laravel. У меня есть проект в Laravel 6. Я делаю свой проект с этой статьей: https://itnext.io/repository-design-pattern-done-right-in-laravel-d177b5fa75d4 У меня есть в моей serwer php 7.4
У меня есть этот код:
interface RepositoryInterface
{
public function all(array $columns = ['*']);
public function list(string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*']);
public function listWithPaginate(string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*']);
public function create(array $data);
public function update(array $data, int $id, string $attribute = 'id');
public function delete(int $id);
public function find(int $id, array $columns = array('*'));
public function getModel();
public function findOrFail(int $id, array $columns = array('*'));
}
interface SlideRepositoryInterface extends RepositoryInterface
{
public function search(string $query, string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*'], int $perPage = 10);
}
use App\Models\Slide;
use App\Repositories\Interfaces\SlideRepositoryInterface;
use Cache;
class SlideRepository implements SlideRepositoryInterface
{
public function __construct(Slide $model)
{
$this->model = $model;
}
public function search(string $query, string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*'], int $perPage = 10)
{
return $this->model->where('line1', 'LIKE', '%' . $query . '%')->orWhere('id', 'LIKE', '%' . $query . '%')->with($with)->orderBy($orderByColumn, $orderBy)->paginate($perPage, $columns)->appends(request()->query());
}
}
class SlideServiceProvider extends ServiceProvider
{
public function register()
{
$this->app->bind(
SlideRepositoryInterface::class,
SlideRepository::class
);
}
}
И мой контроллер:
public function __construct(SlideRepositoryInterface $repository, Request $request)
{
$this->model = $repository;
$this->sortBy = $this->sortResultsBy($request->input('sortAfter') ?? 0, 'line1');
}
abstract class BaseRepository implements RepositoryInterface
{
protected $model;
public function all(array $columns = array('*'))
{
return $this->model->get($columns);
}
public function list(string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*'])
{
return $this->model->with($with)
->orderBy($orderByColumn, $orderBy)
->get($columns);
}
public function listWithPaginate(string $orderByColumn, string $orderBy = 'desc', array $with = [], array $columns = ['*'], int $perPage = 10)
{
return $this->model->with($with)
->orderBy($orderByColumn, $orderBy)
->paginate($perPage, $columns)->appends(request()->query());
}
public function create(array $data): int
{
return $this->model->create($data)->id;
}
public function update(array $data, int $id, string $attribute = 'id'): void
{
$this->model->where($attribute, '=', $id)->update($data);
}
public function delete(int $id): void
{
$this->model->destroy($id);
}
public function find(int $id, array $columns = array('*'))
{
return $this->model->find($id, $columns);
}
public function getModel()
{
return $this->model;
}
public function getFirst(int $id)
{
return $this->model->where('id', $id)->first();
}
public function findOrFail(int $id, array $columns = array('*'))
{
return $this->model->findOrFail($id, $columns);
}
}
Когда я запускаю этот код, у меня появляется ошибка:
Цель [App \ Repositories \ Interfaces \ SlideRepositoryInterface] не создается, пока build [App \ Http \ Controllers \ psCMS \ SlideController]
Я хочу сделать свой проект в шаблоне проектирования репозитория.
Почему он не работает? Как мне отремонтировать мой проект?
Пожалуйста, помогите мне:)