summaryrefslogtreecommitdiff
path: root/db/migrate/20210713123345_create_dast_profile_schedule.rb
blob: 951aab6357974837d7cb6710beda49ad31d71b15 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# frozen_string_literal: true

class CreateDastProfileSchedule < ActiveRecord::Migration[6.1]
  include Gitlab::Database::MigrationHelpers

  INDEX_NAME = 'index_dast_profile_schedules_active_next_run_at'

  def up
    table_comment = {
      owner: 'group::dynamic analysis', description: 'Scheduling for scans using DAST Profiles'
    }

    create_table_with_constraints :dast_profile_schedules, comment: table_comment.to_json do |t|
      t.bigint :project_id, null: false
      t.bigint :dast_profile_id, null: false
      t.bigint :user_id

      t.datetime_with_timezone :next_run_at, null: false
      t.timestamps_with_timezone null: false
      t.boolean :active, default: true, null: false
      t.text :cron, null: false
      t.text_limit :cron, 255

      t.index %i[active next_run_at], name: INDEX_NAME
      t.index %i[project_id dast_profile_id], unique: true
      t.index :dast_profile_id
      t.index :user_id
    end
  end

  def down
    with_lock_retries do
      drop_table :dast_profile_schedules
    end
  end
end