31 lines
		
	
	
	
		
			658 B
		
	
	
	
		
			Elixir
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
	
		
			658 B
		
	
	
	
		
			Elixir
		
	
	
	
	
	
defmodule Pleroma.Repo.Migrations.CaseInsensivtivity do
 | 
						|
  use Ecto.Migration
 | 
						|
 | 
						|
  # Two-steps alters are intentional.
 | 
						|
  # When alter of 2 columns is done in a single operation,
 | 
						|
  # inconsistent failures happen because of index on `email` column.
 | 
						|
 | 
						|
  def up do
 | 
						|
    execute("create extension if not exists citext")
 | 
						|
 | 
						|
    alter table(:users) do
 | 
						|
      modify(:email, :citext)
 | 
						|
    end
 | 
						|
 | 
						|
    alter table(:users) do
 | 
						|
      modify(:nickname, :citext)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def down do
 | 
						|
    alter table(:users) do
 | 
						|
      modify(:email, :string)
 | 
						|
    end
 | 
						|
 | 
						|
    alter table(:users) do
 | 
						|
      modify(:nickname, :string)
 | 
						|
    end
 | 
						|
 | 
						|
    execute("drop extension if exists citext")
 | 
						|
  end
 | 
						|
end
 |