skill-assessment-app/db/migrate/20160826200610_encode_candidate_emails.rb
Mark Moser 4bbd93ded1 rubocop noise: fixes FrozenStringLiteralComment
Adding the .ruby-verison file triggered previously un-run cops, specifically:

  This cop is designed to help upgrade to Ruby 3.0. It will add the
  comment `# frozen_string_literal: true` to the top of files to enable
  frozen string literals. Frozen string literals will be default in Ruby
  3.0. The comment will be added below a shebang and encoding comment. The
  frozen string literal comment is only valid in Ruby 2.3+.

More info on rubocop [Automatic-Corrections](https://github.com/bbatsov/rubocop/wiki/Automatic-Corrections)
2016-09-08 10:30:13 -05:00

28 lines
778 B
Ruby

# frozen_string_literal: true
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