* Add consumable invites * Add UI for generating invite codes * Add tests * Display max uses and expiration in invites table, delete invite * Remove unused column and redundant validator - Default follows not used, probably bad idea - InviteCodeValidator is redundant because RegistrationsController checks invite code validity * Add admin setting to disable invites * Add admin UI for invites, configurable role for invite creation - Admin UI that lists everyone's invites, always available - Admin setting min_invite_role to control who can invite people - Non-admin invite UI only visible if users are allowed to * Do not remove invites from database, expire them instantly
		
			
				
	
	
		
			69 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
module Admin
 | 
						|
  class SettingsController < BaseController
 | 
						|
    ADMIN_SETTINGS = %w(
 | 
						|
      site_contact_username
 | 
						|
      site_contact_email
 | 
						|
      site_title
 | 
						|
      site_description
 | 
						|
      site_extended_description
 | 
						|
      site_terms
 | 
						|
      open_registrations
 | 
						|
      closed_registrations_message
 | 
						|
      open_deletion
 | 
						|
      timeline_preview
 | 
						|
      show_staff_badge
 | 
						|
      bootstrap_timeline_accounts
 | 
						|
      thumbnail
 | 
						|
      min_invite_role
 | 
						|
    ).freeze
 | 
						|
 | 
						|
    BOOLEAN_SETTINGS = %w(
 | 
						|
      open_registrations
 | 
						|
      open_deletion
 | 
						|
      timeline_preview
 | 
						|
      show_staff_badge
 | 
						|
    ).freeze
 | 
						|
 | 
						|
    UPLOAD_SETTINGS = %w(
 | 
						|
      thumbnail
 | 
						|
    ).freeze
 | 
						|
 | 
						|
    def edit
 | 
						|
      authorize :settings, :show?
 | 
						|
      @admin_settings = Form::AdminSettings.new
 | 
						|
    end
 | 
						|
 | 
						|
    def update
 | 
						|
      authorize :settings, :update?
 | 
						|
 | 
						|
      settings_params.each do |key, value|
 | 
						|
        if UPLOAD_SETTINGS.include?(key)
 | 
						|
          upload = SiteUpload.where(var: key).first_or_initialize(var: key)
 | 
						|
          upload.update(file: value)
 | 
						|
        else
 | 
						|
          setting = Setting.where(var: key).first_or_initialize(var: key)
 | 
						|
          setting.update(value: value_for_update(key, value))
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      flash[:notice] = I18n.t('generic.changes_saved_msg')
 | 
						|
      redirect_to edit_admin_settings_path
 | 
						|
    end
 | 
						|
 | 
						|
    private
 | 
						|
 | 
						|
    def settings_params
 | 
						|
      params.require(:form_admin_settings).permit(ADMIN_SETTINGS)
 | 
						|
    end
 | 
						|
 | 
						|
    def value_for_update(key, value)
 | 
						|
      if BOOLEAN_SETTINGS.include?(key)
 | 
						|
        value == '1'
 | 
						|
      else
 | 
						|
        value
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |