-class UserBlock < ActiveRecord::Base
+# == Schema Information
+#
+# Table name: user_blocks
+#
+# id :integer not null, primary key
+# user_id :bigint(8) not null
+# creator_id :bigint(8) not null
+# reason :text not null
+# ends_at :datetime not null
+# needs_view :boolean default(FALSE), not null
+# revoker_id :bigint(8)
+# created_at :datetime
+# updated_at :datetime
+# reason_format :enum default("markdown"), not null
+#
+# Indexes
+#
+# index_user_blocks_on_user_id (user_id)
+#
+# Foreign Keys
+#
+# user_blocks_moderator_id_fkey (creator_id => users.id)
+# user_blocks_revoker_id_fkey (revoker_id => users.id)
+# user_blocks_user_id_fkey (user_id => users.id)
+#
+
+class UserBlock < ApplicationRecord
validate :moderator_permissions
+ validates :reason, :characters => true
belongs_to :user, :class_name => "User", :foreign_key => :user_id
belongs_to :creator, :class_name => "User", :foreign_key => :creator_id
belongs_to :revoker, :class_name => "User", :foreign_key => :revoker_id
- PERIODS = USER_BLOCK_PERIODS
+ PERIODS = Settings.user_block_periods
##
# scope to match active blocks
##
# return a renderable version of the reason text.
def reason
- RichText.new(read_attribute(:reason_format), read_attribute(:reason))
+ RichText.new(self[:reason_format], self[:reason])
end
##
needs_view || ends_at > Time.now.getutc
end
+ ##
+ # returns true if the block is a "zero hour" block
+ def zero_hour?
+ # if the times differ more than 1 minute we probably have more important issues
+ needs_view && (ends_at.to_i - updated_at.to_i) < 60
+ end
+
##
# revokes the block, allowing the user to use the API again. the argument
# is the user object who is revoking the ban.
def revoke!(revoker)
- update_attributes(
+ update(
:ends_at => Time.now.getutc,
:revoker_id => revoker.id,
:needs_view => false