diff options
Diffstat (limited to 'db/migrate/20210117210226_add_has_external_issue_tracker_trigger.rb')
-rw-r--r-- | db/migrate/20210117210226_add_has_external_issue_tracker_trigger.rb | 61 |
1 files changed, 0 insertions, 61 deletions
diff --git a/db/migrate/20210117210226_add_has_external_issue_tracker_trigger.rb b/db/migrate/20210117210226_add_has_external_issue_tracker_trigger.rb deleted file mode 100644 index 20fe0ee0fd1..00000000000 --- a/db/migrate/20210117210226_add_has_external_issue_tracker_trigger.rb +++ /dev/null @@ -1,61 +0,0 @@ -# frozen_string_literal: true - -class AddHasExternalIssueTrackerTrigger < ActiveRecord::Migration[6.0] - include Gitlab::Database::SchemaHelpers - - DOWNTIME = false - FUNCTION_NAME = 'set_has_external_issue_tracker' - TRIGGER_ON_INSERT_NAME = 'trigger_has_external_issue_tracker_on_insert' - TRIGGER_ON_UPDATE_NAME = 'trigger_has_external_issue_tracker_on_update' - TRIGGER_ON_DELETE_NAME = 'trigger_has_external_issue_tracker_on_delete' - - def up - create_trigger_function(FUNCTION_NAME, replace: true) do - <<~SQL - UPDATE projects SET has_external_issue_tracker = ( - EXISTS - ( - SELECT 1 - FROM services - WHERE project_id = COALESCE(NEW.project_id, OLD.project_id) - AND active = TRUE - AND category = 'issue_tracker' - ) - ) - WHERE projects.id = COALESCE(NEW.project_id, OLD.project_id); - RETURN NULL; - SQL - end - - execute(<<~SQL) - CREATE TRIGGER #{TRIGGER_ON_INSERT_NAME} - AFTER INSERT ON services - FOR EACH ROW - WHEN (NEW.category = 'issue_tracker' AND NEW.active = TRUE AND NEW.project_id IS NOT NULL) - EXECUTE FUNCTION #{FUNCTION_NAME}(); - SQL - - execute(<<~SQL) - CREATE TRIGGER #{TRIGGER_ON_UPDATE_NAME} - AFTER UPDATE ON services - FOR EACH ROW - WHEN (NEW.category = 'issue_tracker' AND OLD.active != NEW.active AND NEW.project_id IS NOT NULL) - EXECUTE FUNCTION #{FUNCTION_NAME}(); - SQL - - execute(<<~SQL) - CREATE TRIGGER #{TRIGGER_ON_DELETE_NAME} - AFTER DELETE ON services - FOR EACH ROW - WHEN (OLD.category = 'issue_tracker' AND OLD.active = TRUE AND OLD.project_id IS NOT NULL) - EXECUTE FUNCTION #{FUNCTION_NAME}(); - SQL - end - - def down - drop_trigger(:services, TRIGGER_ON_INSERT_NAME) - drop_trigger(:services, TRIGGER_ON_UPDATE_NAME) - drop_trigger(:services, TRIGGER_ON_DELETE_NAME) - drop_function(FUNCTION_NAME) - end -end |