pundit: convert ip bans to pundit.

This commit is contained in:
evazion
2020-03-18 01:36:54 -05:00
parent 9242bf522b
commit 92aeb8728f
4 changed files with 29 additions and 21 deletions

View File

@@ -1,35 +1,32 @@
class IpBansController < ApplicationController
respond_to :html, :xml, :json, :js
before_action :moderator_only
def new
@ip_ban = IpBan.new
@ip_ban = authorize IpBan.new(permitted_attributes(IpBan))
respond_with(@ip_ban)
end
def create
@ip_ban = CurrentUser.ip_bans.create(ip_ban_params)
@ip_ban = authorize IpBan.new(creator: CurrentUser.user, **permitted_attributes(IpBan))
@ip_ban.save
respond_with(@ip_ban, :location => ip_bans_path)
end
def index
@ip_bans = IpBan.paginated_search(params, count_pages: true)
@ip_bans = authorize IpBan.paginated_search(params, count_pages: true)
@ip_bans = @ip_bans.includes(:creator) if request.format.html?
respond_with(@ip_bans)
end
def destroy
@ip_ban = IpBan.find(params[:id])
@ip_ban = authorize IpBan.find(params[:id])
@ip_ban.destroy
respond_with(@ip_ban)
end
private
def ip_ban_params
params.fetch(:ip_ban, {}).permit(%i[ip_addr reason])
end
def search_params
params.fetch(:search, {}).permit(%i[ip_addr order])
end

View File

@@ -0,0 +1,17 @@
class IpBanPolicy < ApplicationPolicy
def create?
user.is_moderator?
end
def index?
user.is_moderator?
end
def destroy?
user.is_moderator?
end
def permitted_attributes
[:ip_addr, :reason]
end
end

View File

@@ -157,6 +157,9 @@
<% if CurrentUser.is_moderator? %>
<li><%= link_to("Moderation Reports", moderation_reports_path) %></li>
<li><%= link_to("IP Addresses", ip_addresses_path) %></li>
<% end %>
<% if policy(IpBan).index? %>
<li><%= link_to("IP Bans", ip_bans_path) %></li>
<% end %>

View File

@@ -4,6 +4,7 @@ class IpBansControllerTest < ActionDispatch::IntegrationTest
context "The ip bans controller" do
setup do
@admin = create(:admin_user)
@ip_ban = create(:ip_ban)
end
context "new action" do
@@ -17,17 +18,12 @@ class IpBansControllerTest < ActionDispatch::IntegrationTest
should "create a new ip ban" do
assert_difference("IpBan.count", 1) do
post_auth ip_bans_path, @admin, params: {:ip_ban => {:ip_addr => "1.2.3.4", :reason => "xyz"}}
assert_response :redirect
end
end
end
context "index action" do
setup do
as(@admin) do
create(:ip_ban)
end
end
should "render" do
get_auth ip_bans_path, @admin
assert_response :success
@@ -42,15 +38,10 @@ class IpBansControllerTest < ActionDispatch::IntegrationTest
end
context "destroy action" do
setup do
as(@admin) do
@ip_ban = create(:ip_ban)
end
end
should "destroy an ip ban" do
assert_difference("IpBan.count", -1) do
delete_auth ip_ban_path(@ip_ban), @admin, params: {:format => "js"}
assert_response :success
end
end
end