summaryrefslogtreecommitdiff
path: root/db/migrate/20210713123345_create_dast_profile_schedule.rb
diff options
context:
space:
mode:
Diffstat (limited to 'db/migrate/20210713123345_create_dast_profile_schedule.rb')
-rw-r--r--db/migrate/20210713123345_create_dast_profile_schedule.rb36
1 files changed, 36 insertions, 0 deletions
diff --git a/db/migrate/20210713123345_create_dast_profile_schedule.rb b/db/migrate/20210713123345_create_dast_profile_schedule.rb
new file mode 100644
index 00000000000..951aab63579
--- /dev/null
+++ b/db/migrate/20210713123345_create_dast_profile_schedule.rb
@@ -0,0 +1,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