承接 sweet1s/moonshine-database 相关项目开发

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

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

sweet1s/moonshine-database

最新稳定版本:1.0.0

Composer 安装命令:

composer require sweet1s/moonshine-database

包简介

Moonshine Database

README 文档

README

Description

The Moonshine Database Manager package is a powerful extension for the Moonshine Admin Panel that facilitates seamless database management directly from the admin interface. This Laravel package enhances the functionality of the Moonshine Admin Panel by allowing administrators to effortlessly interact with the underlying database without the need for complex SQL queries or external tools.

Features

  • Intuitive Interface: The package integrates seamlessly with the Moonshine Admin Panel, providing a user-friendly interface to manage databases. Administrators can perform CRUD (Create, Read, Update, Delete) operations on database records effortlessly.
  • User Permissions: Control access to the database manager with robust user permission settings. Define which administrators can view, edit, or delete database records and tables.
  • Easy Installation: The package is easy to install and configure.

Installation

  1. Install the package via composer:
composer require sweet1s/moonshine-database
  1. Publish the configuration file:
php artisan vendor:publish --provider="Sweet1s\MoonShineDatabase\Providers\MoonShineDatabaseServiceProvider"
  1. Add the item to your MoonShineServiceProvider file, like this:
public function boot(): void
    {
        app(MoonShine::class)->menu([
            ...
            \Sweet1s\MoonShineDatabase\Menu\DatabaseItem::make(),
            ...
        ]);
    }

Authentication

To utilize authentication, Moonshine Database relies on the Laravel Gate system. To enable this functionality, you need to add the following code to your AuthServiceProvider and implement your own authorization logic. First, you should set the auth parameter to true in the moonshine-database.php configuration file. Here's an example code snippet:

In your config/moonshine-database.php file

...
'auth' => [
    'enable' => true
],
...

In your app/Providers/AuthServiceProvider.php file

<?php

namespace App\Providers;

use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;use Illuminate\Support\Facades\Gate;

class AuthServiceProvider extends ServiceProvider
{
    /**
     * Register any authentication / authorization services.
     *
     * @return void
     */
    public function boot()
    {
        ...
        foreach (config('moonshine-database.auth.permissions') as $key => $value) {
            Gate::define($value, function ($user) use ($value) {
                // Here you can implement your own authorization logic

                // I use spatie/laravel-permission package, so I can do like this:
                return $user->role->hasPermissionTo($value);
            });
        }
    }
}

How does it look in the Admin Panel ?

Index page Index Page

Edit page Edit Page

Create page Edit Page

统计信息

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

GitHub 信息

  • Stars: 4
  • Watchers: 1
  • Forks: 0
  • 开发语言: Blade

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-08-05