grazulex/laravel-statecraft

A declarative and testable way to model entity state transitions (orders, documents, processes…) with guard conditions, actions, and events.

v1.3.0 2025-07-20 12:28 UTC

This package is auto-updated.

Last update: 2025-08-21 23:42:01 UTC


README

Laravel Statecraft

Advanced State Machine implementation for Laravel applications. Declarative state management with support for conditions, actions, and complex workflows through YAML configuration.

Latest Version Total Downloads License PHP Version Laravel Version Tests Code Style

πŸ“– Table of Contents

Overview

Laravel Statecraft is a powerful state machine implementation for Laravel that provides declarative state management through YAML configuration. Build complex workflows with conditional transitions, guards, actions, and comprehensive state tracking.

Perfect for order processing, user workflows, approval systems, and any application requiring sophisticated state management.

🎯 Use Cases

Laravel Statecraft is perfect for:

  • Order Processing - Complex e-commerce order workflows
  • User Registration - Multi-step user onboarding flows
  • Approval Systems - Document or request approval workflows
  • Content Management - Publishing and moderation workflows
  • Business Processes - Any multi-state business logic

✨ Features

  • πŸš€ Declarative Configuration - Define state machines in YAML files
  • πŸ”„ Flexible Transitions - Conditional transitions with guards and actions
  • 🎯 Event System - Built-in events for state changes and transitions
  • πŸ“Š State History - Track all state changes with timestamps
  • πŸ›‘οΈ Guards & Actions - Pre/post transition validation and processing
  • πŸ”— Model Integration - Seamless Eloquent model integration
  • πŸ“‹ YAML Support - Human-readable state machine definitions
  • 🎨 Artisan Commands - CLI tools for state machine management
  • βœ… Validation - Comprehensive state machine validation
  • πŸ“ˆ Visualization - Export state machines to Mermaid diagrams
  • πŸ§ͺ Test-Friendly - Built-in testing utilities
  • ⚑ Performance - Optimized for speed with caching support

πŸ“¦ Installation

Detailed installation instructions are available in our wiki: πŸ“¦ Installation & Setup

Quick install via Composer:

composer require grazulex/laravel-statecraft

πŸ’‘ Auto-Discovery
The service provider will be automatically registered thanks to Laravel's package auto-discovery.

Publish configuration:

php artisan vendor:publish --tag=statecraft-config

Publish migrations (if using history tracking):

php artisan vendor:publish --tag=statecraft-migrations
php artisan migrate

πŸš€ Quick Start

For a complete getting started guide, visit: πŸš€ Basic Usage Guide

1. Create a State Machine Definition

php artisan statecraft:make OrderStateMachine --model=Order

2. Define Your State Machine in YAML

# state-machines/OrderStateMachine.yaml
name: OrderStateMachine
model: App\Models\Order
initial_state: pending

states:
  - name: pending
    description: Order is pending payment
  - name: paid
    description: Order has been paid
  - name: shipped
    description: Order has been shipped

transitions:
  - name: pay
    from: pending
    to: paid
    guard: PaymentGuard
    action: ProcessPayment

3. Add the Trait to Your Model

use Grazulex\LaravelStatecraft\HasStateMachine;

class Order extends Model
{
    use HasStateMachine;
    
    protected $stateMachine = 'OrderStateMachine';
}

4. Use State Transitions

// Create a new order (starts in 'pending' state)
$order = Order::create(['total' => 100.00]);

// Transition to next state
$order->transition('pay'); // Moves to 'paid' state

// Check current state
echo $order->currentState(); // 'paid'

πŸ“š Complete Documentation

Our comprehensive documentation is available in the GitHub Wiki:

πŸ—οΈ Core Concepts

πŸ”§ Advanced Topics

πŸ“– Getting Started

πŸ’‘ Examples & Use Cases

Explore real-world implementations and patterns:

πŸ”§ Requirements

  • PHP 8.2 or higher
  • Laravel 11.x or higher
  • Optional: Redis for caching (recommended for production)

πŸ§ͺ Testing

Comprehensive testing guide: πŸ§ͺ Testing Guide

composer test
composer test:coverage
composer test:types

πŸš€ Performance

Laravel Statecraft is optimized for production use with caching support and minimal overhead. See our βš™οΈ Configuration Guide for performance optimization tips.

🀝 Contributing

We welcome contributions! Please see CONTRIBUTING.md for details.

Before contributing:

  1. Read our Code of Conduct
  2. Check the issue tracker
  3. Review our πŸ“š Complete Documentation

πŸ”’ Security

If you discover a security vulnerability, please send an e-mail via the security policy. All security vulnerabilities will be promptly addressed.

πŸ“„ License

Laravel Statecraft is open-sourced software licensed under the MIT license.

Made with ❀️ for the Laravel community

Resources

Community Links