about summary refs log tree commit diff
path: root/db/migrate/20181127130500_identity_id_to_bigint.rb
diff options
context:
space:
mode:
authorThibaut Girka <thib@sitedethib.com>2018-11-27 15:10:58 +0100
committerThibaut Girka <thib@sitedethib.com>2018-11-27 15:10:58 +0100
commit55edfd6e0e1cb5377f0c3406d94ddfd84ddb7b20 (patch)
tree0f9f6e40e40f4ecabfa1e5f906000abe756f42a9 /db/migrate/20181127130500_identity_id_to_bigint.rb
parentf969eca07e2ac7b601694c463ef7097b787bbf65 (diff)
parent637d0ed8380442e95696e0b9769ba304afb22cd5 (diff)
Merge branch 'master' into glitch-soc/merge-upstream
Diffstat (limited to 'db/migrate/20181127130500_identity_id_to_bigint.rb')
-rw-r--r--db/migrate/20181127130500_identity_id_to_bigint.rb27
1 files changed, 27 insertions, 0 deletions
diff --git a/db/migrate/20181127130500_identity_id_to_bigint.rb b/db/migrate/20181127130500_identity_id_to_bigint.rb
new file mode 100644
index 000000000..5f388aca7
--- /dev/null
+++ b/db/migrate/20181127130500_identity_id_to_bigint.rb
@@ -0,0 +1,27 @@
+require Rails.root.join('lib', 'mastodon', 'migration_helpers')
+
+class IdentityIdToBigint < ActiveRecord::Migration[5.2]
+  include Mastodon::MigrationHelpers
+
+  disable_ddl_transaction!
+
+  def up
+    safety_assured do
+      change_column_type_concurrently :identities, :id, :bigint
+      cleanup_concurrent_column_type_change :identities, :id
+
+      change_column_type_concurrently :identities, :user_id, :bigint
+      cleanup_concurrent_column_type_change :identities, :user_id
+    end
+  end
+
+  def down
+    safety_assured do
+      change_column_type_concurrently :identities, :id, :integer
+      cleanup_concurrent_column_type_change :identities, :id
+
+      change_column_type_concurrently :identities, :user_id, :integer
+      cleanup_concurrent_column_type_change :identities, :user_id
+    end
+  end
+end