Package Data | |
---|---|
Maintainer Username: | bmstanley |
Maintainer Contact: | patrick@shiftonelabs.com (Patrick Carlo-Hickman) |
Package Create Date: | 2019-11-15 |
Package Last Update: | 2019-11-15 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-22 15:05:06 |
Package Statistics | |
---|---|
Total Downloads: | 172 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 0 |
Total Watchers: | 1 |
Total Forks: | 0 |
Total Open Issues: | 0 |
This Laravel package provides additional functionality for the Illuminate Database migrations. Currently the only additional functionality is the ability to specify custom database field types, but new functionality can be added as requested/submitted.
5.5
Via Composer
$ composer require bmstanley/laravel-nomad
For Laravel 5.5 and newer, no configuration is needed. The package will be auto-discovered.
Laravel's migrations provide methods for a wide base of the standard field types used in the supported databases, however it is not an exhaustive list. Additionally, some databases have extensions that can be enabled that add new field types. Unfortunately, one cannot create fields with these new data types using built-in migration methods.
As an example, PostgreSQL has a "citext" module to allow easy case-insensitive matching. This module adds a new "citext" field data type for storing case-insensitive string data. The built-in migration methods do not have a way to create a "citext" field, so one would have to add a direct "ALTER" statement to run after the table is created.
This package adds a new passthru
method to allow defining custom data types in the migration. The passthru
method can be used to add a field with any data type, as the specified type is merely passed through to the schema grammar.
The passthru
method requires two parameters: the data type and the field name. An optional third parameter can be used to specify the actual data type definition, if needed. The definition
method can also be chained on to specify the actual data type definition. A usage example is shown below:
class CreateUsersTable extends Migration {
public function up()
{
Schema::create('users', function(Blueprint $table)
{
$table->increments('id');
$table->passthru('citext', 'name');
$table->passthru('citext', 'title')->nullable();
$table->passthru('string', 'email', 'varchar(255)')->unique();
$table->passthru('string', 'password')->definition('varchar(60)');
$table->rememberToken();
$table->timestamps();
});
}
public function down()
{
Schema::drop('users');
}
}
Contributions are very welcome. Please see CONTRIBUTING for details.
If you discover any security related issues, please email patrick@shiftonelabs.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.