Download the PHP package vdlp/eloquent-model-cloner without Composer
On this page you can find all versions of the php package vdlp/eloquent-model-cloner. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download vdlp/eloquent-model-cloner
More information about vdlp/eloquent-model-cloner
Files in vdlp/eloquent-model-cloner
Package eloquent-model-cloner
Short Description Clone eloquent models and relations
License MIT
Homepage https://github.com/vdlp/eloquent-model-cloner
Informations about the package eloquent-model-cloner
Eloquent model cloner
This package was inspired by https://github.com/BKWLD/cloner and modified to also work with OctoberCMS installations.
A trait for Laravel Eloquent models that lets you clone a model and it's relationships, including files. Even to another database.
Installation
To get started with the Eloquent Model Cloner, use Composer to add the package to your project's dependencies:
Usage
Your model should now look like this:
You can clone an Article model like so:
Cloning Relationships
Lets say your Article
has many Photos
(a one to many relationship) and can have more than one Authors
(a many to many relationship). Now, your Article
model should look like this:
The $cloneableRelations
informs the Cloneable
as to which relations it should follow when cloning.
Now when you call Article::first()->duplicate()
, all of the Photo
rows of the original will be copied and associated with the new Article
.
And new pivot rows will be created associating the new Article
with the Authors
of the original (because it is a many to many relationship, no new Author
rows are created).
Furthermore, if the Photo
model has many of some other model, you can specify $cloneableRelations
in its class and Cloner
will continue replicating them as well.
Customizing the cloned attributes
By default, Cloner
does not copy the id
(or whatever you've defined as the key
for the model) field; it assumes a new value will be auto-incremented.
It also does not copy the created_at
or updated_at
.
You can add additional attributes to ignore as follows:
The $cloneExemptAttributes
adds to the defaults.
If you want to replace the defaults altogether, override the trait's getCloneExemptAttributes()
method and return an array.
Also, note the onCloning()
method in the example.
It is being used to make sure a unique column stays unique.
The Cloneable
trait adds to no-op callbacks that get called immediately before a model is saved during a duplication and immediately after: onCloning()
and onCloned()
.
The $child
parameter allows you to customize the behavior based on if it's being cloned as a relation or direct.
In addition, Cloner fires events during cloning and when the model has been cloned, see:
\Vdlp\EloquentModelCloner\Events\Cloned
\Vdlp\EloquentModelCloner\Events\Cloning
The event payload contains the clone and the original model instances.