47 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?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('users', function (Blueprint $table) {
 | 
						|
            $table->ulid('id')->primary(); // ulid primary key
 | 
						|
            $table->string('uri')->nullable(); // formerly from sabre principals table
 | 
						|
            $table->string('displayname')->nullable(); // formerly from sabre principals table
 | 
						|
            $table->string('name')->nullable(); // custom name if necessary
 | 
						|
            $table->string('email')->unique();
 | 
						|
            $table->timestamp('email_verified_at')->nullable();
 | 
						|
            $table->string('password');
 | 
						|
            $table->rememberToken();
 | 
						|
            $table->timestamps();
 | 
						|
        });
 | 
						|
 | 
						|
        Schema::create('password_reset_tokens', function (Blueprint $table) {
 | 
						|
            $table->string('email')->primary();
 | 
						|
            $table->string('token');
 | 
						|
            $table->timestamp('created_at')->nullable();
 | 
						|
        });
 | 
						|
 | 
						|
        Schema::create('sessions', function (Blueprint $table) {
 | 
						|
            $table->string('id')->primary();
 | 
						|
            $table->ulid('user_id')->nullable()->index();   // ULID FK
 | 
						|
            $table->foreign('user_id')->references('id')->on('users')->cascadeOnDelete();
 | 
						|
            $table->string('ip_address', 45)->nullable();
 | 
						|
            $table->text('user_agent')->nullable();
 | 
						|
            $table->longText('payload');
 | 
						|
            $table->integer('last_activity')->index();
 | 
						|
        });
 | 
						|
    }
 | 
						|
 | 
						|
    public function down(): void
 | 
						|
    {
 | 
						|
        Schema::dropIfExists('sessions');
 | 
						|
        Schema::dropIfExists('password_reset_tokens');
 | 
						|
        Schema::dropIfExists('users');
 | 
						|
    }
 | 
						|
};
 |