Server IP : 66.29.132.124 / Your IP : 13.59.68.161 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/database/migrations/ |
Upload File : |
<?php use Bavix\Wallet\Models\Transaction; use Bavix\Wallet\Models\Wallet; use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\Schema; use Illuminate\Database\SQLiteConnection; class UpdateTransactionsTable extends Migration { /** * @return string */ protected function table(): string { return (new Transaction())->getTable(); } /** * @return string */ protected function walletTable(): string { return (new Wallet())->getTable(); } /** * @return void */ public function up(): void { Schema::table($this->table(), function (Blueprint $table) { $table->unsignedBigInteger('wallet_id') ->nullable() ->after('payable_id'); $table->foreign('wallet_id') ->references('id') ->on($this->walletTable()) ->onDelete('cascade'); }); $slug = config('wallet.wallet.default.slug', 'default'); DB::transaction(function () use ($slug) { Wallet::where('slug', $slug)->each(function (Wallet $wallet) { Transaction::query() ->where('payable_type', $wallet->holder_type) ->where('payable_id', $wallet->holder_id) ->update(['wallet_id' => $wallet->id]); }); }); } /** * @return void */ public function down(): void { Schema::table($this->table(), function (Blueprint $table) { if (!(DB::connection() instanceof SQLiteConnection)) { $table->dropForeign(['wallet_id']); } $table->dropColumn('wallet_id'); }); } }