Conflicts: - `app/controllers/concerns/sign_in_token_authentication_concern.rb`: Conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/concerns/two_factor_authentication_concern.rb`: Conflict due to glitch-soc's theming system. Ported upstream changes.
		
			
				
	
	
		
			47 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class DirectoriesController < ApplicationController
 | |
|   layout 'public'
 | |
| 
 | |
|   before_action :authenticate_user!, if: :whitelist_mode?
 | |
|   before_action :require_enabled!
 | |
|   before_action :set_instance_presenter
 | |
|   before_action :set_tag, only: :show
 | |
|   before_action :set_accounts
 | |
|   before_action :set_pack
 | |
| 
 | |
|   skip_before_action :require_functional!, unless: :whitelist_mode?
 | |
| 
 | |
|   def index
 | |
|     render :index
 | |
|   end
 | |
| 
 | |
|   def show
 | |
|     render :index
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def set_pack
 | |
|     use_pack 'share'
 | |
|   end
 | |
| 
 | |
|   def require_enabled!
 | |
|     return not_found unless Setting.profile_directory
 | |
|   end
 | |
| 
 | |
|   def set_tag
 | |
|     @tag = Tag.discoverable.find_normalized!(params[:id])
 | |
|   end
 | |
| 
 | |
|   def set_accounts
 | |
|     @accounts = Account.local.discoverable.by_recent_status.page(params[:page]).per(20).tap do |query|
 | |
|       query.merge!(Account.tagged_with(@tag.id)) if @tag
 | |
|       query.merge!(Account.not_excluded_by_account(current_account)) if current_account
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def set_instance_presenter
 | |
|     @instance_presenter = InstancePresenter.new
 | |
|   end
 | |
| end
 |