1
0

20260428120011_create_manual_blocks.php 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. <?php
  2. declare(strict_types=1);
  3. use App\Infrastructure\Db\Migrations\BaseMigration;
  4. final class CreateManualBlocks extends BaseMigration
  5. {
  6. public function change(): void
  7. {
  8. $table = $this->table('manual_blocks');
  9. $table->addColumn('kind', 'string', ['limit' => 16, 'null' => false]);
  10. $this->addIpBinaryColumn($table, 'ip_bin', ['null' => true]);
  11. $this->addIpBinaryColumn($table, 'network_bin', ['null' => true]);
  12. $table->addColumn('prefix_length', 'smallinteger', ['null' => true, 'signed' => false]);
  13. $table->addColumn('reason', 'text', ['null' => true]);
  14. $table->addColumn('created_by_user_id', 'integer', ['null' => true, 'signed' => false]);
  15. $this->addTimestampColumn($table, 'expires_at', ['null' => true]);
  16. $this->addTimestampColumn($table, 'created_at');
  17. $table
  18. ->addIndex(['ip_bin'], ['name' => 'idx_manual_blocks_ip_bin'])
  19. ->addIndex(['network_bin'], ['name' => 'idx_manual_blocks_network_bin'])
  20. ->addIndex(['kind'])
  21. ->addIndex(['created_by_user_id'])
  22. ->addForeignKey(
  23. 'created_by_user_id',
  24. 'users',
  25. 'id',
  26. ['delete' => 'SET_NULL', 'update' => 'NO_ACTION', 'constraint' => 'fk_manual_blocks_created_by']
  27. )
  28. ->create();
  29. }
  30. }