Files
danbooru/app/controllers/artists_controller.rb
evazion 4fd028a5ce artists: fix ban/unban actions.
Fix the ban! and unban! methods to:

* Lock the artist while it is being banned or unbanned.
* Perform the edits as a mass update, so that the posts are updated in parallel.
* Edit the artist as the banner rather than as the current user.
* Soft delete the banned_artist implication when an artist is unbanned instead of hard deleting it.
* Ignore the banned_artist implication if it's deleted.
2022-11-20 19:25:20 -06:00

97 lines
2.7 KiB
Ruby

# frozen_string_literal: true
class ArtistsController < ApplicationController
respond_to :html, :xml, :json, :js
def new
@artist = authorize Artist.new_with_defaults(permitted_attributes(Artist))
respond_with(@artist)
end
def edit
@artist = authorize Artist.find(params[:id])
respond_with(@artist)
end
def banned
redirect_to artists_path(search: { is_banned: "true", order: "updated_at" }, format: request.format.symbol)
end
def ban
@artist = authorize Artist.find(params[:id])
@artist.ban!(CurrentUser.user)
redirect_to(artist_path(@artist), :notice => "Artist was banned")
end
def unban
@artist = authorize Artist.find(params[:id])
@artist.unban!(CurrentUser.user)
redirect_to(artist_path(@artist), :notice => "Artist was unbanned")
end
def index
# XXX
params[:search][:name] = params.delete(:name) if params[:name]
@artists = authorize Artist.visible(CurrentUser.user).paginated_search(params)
@artists = @artists.includes(:urls, :tag) if request.format.html?
respond_with(@artists)
end
def show
@artist = authorize Artist.find(params[:id])
raise PageRemovedError if request.format.html? && @artist.is_banned? && !policy(@artist).can_view_banned?
respond_with(@artist)
end
def create
@artist = authorize Artist.new(permitted_attributes(Artist))
@artist.save
flash[:notice] = [*@artist.errors.full_messages, *@artist.warnings.full_messages].join(".\n \n") if @artist.warnings.any? || @artist.errors.any?
respond_with(@artist)
end
def update
@artist = authorize Artist.find(params[:id])
@artist.update(permitted_attributes(@artist))
flash[:notice] = [*@artist.errors.full_messages, *@artist.warnings.full_messages].join(".\n \n") if @artist.warnings.any? || @artist.errors.any?
respond_with(@artist)
end
def destroy
@artist = authorize Artist.find(params[:id])
@artist.update(is_deleted: true)
redirect_to(artist_path(@artist), :notice => "Artist deleted")
end
def revert
@artist = authorize Artist.find(params[:id])
@version = @artist.versions.find(params[:version_id])
@artist.revert_to!(@version)
respond_with(@artist)
end
def show_or_new
@artist = Artist.find_by_name(params[:name])
if params[:name].blank?
redirect_to new_artist_path(permitted_attributes(Artist))
elsif @artist.present?
redirect_to artist_path(@artist)
else
@artist = Artist.new(name: params[:name])
respond_with(@artist)
end
end
private
def item_matches_params(artist)
if params[:search][:any_name_or_url_matches]
artist.name == Artist.normalize_name(params[:search][:any_name_or_url_matches])
else
true
end
end
end