Merge branch 'master' into glitch-soc/merge-upstream
Conflicts: - `app/controllers/statuses_controller.rb`: Minor conflict due to theming system
This commit is contained in:
		
							
								
								
									
										29
									
								
								app/controllers/api/v1/announcements/reactions_controller.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								app/controllers/api/v1/announcements/reactions_controller.rb
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
# frozen_string_literal: true
 | 
			
		||||
 | 
			
		||||
class Api::V1::Announcements::ReactionsController < Api::BaseController
 | 
			
		||||
  before_action -> { doorkeeper_authorize! :write, :'write:favourites' }
 | 
			
		||||
  before_action :require_user!
 | 
			
		||||
 | 
			
		||||
  before_action :set_announcement
 | 
			
		||||
  before_action :set_reaction, except: :update
 | 
			
		||||
 | 
			
		||||
  def update
 | 
			
		||||
    @announcement.announcement_reactions.create!(account: current_account, name: params[:id])
 | 
			
		||||
    render_empty
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def destroy
 | 
			
		||||
    @reaction.destroy!
 | 
			
		||||
    render_empty
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  private
 | 
			
		||||
 | 
			
		||||
  def set_reaction
 | 
			
		||||
    @reaction = @announcement.announcement_reactions.where(account: current_account).find_by!(name: params[:id])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def set_announcement
 | 
			
		||||
    @announcement = Announcement.published.find(params[:announcement_id])
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
							
								
								
									
										33
									
								
								app/controllers/api/v1/announcements_controller.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								app/controllers/api/v1/announcements_controller.rb
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,33 @@
 | 
			
		||||
# frozen_string_literal: true
 | 
			
		||||
 | 
			
		||||
class Api::V1::AnnouncementsController < Api::BaseController
 | 
			
		||||
  before_action -> { doorkeeper_authorize! :write, :'write:accounts' }, only: :dismiss
 | 
			
		||||
  before_action :require_user!
 | 
			
		||||
  before_action :set_announcements, only: :index
 | 
			
		||||
  before_action :set_announcement, except: :index
 | 
			
		||||
 | 
			
		||||
  def index
 | 
			
		||||
    render json: @announcements, each_serializer: REST::AnnouncementSerializer
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def dismiss
 | 
			
		||||
    AnnouncementMute.create!(account: current_account, announcement: @announcement)
 | 
			
		||||
    render_empty
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  private
 | 
			
		||||
 | 
			
		||||
  def set_announcements
 | 
			
		||||
    @announcements = begin
 | 
			
		||||
      scope = Announcement.published
 | 
			
		||||
 | 
			
		||||
      scope.merge!(Announcement.without_muted(current_account)) unless truthy_param?(:with_dismissed)
 | 
			
		||||
 | 
			
		||||
      scope.chronological
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def set_announcement
 | 
			
		||||
    @announcement = Announcement.published.find(params[:id])
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
		Reference in New Issue
	
	Block a user