feat(users): added user roles, user factory and seeder
This commit is contained in:
parent
18f14cf58e
commit
241725bf7d
6 changed files with 126 additions and 6 deletions
|
@ -2,12 +2,13 @@
|
|||
|
||||
namespace Database\Factories;
|
||||
|
||||
use App\Models\User;
|
||||
use Illuminate\Database\Eloquent\Factories\Factory;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
/**
|
||||
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\User>
|
||||
* @extends Factory<User>
|
||||
*/
|
||||
class UserFactory extends Factory
|
||||
{
|
||||
|
@ -24,11 +25,12 @@ class UserFactory extends Factory
|
|||
public function definition(): array
|
||||
{
|
||||
return [
|
||||
'name' => fake()->name(),
|
||||
'login' => fake()->name(),
|
||||
'email' => fake()->unique()->safeEmail(),
|
||||
'email_verified_at' => now(),
|
||||
'password' => static::$password ??= Hash::make('password'),
|
||||
'pass' => static::$password ??= Hash::make('password'),
|
||||
'remember_token' => Str::random(10),
|
||||
'type' => $this->faker->randomElement(['A', 'H', 'P']),
|
||||
];
|
||||
}
|
||||
|
||||
|
@ -41,4 +43,43 @@ class UserFactory extends Factory
|
|||
'email_verified_at' => null,
|
||||
]);
|
||||
}
|
||||
|
||||
public function admin(): Factory
|
||||
{
|
||||
return $this->state(function (array $attributes) {
|
||||
return [
|
||||
'type' => 'A',
|
||||
];
|
||||
})->afterCreating(function ($user) {
|
||||
$user->assignRole('admin');
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Define dj user
|
||||
*/
|
||||
public function dj(): Factory
|
||||
{
|
||||
return $this->state(function (array $attributes) {
|
||||
return [
|
||||
'type' => 'H',
|
||||
];
|
||||
})->afterCreating(function ($user) {
|
||||
$user->assignRole('dj');
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Define editor user
|
||||
*/
|
||||
public function editor(): Factory
|
||||
{
|
||||
return $this->state(function (array $attributes) {
|
||||
return [
|
||||
'type' => 'P',
|
||||
];
|
||||
})->afterCreating(function ($user) {
|
||||
$user->assignRole('editor');
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -14,6 +14,7 @@ return new class extends Migration
|
|||
Schema::table('cc_subjs', function (Blueprint $table) {
|
||||
$table->rememberToken();
|
||||
$table->timestamps();
|
||||
$table->string('email_verified_at')->nullable();
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -22,6 +23,6 @@ return new class extends Migration
|
|||
*/
|
||||
public function down(): void
|
||||
{
|
||||
Schema::dropIfExists('wa_users');
|
||||
Schema::dropIfExists('cc_subjs');
|
||||
}
|
||||
};
|
||||
|
|
17
database/seeders/UserSeeder.php
Normal file
17
database/seeders/UserSeeder.php
Normal file
|
@ -0,0 +1,17 @@
|
|||
<?php
|
||||
|
||||
namespace Database\Seeders;
|
||||
|
||||
use App\Models\User;
|
||||
use Illuminate\Database\Seeder;
|
||||
|
||||
class UserSeeder extends Seeder
|
||||
{
|
||||
public function run(): void
|
||||
{
|
||||
User::factory()->admin()->create();
|
||||
User::factory()->dj()->create();
|
||||
User::factory()->editor()->create();
|
||||
}
|
||||
}
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue