]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/user_role.rb
Merge remote-tracking branch 'upstream/pull/1659'
[rails.git] / app / models / user_role.rb
index efa540fec851de209b0a7d9d4fa74b63a60ab10d..adf569a03fe79a5d5827a5e33ddf4cdddb12e94d 100644 (file)
@@ -1,8 +1,29 @@
-class UserRole < ActiveRecord::Base
-
-  ALL_ROLES = ['administrator', 'moderator']
+# == Schema Information
+#
+# Table name: user_roles
+#
+#  id         :integer          not null, primary key
+#  user_id    :integer          not null
+#  role       :enum             not null
+#  created_at :datetime
+#  updated_at :datetime
+#  granter_id :integer          not null
+#
+# Indexes
+#
+#  user_roles_id_role_unique  (user_id,role) UNIQUE
+#
+# Foreign Keys
+#
+#  user_roles_granter_id_fkey  (granter_id => users.id)
+#  user_roles_user_id_fkey     (user_id => users.id)
+#
 
-  validates_inclusion_of :role, :in => ALL_ROLES
+class UserRole < ActiveRecord::Base
   belongs_to :user
+  belongs_to :granter, :class_name => "User"
+
+  ALL_ROLES = %w[administrator moderator].freeze
 
+  validates :role, :inclusion => ALL_ROLES, :uniqueness => { :scope => :user_id }
 end