1
0

20260428120009_create_ip_scores.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536
  1. <?php
  2. declare(strict_types=1);
  3. use App\Infrastructure\Db\Migrations\BaseMigration;
  4. final class CreateIpScores extends BaseMigration
  5. {
  6. public function change(): void
  7. {
  8. $table = $this->table('ip_scores', [
  9. 'id' => false,
  10. 'primary_key' => ['ip_bin', 'category_id'],
  11. ]);
  12. $this->addIpBinaryColumn($table, 'ip_bin', ['null' => false]);
  13. $table->addColumn('category_id', 'integer', ['null' => false, 'signed' => false]);
  14. $table->addColumn('ip_text', 'string', ['limit' => 45, 'null' => false]);
  15. $table->addColumn('score', 'decimal', ['precision' => 12, 'scale' => 4, 'null' => false, 'default' => '0.0000']);
  16. $table->addColumn('report_count_30d', 'integer', ['null' => false, 'default' => 0, 'signed' => false]);
  17. $this->addTimestampColumn($table, 'last_report_at', ['null' => true]);
  18. $this->addTimestampColumn($table, 'recomputed_at', ['null' => true]);
  19. $table
  20. ->addIndex(['category_id'])
  21. ->addIndex(['score'])
  22. ->addForeignKey(
  23. 'category_id',
  24. 'categories',
  25. 'id',
  26. ['delete' => 'CASCADE', 'update' => 'NO_ACTION', 'constraint' => 'fk_ip_scores_category']
  27. )
  28. ->create();
  29. }
  30. }