Sha256: 8afebf7c7c522ab9ae010021d0f8a5859de182e453e41928728f66ded967b50b
Contents?: true
Size: 629 Bytes
Versions: 34
Compression:
Stored size: 629 Bytes
Contents
class PopulateChangesetsUserId < ActiveRecord::Migration def self.up committers = Changeset.connection.select_values("SELECT DISTINCT committer FROM #{Changeset.table_name}") committers.each do |committer| next if committer.blank? if committer.strip =~ /^([^<]+)(<(.*)>)?$/ username, email = $1.strip, $3 u = User.find_by_login(username) u ||= User.find_by_mail(email) unless email.blank? Changeset.where(["committer = ?", committer]).update_all("user_id = #{u.id}") unless u.nil? end end end def self.down Changeset.update_all('user_id = NULL') end end
Version data entries
34 entries across 34 versions & 1 rubygems