2014-03-05 06:52:20 -06:00
|
|
|
class UserBadgesController < ApplicationController
|
|
|
|
def index
|
2014-04-22 04:40:47 -05:00
|
|
|
params.permit(:username).permit(:granted_before)
|
|
|
|
|
2014-04-16 09:56:11 -05:00
|
|
|
if params[:username]
|
|
|
|
user = fetch_user_from_params
|
|
|
|
user_badges = user.user_badges
|
|
|
|
else
|
|
|
|
badge = fetch_badge_from_params
|
2014-05-19 00:02:59 -05:00
|
|
|
user_badges = badge.user_badges.order('granted_at DESC').limit(96)
|
2014-04-22 04:40:47 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
if params[:granted_before]
|
|
|
|
user_badges = user_badges.where('granted_at < ?', Time.at(params[:granted_before].to_f))
|
2014-04-16 09:56:11 -05:00
|
|
|
end
|
2014-04-22 04:40:47 -05:00
|
|
|
|
2014-06-27 14:08:03 -05:00
|
|
|
user_badges = user_badges.includes(:user, :granted_by, badge: :badge_type, post: :topic)
|
2014-04-22 04:40:47 -05:00
|
|
|
|
2014-06-09 20:23:18 -05:00
|
|
|
if params[:grouped]
|
2014-07-14 02:40:01 -05:00
|
|
|
user_badges = user_badges.group(:badge_id)
|
|
|
|
.select(UserBadge.attribute_names.map {|x| "MAX(#{x}) as #{x}" }, 'COUNT(*) as count')
|
2014-05-21 02:22:42 -05:00
|
|
|
end
|
|
|
|
|
2014-04-16 09:56:11 -05:00
|
|
|
render_serialized(user_badges, UserBadgeSerializer, root: "user_badges")
|
2014-03-05 06:52:20 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
params.require(:username)
|
|
|
|
user = fetch_user_from_params
|
|
|
|
|
|
|
|
unless can_assign_badge_to_user?(user)
|
|
|
|
render json: failed_json, status: 403
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
badge = fetch_badge_from_params
|
|
|
|
user_badge = BadgeGranter.grant(badge, user, granted_by: current_user)
|
|
|
|
|
2014-03-19 04:16:16 -05:00
|
|
|
render_serialized(user_badge, UserBadgeSerializer, root: "user_badge")
|
2014-03-05 06:52:20 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
params.require(:id)
|
|
|
|
user_badge = UserBadge.find(params[:id])
|
|
|
|
|
|
|
|
unless can_assign_badge_to_user?(user_badge.user)
|
|
|
|
render json: failed_json, status: 403
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
2014-03-19 14:30:12 -05:00
|
|
|
BadgeGranter.revoke(user_badge, revoked_by: current_user)
|
2014-03-05 06:52:20 -06:00
|
|
|
render json: success_json
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
# Get the badge from either the badge name or id specified in the params.
|
|
|
|
def fetch_badge_from_params
|
|
|
|
badge = nil
|
|
|
|
|
|
|
|
params.permit(:badge_name)
|
|
|
|
if params[:badge_name].nil?
|
|
|
|
params.require(:badge_id)
|
2014-07-14 02:40:01 -05:00
|
|
|
badge = Badge.find_by(id: params[:badge_id], enabled: true)
|
2014-03-05 06:52:20 -06:00
|
|
|
else
|
2014-07-14 02:40:01 -05:00
|
|
|
badge = Badge.find_by(name: params[:badge_name], enabled: true)
|
2014-03-05 06:52:20 -06:00
|
|
|
end
|
|
|
|
raise Discourse::NotFound.new if badge.blank?
|
|
|
|
|
|
|
|
badge
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_assign_badge_to_user?(user)
|
|
|
|
master_api_call = current_user.nil? && is_api?
|
|
|
|
master_api_call or guardian.can_grant_badges?(user)
|
|
|
|
end
|
|
|
|
end
|