定制 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

统计信息

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

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固