devsarfo/laraprunable

Laravel Prunable Package that supports SoftDeletes trait

Installs: 12

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/devsarfo/laraprunable

1.2 2026-01-11 11:39 UTC

This package is auto-updated.

Last update: 2026-01-11 11:42:06 UTC


README

Latest Version on Packagist GitHub Code Style Action Status Total Downloads

A Laravel package that extends the built-in pruning functionality to support models using the SoftDeletes trait. This package allows you to safely prune (soft delete) records based on custom criteria without purging them from the database.

Features

  • SoftDeletes Support: Prune soft-deleted models without remove database records
  • Mass Pruning: Efficiently prune large datasets in chunks
  • Laravel Integration: Seamlessly extends Laravel's existing php artisan model:prune command

Installation

You can install the package via composer using the following command. The command will install the latest applicable version of the package.

composer require devsarfo/laraprunable

The package will automatically register its service provider and extend Laravel's prune command.

Requirements

  • Laravel 8.0 or higher

Usage

1. Add the Trait to Your Model

Choose the appropriate trait based on your pruning needs:

For Individual Pruning (SoftPrunable)

Use this trait when you need to prune models one by one, which is useful for models with complex pruning logic or when you need to perform additional operations during pruning.

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use DevSarfo\LaraPrunable\Traits\SoftPrunable;

class Post extends Model
{
    use SoftDeletes, SoftPrunable;

    /**
     * Get the prunable model query.
     *
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function prunable()
    {
        return static::where('deleted_at', '<=', now()->subDays(30));
    }

    /**
     * Prepare the model for pruning.
     *
     * @return void
     */
    protected function pruning()
    {
        // Perform any cleanup before pruning
        // e.g., delete related files, log activity, etc.
    }
}

For Mass Pruning (SoftMassPrunable)

Use this trait when you need to prune large numbers of records efficiently. This performs bulk deletions in chunks.

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use DevSarfo\LaraPrunable\Traits\SoftMassPrunable;

class Comment extends Model
{
    use SoftDeletes, SoftMassPrunable;

    /**
     * Get the prunable model query.
     *
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function prunable()
    {
        return static::where('deleted_at', '<=', now()->subDays(7));
    }
}

2. Run the Prune Command

Use Laravel's built-in prune command. The package automatically extends it to recognize models using the SoftPrunable and SoftMassPrunable traits.

php artisan model:prune

You can also specify a specific model:

php artisan model:prune --model=App\\Models\\Post

3. Scheduling Pruning

You can schedule pruning to run automatically using Laravel's task scheduler: You are free to choose the appropriate interval at which this command should be run:

// In routes/console.php
use Illuminate\Support\Facades\Schedule;

Schedule::command('model:prune')->daily();

OR

// In app/Console/Kernel.php
protected function schedule(Schedule $schedule)
{
    $schedule->command('model:prune')->daily();
}

Configuration

No additional configuration is required. The package automatically:

  • Registers the service provider
  • Extends Laravel's PruneCommand
  • Recognizes models using the provided traits

Testing

composer test

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email devsarfo@gmail.com instead of using the issue tracker.

Credits

License

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