|
- module Dcodes
- DCODES = %W(1 2 3 4 5 6 7 8 9 a b c f e f g h i j k l m n o p q r s t u v w x y z A B C D E F G H I J K L M N O P Q R S T U V W X Y Z)
-
- extend ActiveSupport::Concern
-
- def generate_dcode(field, num, pre='')
- code = DCODES.sample(num).join
- while self.class.exists?("#{field}": pre+code) do
- code = DCODES.sample(num).join
- end
- code
- end
-
- def init_project_invite_code
- while Project.where(invite_code: nil).size > 0 do
- projects = Project.where(invite_code: nil).limit(1000)
- set_sql = ""
- projects.each do |p|
- set_sql += "WHEN #{p.id} THEN '#{DCODES.sample(6).join}' "
- end
- sql = "UPDATE projects SET invite_code = CASE id "+ set_sql+ "END WHERE id IN(#{projects.ids.join(",")})"
- Project.connection.execute(sql)
- end
- repeat_codes = Project.group(:invite_code).count.select{|k,v| v>1}
- Project.where(invite_code: repeat_code.keys).update_all(invite_code: nil)
- end
-
- end
|