feat(wallets): implement wallet and transaction management with associated models, policies, and resources
This commit is contained in:
@@ -0,0 +1,24 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
public function up(): void
|
||||
{
|
||||
Schema::create('wallets', function (Blueprint $table) {
|
||||
$table->id();
|
||||
$table->foreignId('user_id')->unique()->constrained()->cascadeOnDelete();
|
||||
$table->unsignedBigInteger('balance')->default(0);
|
||||
$table->boolean('is_active')->default(true);
|
||||
$table->timestamps();
|
||||
});
|
||||
}
|
||||
|
||||
public function down(): void
|
||||
{
|
||||
Schema::dropIfExists('wallets');
|
||||
}
|
||||
};
|
||||
@@ -0,0 +1,30 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
public function up(): void
|
||||
{
|
||||
Schema::create('wallet_transactions', function (Blueprint $table) {
|
||||
$table->id();
|
||||
$table->foreignId('wallet_id')->constrained()->cascadeOnDelete();
|
||||
$table->string('type');
|
||||
$table->unsignedBigInteger('amount');
|
||||
$table->unsignedBigInteger('balance_before');
|
||||
$table->unsignedBigInteger('balance_after');
|
||||
$table->string('description')->nullable();
|
||||
$table->foreignId('created_by')->nullable()->constrained('users')->nullOnDelete();
|
||||
$table->timestamps();
|
||||
|
||||
$table->index(['wallet_id', 'created_at']);
|
||||
});
|
||||
}
|
||||
|
||||
public function down(): void
|
||||
{
|
||||
Schema::dropIfExists('wallet_transactions');
|
||||
}
|
||||
};
|
||||
@@ -5,6 +5,7 @@ namespace Database\Seeders;
|
||||
use App\Models\Permission;
|
||||
use App\Models\Role;
|
||||
use App\Models\User;
|
||||
use App\Services\WalletService;
|
||||
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
|
||||
use Illuminate\Database\Seeder;
|
||||
|
||||
@@ -24,6 +25,7 @@ class DatabaseSeeder extends Seeder
|
||||
['name' => 'مدیریت کاربران', 'slug' => 'users.manage'],
|
||||
['name' => 'مدیریت نقشها', 'slug' => 'roles.manage'],
|
||||
['name' => 'مدیریت دسترسیها', 'slug' => 'permissions.manage'],
|
||||
['name' => 'مدیریت کیف پول', 'slug' => 'wallets.manage'],
|
||||
])->map(fn (array $permission) => Permission::query()->updateOrCreate(
|
||||
['slug' => $permission['slug']],
|
||||
['name' => $permission['name']],
|
||||
@@ -47,5 +49,7 @@ class DatabaseSeeder extends Seeder
|
||||
);
|
||||
|
||||
$user->roles()->sync([$adminRole->id]);
|
||||
|
||||
User::query()->each(fn (User $user) => app(WalletService::class)->createForUser($user));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user