mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-19 00:21:40 +01:00
74c5b2bd08
Conflicts: - Gemfile - app/controllers/api/v1/search_controller.rb Conflict because we changed the number of default results to be configurable - app/lib/settings/scoped_settings.rb Addition of a new “noindex” site-wide setting, conflict due to our change of the two other site-wide settings (default flavour and skin instead of theme) - spec/controllers/application_controller_spec.rb Addition of a new “noindex” site-wide setting, conflict due to our change of the two other site-wide settings (default flavour and skin instead of theme)
131 lines
3.1 KiB
Ruby
131 lines
3.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Form::AdminSettings
|
|
include ActiveModel::Model
|
|
|
|
KEYS = %i(
|
|
site_contact_username
|
|
site_contact_email
|
|
site_title
|
|
site_short_description
|
|
site_description
|
|
site_extended_description
|
|
site_terms
|
|
registrations_mode
|
|
closed_registrations_message
|
|
open_deletion
|
|
timeline_preview
|
|
show_staff_badge
|
|
bootstrap_timeline_accounts
|
|
flavour
|
|
skin
|
|
min_invite_role
|
|
activity_api_enabled
|
|
peers_api_enabled
|
|
show_known_fediverse_at_about_page
|
|
preview_sensitive_media
|
|
custom_css
|
|
profile_directory
|
|
hide_followers_count
|
|
enable_keybase
|
|
flavour_and_skin
|
|
thumbnail
|
|
hero
|
|
mascot
|
|
show_reblogs_in_public_timelines
|
|
show_replies_in_public_timelines
|
|
spam_check_enabled
|
|
trends
|
|
show_domain_blocks
|
|
show_domain_blocks_rationale
|
|
noindex
|
|
).freeze
|
|
|
|
BOOLEAN_KEYS = %i(
|
|
open_deletion
|
|
timeline_preview
|
|
show_staff_badge
|
|
activity_api_enabled
|
|
peers_api_enabled
|
|
show_known_fediverse_at_about_page
|
|
preview_sensitive_media
|
|
profile_directory
|
|
hide_followers_count
|
|
enable_keybase
|
|
show_reblogs_in_public_timelines
|
|
show_replies_in_public_timelines
|
|
spam_check_enabled
|
|
trends
|
|
noindex
|
|
).freeze
|
|
|
|
UPLOAD_KEYS = %i(
|
|
thumbnail
|
|
hero
|
|
mascot
|
|
).freeze
|
|
|
|
PSEUDO_KEYS = %i(
|
|
flavour_and_skin
|
|
).freeze
|
|
|
|
attr_accessor(*KEYS)
|
|
|
|
validates :site_short_description, :site_description, html: { wrap_with: :p }
|
|
validates :site_extended_description, :site_terms, :closed_registrations_message, html: true
|
|
validates :registrations_mode, inclusion: { in: %w(open approved none) }
|
|
validates :min_invite_role, inclusion: { in: %w(disabled user moderator admin) }
|
|
validates :site_contact_email, :site_contact_username, presence: true
|
|
validates :site_contact_username, existing_username: true
|
|
validates :bootstrap_timeline_accounts, existing_username: { multiple: true }
|
|
validates :show_domain_blocks, inclusion: { in: %w(disabled users all) }
|
|
validates :show_domain_blocks_rationale, inclusion: { in: %w(disabled users all) }
|
|
|
|
def initialize(_attributes = {})
|
|
super
|
|
initialize_attributes
|
|
end
|
|
|
|
def save
|
|
return false unless valid?
|
|
|
|
KEYS.each do |key|
|
|
next if PSEUDO_KEYS.include?(key)
|
|
value = instance_variable_get("@#{key}")
|
|
|
|
if UPLOAD_KEYS.include?(key) && !value.nil?
|
|
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: typecast_value(key, value))
|
|
end
|
|
end
|
|
end
|
|
|
|
def flavour_and_skin
|
|
"#{Setting.flavour}/#{Setting.skin}"
|
|
end
|
|
|
|
def flavour_and_skin=(value)
|
|
@flavour, @skin = value.split('/', 2)
|
|
end
|
|
|
|
private
|
|
|
|
def initialize_attributes
|
|
KEYS.each do |key|
|
|
next if PSEUDO_KEYS.include?(key)
|
|
instance_variable_set("@#{key}", Setting.public_send(key)) if instance_variable_get("@#{key}").nil?
|
|
end
|
|
end
|
|
|
|
def typecast_value(key, value)
|
|
if BOOLEAN_KEYS.include?(key)
|
|
value == '1'
|
|
else
|
|
value
|
|
end
|
|
end
|
|
end
|