pundit: convert user feedbacks to pundit.
Allow users to delete feedbacks they've given to other users, not just mods.
This commit is contained in:
@@ -1,53 +1,37 @@
|
||||
class UserFeedbacksController < ApplicationController
|
||||
before_action :gold_only, :only => [:new, :edit, :create, :update]
|
||||
respond_to :html, :xml, :json, :js
|
||||
|
||||
def new
|
||||
@user_feedback = UserFeedback.new(user_feedback_params(:create))
|
||||
@user_feedback = authorize UserFeedback.new(permitted_attributes(UserFeedback))
|
||||
respond_with(@user_feedback)
|
||||
end
|
||||
|
||||
def edit
|
||||
@user_feedback = UserFeedback.visible(CurrentUser.user).find(params[:id])
|
||||
check_privilege(@user_feedback)
|
||||
@user_feedback = authorize UserFeedback.find(params[:id])
|
||||
respond_with(@user_feedback)
|
||||
end
|
||||
|
||||
def show
|
||||
@user_feedback = UserFeedback.visible(CurrentUser.user).find(params[:id])
|
||||
@user_feedback = authorize UserFeedback.find(params[:id])
|
||||
respond_with(@user_feedback)
|
||||
end
|
||||
|
||||
def index
|
||||
@user_feedbacks = UserFeedback.visible(CurrentUser.user).paginated_search(params, count_pages: true)
|
||||
@user_feedbacks = authorize UserFeedback.visible(CurrentUser.user).paginated_search(params, count_pages: true)
|
||||
@user_feedbacks = @user_feedbacks.includes(:user, :creator) if request.format.html?
|
||||
|
||||
respond_with(@user_feedbacks)
|
||||
end
|
||||
|
||||
def create
|
||||
@user_feedback = UserFeedback.create(user_feedback_params(:create).merge(creator: CurrentUser.user))
|
||||
@user_feedback = authorize UserFeedback.new(creator: CurrentUser.user, **permitted_attributes(UserFeedback))
|
||||
@user_feedback.save
|
||||
respond_with(@user_feedback)
|
||||
end
|
||||
|
||||
def update
|
||||
@user_feedback = UserFeedback.visible(CurrentUser.user).find(params[:id])
|
||||
check_privilege(@user_feedback)
|
||||
@user_feedback.update(user_feedback_params(:update, @user_feedback))
|
||||
@user_feedback = authorize UserFeedback.find(params[:id])
|
||||
@user_feedback.update(permitted_attributes(@user_feedback))
|
||||
respond_with(@user_feedback)
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def check_privilege(user_feedback)
|
||||
raise User::PrivilegeError unless user_feedback.editable_by?(CurrentUser.user)
|
||||
end
|
||||
|
||||
def user_feedback_params(context, user_feedback = nil)
|
||||
permitted_params = %i[body category]
|
||||
permitted_params += %i[user_id user_name] if context == :create
|
||||
permitted_params += %i[is_deleted] if context == :update && user_feedback.deletable_by?(CurrentUser.user)
|
||||
|
||||
params.fetch(:user_feedback, {}).permit(permitted_params)
|
||||
end
|
||||
end
|
||||
|
||||
@@ -6,8 +6,6 @@ class UserFeedback < ApplicationRecord
|
||||
attr_accessor :disable_dmail_notification
|
||||
validates_presence_of :body, :category
|
||||
validates_inclusion_of :category, :in => %w(positive negative neutral)
|
||||
validate :creator_is_gold
|
||||
validate :user_is_not_creator
|
||||
after_create :create_dmail, unless: :disable_dmail_notification
|
||||
after_update(:if => ->(rec) { CurrentUser.id != rec.creator_id}) do |rec|
|
||||
ModAction.log(%{#{CurrentUser.name} updated user feedback for "#{rec.user.name}":/users/#{rec.user_id}}, :user_feedback_update)
|
||||
@@ -67,26 +65,6 @@ class UserFeedback < ApplicationRecord
|
||||
Dmail.create_automated(:to_id => user_id, :title => "Your user record has been updated", :body => body)
|
||||
end
|
||||
|
||||
def creator_is_gold
|
||||
if !creator.is_gold?
|
||||
errors[:creator] << "must be gold"
|
||||
end
|
||||
end
|
||||
|
||||
def user_is_not_creator
|
||||
if user_id == creator_id
|
||||
errors[:creator] << "cannot submit feedback for yourself"
|
||||
end
|
||||
end
|
||||
|
||||
def deletable_by?(deleter)
|
||||
deleter.is_moderator? && deleter != user
|
||||
end
|
||||
|
||||
def editable_by?(editor)
|
||||
(editor.is_moderator? && editor != user) || (creator == editor && !is_deleted?)
|
||||
end
|
||||
|
||||
def self.available_includes
|
||||
[:creator, :user]
|
||||
end
|
||||
|
||||
25
app/policies/user_feedback_policy.rb
Normal file
25
app/policies/user_feedback_policy.rb
Normal file
@@ -0,0 +1,25 @@
|
||||
class UserFeedbackPolicy < ApplicationPolicy
|
||||
def create?
|
||||
unbanned? && user.is_gold? && record.user_id != user.id
|
||||
end
|
||||
|
||||
def update?
|
||||
create? && (user.is_moderator? || (record.creator_id == user.id && !record.is_deleted?))
|
||||
end
|
||||
|
||||
def show?
|
||||
!record.is_deleted? || can_view_deleted?
|
||||
end
|
||||
|
||||
def can_view_deleted?
|
||||
user.is_moderator?
|
||||
end
|
||||
|
||||
def permitted_attributes_for_create
|
||||
[:body, :category, :user_id, :user_name]
|
||||
end
|
||||
|
||||
def permitted_attributes_for_update
|
||||
[:body, :category, :is_deleted]
|
||||
end
|
||||
end
|
||||
@@ -1,6 +1,6 @@
|
||||
<% content_for(:secondary_links) do %>
|
||||
<% if CurrentUser.is_gold? %>
|
||||
<% if @user_feedback %>
|
||||
<% if policy(UserFeedback.new).create? %>
|
||||
<% if @user_feedback.present? && policy(@user_feedback).create? %>
|
||||
<%= subnav_link_to "New", new_user_feedback_path(:user_feedback => {:user_id => @user_feedback.user_id}) %>
|
||||
<% elsif params[:search] && params[:search][:user_id] %>
|
||||
<%= subnav_link_to "New", new_user_feedback_path(:user_feedback => {:user_id => params[:search][:user_id]}) %>
|
||||
|
||||
@@ -10,9 +10,7 @@
|
||||
<%= edit_form_for(@user_feedback) do |f| %>
|
||||
<%= f.input :category, :collection => ["positive", "neutral", "negative"], :include_blank => false %>
|
||||
<%= dtext_field "user_feedback", "body" %>
|
||||
<% if @user_feedback.deletable_by?(CurrentUser.user) %>
|
||||
<%= f.input :is_deleted, label: "Deleted" %>
|
||||
<% end %>
|
||||
<%= f.input :is_deleted, label: "Deleted" %>
|
||||
<%= f.button :submit, "Submit" %>
|
||||
<%= dtext_preview_button "user_feedback", "body" %>
|
||||
<% end %>
|
||||
|
||||
@@ -7,7 +7,7 @@
|
||||
<%= f.input :creator_name, input_html: { value: params.dig(:search, :creator_name), "data-autocomplete": "user" } %>
|
||||
<%= f.input :body_matches, label: "Message", input_html: { value: params.dig(:search, :body_matches) } %>
|
||||
<%= f.input :category, collection: %w[positive negative neutral], include_blank: true, selected: params.dig(:search, :category) %>
|
||||
<% if CurrentUser.is_moderator? %>
|
||||
<% if policy(UserFeedback).can_view_deleted? %>
|
||||
<%= f.input :is_deleted, label: "Deleted", collection: %w[Yes No], include_blank: true, selected: params.dig(:search, :is_deleted) %>
|
||||
<% end %>
|
||||
<%= f.submit "Search" %>
|
||||
@@ -24,9 +24,9 @@
|
||||
</div>
|
||||
<%= render "application/update_notice", record: feedback, interval: 0.minutes %>
|
||||
<% end %>
|
||||
<% if CurrentUser.is_moderator? %>
|
||||
<% if policy(UserFeedback).can_view_deleted? %>
|
||||
<% t.column "Status" do |feedback| %>
|
||||
<%= "deleted" if feedback.is_deleted? %>
|
||||
<%= "Deleted" if feedback.is_deleted? %>
|
||||
<% end %>
|
||||
<% end %>
|
||||
<% t.column "Category" do |feedback| %>
|
||||
@@ -38,12 +38,12 @@
|
||||
<div><%= time_ago_in_words_tagged(feedback.created_at) %></div>
|
||||
<% end %>
|
||||
<% t.column column: "control" do |feedback| %>
|
||||
<% if feedback.editable_by?(CurrentUser.user) %>
|
||||
<%= link_to "edit", edit_user_feedback_path(feedback) %>
|
||||
<% if feedback.deletable_by?(CurrentUser.user) && !feedback.is_deleted? %>
|
||||
| <%= link_to "delete", user_feedback_path(feedback), method: :put, remote: true, "data-params": "user_feedback[is_deleted]=true", "data-confirm": "Are you sure you want to delete this user feedback?" %>
|
||||
<% elsif feedback.deletable_by?(CurrentUser.user) && feedback.is_deleted? %>
|
||||
| <%= link_to "undelete", user_feedback_path(feedback), method: :put, remote: true, "data-params": "user_feedback[is_deleted]=false" %>
|
||||
<% if policy(feedback).update? %>
|
||||
<%= link_to "Edit", edit_user_feedback_path(feedback) %>
|
||||
<% if feedback.is_deleted? %>
|
||||
| <%= link_to "Undelete", user_feedback_path(feedback), method: :put, remote: true, "data-params": "user_feedback[is_deleted]=false" %>
|
||||
<% else %>
|
||||
| <%= link_to "Delete", user_feedback_path(feedback), method: :put, remote: true, "data-params": "user_feedback[is_deleted]=true", "data-confirm": "Are you sure you want to delete this user feedback?" %>
|
||||
<% end %>
|
||||
<% end %>
|
||||
<% end %>
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<% if @user_feedback.editable_by?(CurrentUser.user) %>
|
||||
<% if policy(@user_feedback).update? %>
|
||||
<p><%= link_to "Edit", edit_user_feedback_path(@user_feedback) %></p>
|
||||
<% end %>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user