27 lines
748 B
Ruby
27 lines
748 B
Ruby
|
class EncodeCandidateEmails < ActiveRecord::Migration[5.0]
|
||
|
def change
|
||
|
sql = "select id, email from candidates;"
|
||
|
candidates = ActiveRecord::Base.connection.execute(sql).to_h
|
||
|
|
||
|
candidates.each do |id, email|
|
||
|
sql = if base64?(email)
|
||
|
# going down - decrypt
|
||
|
"UPDATE candidates set email = '#{CryptSerializer.load email}' WHERE id = #{id};"
|
||
|
else
|
||
|
# going up - encrypt emails
|
||
|
"UPDATE candidates set email = '#{CryptSerializer.dump email}' WHERE id = #{id};"
|
||
|
end
|
||
|
ActiveRecord::Base.connection.execute(sql)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def base64? string
|
||
|
Base64.urlsafe_decode64 string
|
||
|
true
|
||
|
rescue ArgumentError
|
||
|
false
|
||
|
end
|
||
|
end
|