laravilt/plugins
最新稳定版本:1.0.2
Composer 安装命令:
composer require laravilt/plugins
包简介
Complete plugin system with generator, management, and FilamentPHP compatibility for Laravilt
关键字:
README 文档
README
Laravilt Plugins
Complete plugin system with generator, management, and FilamentPHP v4 compatibility for Laravilt.ipsum
✨ Features
🎨 Plugin Generation
- Interactive CLI - Laravel Prompts with smart defaults
- Factory Pattern - Extensible feature-based architecture
- Priority System - Ordered feature execution (0-100)
- Stub Processing - Template-based file generation
- Auto-Discovery - Automatic plugin registration
🧩 Component Generators
Generate 13 component types within plugins:
- Migration - Database migrations with timestamps
- Model - Eloquent models with proper namespacing
- Controller - HTTP controllers
- Command - Artisan commands
- Job - Queueable jobs
- Event - Event classes
- Listener - Event listeners
- Notification - Notifications with mail support
- Seeder - Database seeders
- Factory - Model factories
- Test - Feature/Unit tests
- Lang - Language files
- Route - Route files
🤖 MCP Server Integration
- AI Agent Support - Built-in MCP server for Claude, GPT, etc.
- 6 Tools Available - list-plugins, plugin-info, generate-plugin, generate-component, list-component-types, plugin-structure
- Natural Language - Generate plugins through conversation
- Auto-Discovery - AI agents can explore plugin ecosystem
🎨 Professional Assets
- Cover Images - Auto-generated 1200x630px screenshots
- Dark Theme - Professional gradient backgrounds
- Plugin Branding - Cyan icon with Laravilt branding
- Social Media Ready - Optimized for GitHub/Twitter previews
- README Integration - Auto-embedded in documentation
⚙️ GitHub Integration
- Workflows - tests.yml, fix-php-code-styling.yml, dependabot-auto-merge.yml
- Issue Templates - Bug reports, feature requests (GitHub forms)
- Dependabot - Automated dependency updates
- FUNDING.yml - GitHub Sponsors support
- CONTRIBUTING.md - Contribution guidelines
- SECURITY.md - Security vulnerability reporting
📦 Complete Package Setup
- Service Provider - Auto-discovery compatible
- Configuration - Publishable config with env support
- Composer - PSR-4 autoloading, version constraints
- Testing - Pest, PHPStan, Pint, Testbench
- Assets - Vite, Tailwind v4, Vue.js plugin support
- Documentation - README, CHANGELOG, LICENSE, CODE_OF_CONDUCT
📋 Requirements
- PHP 8.3+
- Laravel 12+
- FilamentPHP v4+ (for plugins features)
- Composer 2+
- Node.js 18+ (for asset compilation)
🚀 Installation
composer require laravilt/plugins
The service provider is auto-discovered and will register automatically.
Configuration
Publish the configuration file:
php artisan vendor:publish --tag=laravilt-plugins-config
Configure defaults in config/laravilt-plugins.php:
return [ 'defaults' => [ 'vendor' => env('LARAVILT_PLUGINS_DEFAULT_VENDOR', 'laravilt'), 'author' => env('LARAVILT_PLUGINS_DEFAULT_AUTHOR', 'Your Name'), 'email' => env('LARAVILT_PLUGINS_DEFAULT_EMAIL', 'your@email.com'), 'license' => env('LARAVILT_PLUGINS_DEFAULT_LICENSE', 'MIT'), 'github_sponsor' => env('LARAVILT_PLUGINS_DEFAULT_GITHUB_SPONSOR', 'yourusername'), ], ];
MCP Server Setup (for AI Agents)
Install the MCP server configuration:
php artisan laravilt:install-mcp
This command will:
- Publish
routes/ai.php(if needed) - Register the MCP server in your routes
- Update
.mcp.jsonfor AI clients
After installation, restart your AI agent to access the plugin management tools.
📖 Usage
Generate a Plugin
Interactive mode (recommended):
php artisan laravilt:plugin MyPlugin
Non-interactive mode:
php artisan laravilt:plugin MyPlugin --no-interaction
The command will guide you through:
- Plugin name and description
- Feature selection (migrations, views, routes, assets, etc.)
- Author details (optional)
- GitHub sponsor (optional)
- Language selection
Generate Components
Use the unified component generator:
php artisan laravilt:make
Or specify directly:
# Generate a model php artisan laravilt:make my-plugin model Post # Generate a controller php artisan laravilt:make my-plugin controller PostController # Generate a migration php artisan laravilt:make my-plugin migration CreatePostsTable # Generate a command php artisan laravilt:make my-plugin command ProcessPostsCommand # Generate a job php artisan laravilt:make my-plugin job ProcessPost # Generate a test php artisan laravilt:make my-plugin test PostTest
All 13 component types are supported with proper namespace detection and PSR-4 structure.
Generated Plugin Structure
my-plugin/
├── .github/
│ ├── workflows/
│ │ ├── tests.yml
│ │ ├── fix-php-code-styling.yml
│ │ └── dependabot-auto-merge.yml
│ ├── ISSUE_TEMPLATE/
│ │ ├── bug.yml
│ │ └── config.yml
│ ├── CONTRIBUTING.md
│ ├── FUNDING.yml
│ ├── SECURITY.md
│ └── dependabot.yml
├── arts/
│ └── screenshot.jpg # Auto-generated cover image
├── config/
│ └── laravilt-my-plugin.php
├── database/
│ ├── factories/
│ ├── migrations/
│ └── seeders/
├── resources/
│ ├── css/
│ │ └── app.css # Tailwind v4
│ ├── js/
│ │ └── app.js # Vue.js plugin
│ ├── lang/
│ │ └── en/
│ └── views/
├── routes/
│ ├── api.php
│ └── web.php
├── src/
│ ├── Commands/
│ │ └── InstallMyPluginCommand.php
│ ├── Http/
│ │ └── Controllers/
│ ├── Models/
│ ├── MyPluginPlugin.php # Main plugin class
│ └── MyPluginServiceProvider.php
├── tests/
│ ├── Feature/
│ │ └── DebugTest.php
│ ├── Pest.php
│ └── TestCase.php
├── CHANGELOG.md
├── CODE_OF_CONDUCT.md
├── LICENSE.md
├── README.md
├── composer.json
├── package.json # If JS selected
├── phpstan.neon
├── pint.json
├── testbench.yaml
└── vite.plugin.js # If JS selected
🏗️ Architecture
Factory Pattern
The plugin system uses a Factory Pattern for extensible feature generation:
Features (Priority 0-100)
├── Core Files (0-20)
│ ├── ComposerJsonFeature (1)
│ ├── GitignoreFeature (2)
│ ├── ServiceProviderFeature (5)
│ ├── PluginClassFeature (10)
│ ├── InstallCommandFeature (12)
│ └── ConfigFeature (15)
├── Structure Files (21-40)
│ ├── MigrationsFeature (25)
│ ├── RoutesFeature (30)
│ ├── ViewsFeature (35)
│ └── LanguageFeature (40)
├── Asset Files (41-60)
│ ├── CssFeature (50)
│ ├── JsFeature (51)
│ └── ArtsFeature (55)
├── Testing Files (61-80)
│ ├── TestingFeature (70)
│ ├── TestbenchFeature (75)
│ └── PintFeature (76)
└── Documentation Files (81-100)
├── ReadmeFeature (85)
├── GitHubFeature (90)
└── DocumentationFeature (95)
Extending with Custom Features
Create a custom feature:
<?php namespace App\PluginFeatures; use Laravilt\Plugins\Features\AbstractFeature; class CustomFeature extends AbstractFeature { public function getName(): string { return 'custom'; } public function shouldGenerate(array $config): bool { return $config['generate_custom'] ?? false; } public function getPriority(): int { return 99; // Execute near the end } public function generate(array $config): void { // Your generation logic $this->processor->generateFile( $config['base_path'].'/custom/file.php', 'custom/file', ['key' => 'value'] ); } }
Register in config:
'features' => [ // ... existing features \App\PluginFeatures\CustomFeature::class, ],
🤖 MCP Server
Available Tools
list-plugins
List all installed Laravilt plugins.
plugin-info
Get detailed information about a specific plugin.
Arguments:
plugin(string): Plugin name in kebab-case
generate-plugin
Generate a new plugin with specified features.
Arguments:
name(string): Plugin name in StudlyCasedescription(string, optional)migrations(bool, default: false)views(bool, default: false)webRoutes(bool, default: false)apiRoutes(bool, default: false)css(bool, default: false)js(bool, default: false)arts(bool, default: true)github(bool, default: true)phpstan(bool, default: true)
generate-component
Generate a component within a plugin.
Arguments:
plugin(string): Plugin name in kebab-casetype(string): Component type (migration, model, controller, etc.)name(string): Component name
list-component-types
List all available component types.
plugin-structure
Get the complete directory structure of a plugin.
Arguments:
plugin(string): Plugin name in kebab-case
AI Agent Examples
You: "List all my plugins"
AI: [calls list-plugins tool]
You: "Create a blog plugin with migrations and views"
AI: [calls generate-plugin with appropriate parameters]
You: "Generate a Post model in the blog plugin"
AI: [calls generate-component]
🧪 Testing
Run tests in the plugins package:
cd packages/laravilt/plugins composer test
Run tests in a generated plugin:
cd packages/myvendor/my-plugin composer test # Run Pest tests composer format # Format code with Pint composer analyse # Run PHPStan analysis
📚 Documentation
Comprehensive documentation is available in the docs/ directory:
- Getting Started
- Architecture
- Plugin Generation
- Component Generators
- Factory Pattern
- Features System
- MCP Server
- API Reference
🤝 Contributing
Please see CONTRIBUTING.md for details.
🔒 Security
If you discover any security-related issues, please email info@3x1.io instead of using the issue tracker.
📝 Changelog
Please see CHANGELOG.md for recent changes.
📄 License
The MIT License (MIT). Please see License File for more information.
👥 Credits
🌟 Sponsors
Support this project via GitHub Sponsors.
统计信息
- 总下载量: 146
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-12-02
