summaryrefslogtreecommitdiff
path: root/db/migrate/20201214032220_add_has_external_wiki_trigger.rb
blob: f6e066b75daac56e1d921e8c9837211f8cb993e2 (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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# frozen_string_literal: true

class AddHasExternalWikiTrigger < ActiveRecord::Migration[6.0]
  include Gitlab::Database::SchemaHelpers

  DOWNTIME = false
  FUNCTION_NAME = 'set_has_external_wiki'.freeze
  TRIGGER_ON_INSERT_NAME = 'trigger_has_external_wiki_on_insert'.freeze
  TRIGGER_ON_UPDATE_NAME = 'trigger_has_external_wiki_on_update'.freeze
  TRIGGER_ON_DELETE_NAME = 'trigger_has_external_wiki_on_delete'.freeze

  def up
    create_trigger_function(FUNCTION_NAME, replace: true) do
      <<~SQL
        UPDATE projects SET has_external_wiki = COALESCE(NEW.active, FALSE)
        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.active = TRUE AND NEW.type = 'ExternalWikiService' 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.type = 'ExternalWikiService' 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.type = 'ExternalWikiService' 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