2018-07-25 01:16:36 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-02-21 12:09:07 +00:00
|
|
|
# See https://docs.gitlab.com/ee/development/migration_style_guide.html
|
2016-05-09 13:06:22 +00:00
|
|
|
# for more information on how to write migrations for GitLab.
|
|
|
|
|
2021-09-01 18:08:49 +00:00
|
|
|
class <%= migration_class_name %> < Gitlab::Database::Migration[<%= Gitlab::Database::Migration.current_version %>]
|
2021-03-25 21:09:13 +00:00
|
|
|
# When using the methods "add_concurrent_index" or "remove_concurrent_index"
|
|
|
|
# you must disable the use of transactions
|
2017-04-05 22:53:57 +00:00
|
|
|
# as these methods can not run in an existing transaction.
|
|
|
|
# When using "add_concurrent_index" or "remove_concurrent_index" methods make sure
|
|
|
|
# that either of them is the _only_ method called in the migration,
|
|
|
|
# any other changes should go in a separate migration.
|
|
|
|
# This ensures that upon failure _only_ the index creation or removing fails
|
|
|
|
# and can be retried or reverted easily.
|
2016-05-09 12:31:39 +00:00
|
|
|
#
|
|
|
|
# To disable transactions uncomment the following line and remove these
|
|
|
|
# comments:
|
|
|
|
# disable_ddl_transaction!
|
2022-04-13 18:08:33 +00:00
|
|
|
#
|
|
|
|
# Configure the `gitlab_schema` to perform data manipulation (DML).
|
|
|
|
# Visit: https://docs.gitlab.com/ee/development/database/migrations_for_multiple_databases.html
|
|
|
|
# restrict_gitlab_migration gitlab_schema: :gitlab_main
|
2016-05-09 12:31:39 +00:00
|
|
|
|
|
|
|
<%- if migration_action == 'add' -%>
|
|
|
|
def change
|
|
|
|
<% attributes.each do |attribute| -%>
|
|
|
|
<%- if attribute.reference? -%>
|
|
|
|
add_reference :<%= table_name %>, :<%= attribute.name %><%= attribute.inject_options %>
|
|
|
|
<%- else -%>
|
|
|
|
add_column :<%= table_name %>, :<%= attribute.name %>, :<%= attribute.type %><%= attribute.inject_options %>
|
|
|
|
<%- if attribute.has_index? -%>
|
|
|
|
add_index :<%= table_name %>, :<%= attribute.index_name %><%= attribute.inject_index_options %>
|
|
|
|
<%- end -%>
|
|
|
|
<%- end -%>
|
|
|
|
<%- end -%>
|
|
|
|
end
|
|
|
|
<%- elsif migration_action == 'join' -%>
|
|
|
|
def change
|
|
|
|
create_join_table :<%= join_tables.first %>, :<%= join_tables.second %> do |t|
|
|
|
|
<%- attributes.each do |attribute| -%>
|
|
|
|
<%= '# ' unless attribute.has_index? -%>t.index <%= attribute.index_name %><%= attribute.inject_index_options %>
|
|
|
|
<%- end -%>
|
|
|
|
end
|
|
|
|
end
|
|
|
|
<%- else -%>
|
|
|
|
def change
|
|
|
|
<% attributes.each do |attribute| -%>
|
|
|
|
<%- if migration_action -%>
|
|
|
|
<%- if attribute.reference? -%>
|
|
|
|
remove_reference :<%= table_name %>, :<%= attribute.name %><%= attribute.inject_options %>
|
|
|
|
<%- else -%>
|
|
|
|
<%- if attribute.has_index? -%>
|
|
|
|
remove_index :<%= table_name %>, :<%= attribute.index_name %><%= attribute.inject_index_options %>
|
|
|
|
<%- end -%>
|
|
|
|
remove_column :<%= table_name %>, :<%= attribute.name %>, :<%= attribute.type %><%= attribute.inject_options %>
|
|
|
|
<%- end -%>
|
|
|
|
<%- end -%>
|
|
|
|
<%- end -%>
|
|
|
|
end
|
|
|
|
<%- end -%>
|
|
|
|
end
|