Download the PHP package laracasts/generators without Composer
On this page you can find all versions of the php package laracasts/generators. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download laracasts/generators
More information about laracasts/generators
Files in laracasts/generators
Package generators
Short Description Advanced Laravel generators, that include schema information.
License MIT
Informations about the package generators
Extended Migration Generators for Laravel 6, 7, 8 and 9
Easily define the migration schema right in your make:migration
command. The new commands this package provides are:
make:migration:schema
make:migration:pivot
Which allows you to do php artisan make:migration:schema create_dogs_table --schema="name:string:nullable, description:text, age:integer, email:string:unique"
and get a full migration that you can run using php artisan migrate
. For simple cases like this one, no need to tinker inside the migration file itself. And if you do need to change anything, it's easier because the bulk of the code has already been generated.
Created in 2015 by Jeffrey Way as a natural progression of his JeffreyWay/Laravel-4-Generators package, to provide the same features for Laravel 5. Since 2017 it's been maintained by the Backpack for Laravel team, with features and fixes added by community members like you. So feel free to pitch in.
Table of Contents
- Versions
- Installation
- Examples
- Migrations With Schema
- Foreign Constraints
- Pivot Tables
- Migrations With Schema
Versions
Depending on your Laravel version, you should:
- use JeffreyWay/Laravel-4-Generators for Laravel 4;
- use
v1
of this package for Laravel 5.0 - 5.8; - use
v2
of this package for Laravel 6-8;
Installation
You can install v2 of this project using composer, the service provider will be automatically loaded by Laravel itself:
You're all set. Run php artisan
from the console, and you'll see the new commands in the make:*
namespace section.
Examples
- Migrations With Schema
- Pivot Tables
Migrations With Schema
Notice the format that we use, when declaring any applicable schema: a comma-separated list...
So any of these will do:
Using the schema from earlier...
...this will give you:
When generating migrations with schema, the name of your migration (like, "create_users_table") matters. We use it to figure out what you're trying to accomplish. In this case, we began with the "create" keyword, which signals that we want to create a new table.
Alternatively, we can use the "remove" or "add" keywords, and the generated boilerplate will adapt, as needed. Let's create a migration to remove a column.
Now, notice that we're using the correct Schema methods.
Here's a few other examples of commands that you might write:
php artisan make:migration:schema create_posts_table
php artisan make:migration:schema create_posts_table --schema="title:string, body:text, excerpt:string:nullable"
php artisan make:migration:schema remove_excerpt_from_posts_table --schema="excerpt:string:nullable"
Models
Now, when you create a migration, you typically want a model to go with it, right? By default, this package won't create a model to go with the migration. But it could. Just specify --model=true
and it will do that for you:
Migration Path
If you wish to specify a different path for your migration file, you can use the --path
option like so:
Foreign Constraints
There's also a secret bit of sugar for when you need to generate foreign constraints. Imagine that you have a posts table, where each post belongs to a user. Let's try:
Notice that "foreign" option (user_id:unsignedInteger:foreign
)? That's special. It signals that user_id
should receive a foreign constraint. Following conventions, this will give us:
As such, for that full command, our schema should look like so:
Neato.
Pivot Tables
So you need a migration to setup a pivot table in your database? Easy. We can scaffold the whole class with a single command.
Here we pass, in any order, the names of the two tables that we need a joining/pivot table for. This will give you:
Notice that the naming conventions are being followed here, regardless of what order you pass the table names.