• Stars
    star
    935
  • Rank 48,878 (Top 1.0 %)
  • Language
    PHP
  • License
    MIT License
  • Created over 8 years ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Cascading deletes for Eloquent models that implement soft deletes

Cascading soft deletes for the Laravel PHP Framework

Build Status Latest Stable Version Total Downloads License Buy us a tree

Introduction

In scenarios when you delete a parent record - say for example a blog post - you may want to also delete any comments associated with it as a form of self-maintenance of your data.

Normally, you would use your database's foreign key constraints, adding an ON DELETE CASCADE rule to the foreign key constraint in your comments table.

It may be useful to be able to restore a parent record after it was deleted. In those instances, you may reach for Laravel's soft deleting functionality.

In doing so, however, you lose the ability to use the cascading delete functionality that your database would otherwise provide. That is where this package aims to bridge the gap in functionality when using the SoftDeletes trait.

Code Samples

<?php

namespace App;

use App\Comment;
use Dyrynda\Database\Support\CascadeSoftDeletes;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;

class Post extends Model
{
    use SoftDeletes, CascadeSoftDeletes;

    protected $cascadeDeletes = ['comments'];

    protected $dates = ['deleted_at'];

    public function comments()
    {
        return $this->hasMany(Comment::class);
    }
}

Now you can delete an App\Post record, and any associated App\Comment records will be deleted. If the App\Comment record implements the CascadeSoftDeletes trait as well, it's children will also be deleted and so on.

$post = App\Post::find($postId)
$post->delete(); // Soft delete the post, which will also trigger the delete() method on any comments and their children.

Note: It's important to know that when you cascade your soft deleted child records, there is no way to know which were deleted by the cascading operation, and which were deleted prior to that. This means that when you restore the blog post, the associated comments will not be.

Because this trait hooks into the deleting Eloquent model event, we can prevent the parent record from being deleted as well as any child records, if any exception is triggered. A LogicException will be triggered if the model does not use the Illuminate\Database\Eloquent\SoftDeletes trait, or if any of the defined cascadeDeletes relationships do not exist, or do not return an instance of Illuminate\Database\Eloquent\Relations\Relation.

Installation

This trait is installed via Composer. To install, simply add to your composer.json file:

$ composer require dyrynda/laravel-cascade-soft-deletes

Support

If you are having general issues with this package, feel free to contact me on Twitter.

If you believe you have found an issue, please report it using the GitHub issue tracker, or better yet, fork the repository and submit a pull request.

If you're using this package, I'd love to hear your thoughts. Thanks!

Treeware

You're free to use this package, but if it makes it to your production environment you are required to buy the world a tree.

It’s now common knowledge that one of the best tools to tackle the climate crisis and keep our temperatures from rising above 1.5C is to plant trees. If you support this package and contribute to the Treeware forest you’ll be creating employment for local families and restoring wildlife habitats.

You can buy trees here

Read more about Treeware at treeware.earth

More Repositories

1

laravel-model-uuid

This package allows you to easily work with UUIDs in your Laravel models
PHP
449
star
2

laravel-efficient-uuid

PHP
305
star
3

phpstorm-laravel-code-style

PhpStorm code style to meet Laravel's contribution guidelines
293
star
4

laravel-defibrillator

Ensure your Laravel applications keep a normal pulse
PHP
167
star
5

laravel-make-user

A simple Artisan command to create application users
PHP
109
star
6

laravel-nullable-fields

Handles saving empty fields as null for Eloquent models
PHP
104
star
7

dotfiles

Lua
57
star
8

nomad

Laravel-style database migrations wherever they may roam
PHP
56
star
9

vagabond

Eloquent without a home
PHP
48
star
10

founder

Laravel starter application
PHP
48
star
11

carbon.vim

A Vim port of the IntelliJ Carbon theme
Vim Script
41
star
12

Laravel.tmTheme

A Sublime Text 3 theme based on the Laravel documentation colour scheme
40
star
13

founder-style

Founder repository style guide
17
star
14

laravel-owns-models

PHP
15
star
15

readme-generator

Generate README files that rock!
HTML
15
star
16

laravel-google-cse

Laravel wrapper for the Google Custom Search Engine API
PHP
9
star
17

laravel-ldap

Leverage Laravel's middleware to ensure your LDAP-authenticated users stay that way
PHP
6
star
18

git-workflow

A git workflow for facilitating client-facing User Acceptance Testing
6
star
19

RestClient

A REST API Client
PHP
4
star
20

laracasts-saving-json-into-database

Tests and implementation for forum post
JavaScript
4
star
21

terminable-jobs

PHP
3
star
22

telstra-sms

PHP
2
star
23

dyryme

dyry.me link shortener
PHP
2
star
24

amber-electric-php

PHP
2
star
25

zsh-completions

zsh completion scripts
Shell
1
star
26

simple-menu

PHP
1
star
27

chalrynda-blog

Michael & Rhiannon's travel blog
CSS
1
star
28

foods-for-life

Foods For Life Bedrock-based WordPress site
PHP
1
star
29

devdojo-events

PHP
1
star
30

deckset

1
star
31

bbc-good-food

PHP
1
star
32

hemp

PHP
1
star
33

s3upload

Code for blog series on uploading files to Amazon S3 from the browser
PHP
1
star