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
Requires
- illuminate/console: ^8.0|^9.0|^10.0|^11.0||^12.0
- illuminate/database: ^8.0|^9.0|^10.0|^11.0||^12.0
- illuminate/events: ^8.0|^9.0|^10.0|^11.0||^12.0
- illuminate/support: ^8.0|^9.0|^10.0|^11.0||^12.0
Requires (Dev)
- laravel/pint: ^1.27
README
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:prunecommand
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.