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

1.0.0 2025-12-18 15:56 UTC

This package is auto-updated.

Last update: 2025-12-18 15:59:00 UTC


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

Actions demo

Installation

Latest Version on Packagist

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:

License

The MIT License (MIT). Please see License File for more information.