opscale-co / actions
Loris Leiva - Laravel Actions extension with Nova additions
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/opscale-co/actions
Requires
- php: >=8.2
- lorisleiva/laravel-actions: ^2.9
Requires (Dev)
- laravel/mcp: *
- laravel/nova: ^5.7
- laravel/nova-devtool: ^1.0
- phpunit/phpunit: ^10.5
- tightenco/duster: ^2.7
README
At Opscale, weβre passionate about contributing to the open-source community by providing solutions that help businesses scale efficiently. If youβve found our tools helpful, here are a few ways you can show your support:
β Star this repository to help others discover our work and be part of our growing community. Every star makes a difference!
π¬ Share your experience by leaving a review on Trustpilot or sharing your thoughts on social media. Your feedback helps us improve and grow!
π§ Send us feedback on what we can improve at feedback@opscale.co. We value your input to make our tools even better for everyone.
π Get involved by actively contributing to our open-source repositories. Your participation benefits the entire community and helps push the boundaries of whatβs possible.
πΌ Hire us if you need custom dashboards, admin panels, internal tools or MVPs tailored to your business. With our expertise, we can help you systematize operations or enhance your existing product. Contact us at hire@opscale.co to discuss your project needs.
Thanks for helping Opscale continue to scale! π
Description
One logic unit to rule them all.
Encapsulate your business logic in atomic, self-contained classes and reuse them across your entire application stack. Write once, use everywhere.
This package extends Laravel Actions with support for:
- Laravel Nova Actions - Use actions directly as Nova actions
- Laravel MCP Tools - Use actions as Model Context Protocol tools for AI
The same logic can serve multiple audiences:
- For end users β Nova Actions in your admin panel
- For administrators β Artisan commands in the terminal
- For external systems β API endpoints via controllers
- For AI agents β MCP tools for intelligent automation
Installation
You can install the package via composer:
composer require opscale-co/actions
The package is automatically registered via Laravel's package discovery.
Usage
Real-World Example: ResetPassword
Here's a complete example showing how a single ResetPassword action can serve your entire application:
use Opscale\Actions\Action; class ResetPassword extends Action { public function identifier(): string { return 'reset-password'; } public function name(): string { return 'Reset Password'; } public function description(): string { return 'Resets a user\'s password'; } public function parameters(): array { return [ [ 'name' => 'email', 'description' => 'The email address of the user', 'type' => 'string', 'rules' => ['required', 'email', 'exists:users,email'], ], [ 'name' => 'password', 'description' => 'The new password', 'type' => 'string', 'rules' => ['required', 'string', 'min:8'], ], [ 'name' => 'password_confirmation', 'description' => 'Confirm the new password', 'type' => 'string', 'rules' => ['required', 'string', 'same:password'], ], ]; } public function handle(array $attributes = []): array { $this->fill($attributes); $validated = $this->validateAttributes(); $user = User::where('email', $validated['email'])->firstOrFail(); $user->update(['password' => Hash::make($validated['password'])]); return [ 'success' => true, 'message' => 'Password reset successfully' ]; } }
One Action, Multiple Contexts
Now this single class can be used everywhere:
// For end users β Nova Action in admin panel // Register in your Nova Resource: public function actions(NovaRequest $request) { return [ ResetPassword::make() ]; } // For administrators β Artisan command // php artisan reset-password --email=user@example.com --password=newpass123 $this->commands([ ResetPassword::class, ]); // For external systems β API endpoint Route::post('/api/reset-password', ResetPassword::class); // For AI agents β MCP tool // Register in your MCP Server: class PlatformServer extends Server { protected array $tools = [ ResetPassword::class ]; }
Opinionated Design
This package is an opinionated implementation that enforces the use of WithAttributes from Laravel Actions. All input data flows through fill() and validateAttributes(), ensuring consistent parameters validation and attribute handling across all contexts.
The package provides a default behavior for all four audiences (Nova Actions, Artisan Commands, Controllers, and MCP Tools), so your actions work out of the box without additional configuration, but it can be overriden using the speficic methods for each output.
Testing
npm run test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email development@opscale.co instead of using the issue tracker.
Credits
Built by Opscale on top of:
- Laravel Actions by Loris Leiva
- Laravel Nova by Laravel
- Laravel MCP by Laravel
License
The MIT License (MIT). Please see License File for more information.
