patinthehat/laravel-support

Laravel 5 support classes

v1.2.2 2017-04-02 11:31 UTC

This package is not auto-updated.

Last update: 2024-11-09 20:56:23 UTC


README

Various support classes for Laravel 5+.

####Installation

Install with composer:

composer require patinthehat/laravel-support

Classes

#####ExtendedSeeder ExtendedSeeder is an extended version of the Seeder class and provides easy foreign key check enable/disable and table truncating. It also allows for easy access to Faker.

######Methods

  • getFaker() - returns an instance of Faker\Factory (see Faker).
  • init($tableName, $disableForeignKeyChecks = true, $deleteAllTableEntries = true) - call at the beginning of run().
  • cleanup() - call at the end of run().

######Sample Usage:

use App\Support\ExtendedSeeder;
use App\User;

class UserTableSeeder extends ExtendedSeeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        //disable foreign key checks, delete all existing table entries
        $this->init('users', true, true); 
        //seed the table
        $text = $this->getFaker()->text();
        $this->cleanup();
    }
}

#####ExtendedMigration ExtendedMigration is an extended version of the Migration class and provides easy foreign key creation/deletion.

######Methods

######Sample Usage:

use LaravelSupport\Database\ExtendedMigration;

class CreateForeignKeys extends ExtendedMigration
{
    //define the FKs
    protected $foreignKeyDefinitions = [
        'info.author_id' => ['authors.id', 'cascade', 'cascade'],
        'info.book_id' => ['books.id', null, null],
        'table2.test_id' => 'tests.id',
        'myinfo.publisher_id' => null, //creates FK on 'publishers.id'
    ];
    
    //automatically create/delete FKs
    protected $autoCreateDefinedKeys = true;
    protected $autoDeleteDefinedKeys = true;
}

License

LaravelSupport is available under the MIT License.