CreateOauthAuthCodesTable   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 37
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 5

Importance

Changes 0
Metric Value
wmc 2
lcom 1
cbo 5
dl 0
loc 37
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A up() 0 19 1
A down() 0 4 1
1
<?php
2
3
declare(strict_types=1);
4
5
use Illuminate\Support\Facades\Schema;
6
use Illuminate\Database\Schema\Blueprint;
7
use Illuminate\Database\Migrations\Migration;
8
9
class CreateOauthAuthCodesTable extends Migration
10
{
11
    /**
12
     * Run the migrations.
13
     *
14
     * @return void
15
     */
16
    public function up(): void
17
    {
18
        Schema::create(config('rinvex.oauth.tables.auth_codes'), function (Blueprint $table) {
19
            $table->increments('id');
20
            $table->string('identifier', 100);
21
            $table->integer('user_id')->unsigned();
22
            $table->string('user_type');
23
            $table->integer('client_id')->unsigned();
24
            $table->boolean('is_revoked')->default(false);
25
            $table->dateTime('expires_at')->nullable();
26
            $table->timestamps();
27
28
            // Indexes
29
            $table->unique('identifier');
30
            $table->index(['user_type', 'user_id'], 'auth_codes_user_type_id');
31
            $table->foreign('client_id')->references('id')->on(config('rinvex.oauth.tables.clients'))
32
                  ->onDelete('cascade')->onUpdate('cascade');
33
        });
34
    }
35
36
    /**
37
     * Reverse the migrations.
38
     *
39
     * @return void
40
     */
41
    public function down(): void
42
    {
43
        Schema::dropIfExists(config('rinvex.oauth.tables.auth_codes'));
44
    }
45
}
46