forked from fedi/mastodon
740f8a95a9
* 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
70 lines
1.5 KiB
Ruby
70 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
|