1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-25 14:52:20 +01:00
fab-manager/app/models/setting.rb

192 lines
8.1 KiB
Ruby
Raw Permalink Normal View History

# frozen_string_literal: true
# Setting is a configuration element of the platform. Only administrators are allowed to modify Settings
# For some settings, changing them will involve some callback actions (like rebuilding the stylesheets if the theme color Setting is changed).
# A full history of the previous values is kept in database with the date and the author of the change
2020-01-27 17:10:29 +01:00
# after_update callback is handled by SettingService
2020-03-25 10:16:47 +01:00
class Setting < ApplicationRecord
2018-12-17 16:02:02 +01:00
has_many :history_values
# The following list contains all the settings that can be customized from the Fab-manager's UI.
# A few of them that are system settings, that should not be updated manually (uuid, origin...).
2016-03-23 18:39:41 +01:00
validates :name, inclusion:
2018-12-17 16:02:02 +01:00
{ in: %w[about_title
2016-03-23 18:39:41 +01:00
about_body
about_contacts
2019-04-18 15:57:56 +02:00
privacy_draft
privacy_body
privacy_dpo
2016-03-23 18:39:41 +01:00
twitter_name
home_blogpost
machine_explications_alert
training_explications_alert
training_information_message
subscription_explications_alert
invoice_logo
invoice_reference
invoice_code-active
invoice_code-value
invoice_order-nb
invoice_VAT-active
invoice_VAT-rate
invoice_text
invoice_legals
booking_window_start
booking_window_end
booking_move_enable
booking_move_delay
booking_cancel_enable
booking_cancel_delay
main_color
secondary_color
fablab_name
name_genre
reminder_enable
reminder_delay
event_explications_alert
space_explications_alert
visibility_yearly
visibility_others
display_name_enable
machines_sort_by
accounting_journal_code
accounting_card_client_code
accounting_card_client_label
accounting_wallet_client_code
accounting_wallet_client_label
accounting_other_client_code
accounting_other_client_label
accounting_wallet_code
accounting_wallet_label
accounting_VAT_code
accounting_VAT_label
accounting_subscription_code
accounting_subscription_label
accounting_Machine_code
accounting_Machine_label
accounting_Training_code
accounting_Training_label
accounting_Event_code
accounting_Event_label
accounting_Space_code
accounting_Space_label
hub_last_version
2020-01-15 10:46:04 +01:00
hub_public_key
fab_analytics
link_name
2020-01-27 17:10:29 +01:00
home_content
home_css
origin
2020-05-12 15:04:06 +02:00
uuid
phone_required
tracking_id
book_overlapping_slots
slot_duration
2020-05-26 10:53:49 +02:00
events_in_calendar
spaces_module
plans_module
2020-05-27 12:29:45 +02:00
invoicing_module
facebook_app_id
2020-05-27 16:35:30 +02:00
twitter_analytics
recaptcha_site_key
recaptcha_secret_key
feature_tour_display
email_from
disqus_shortname
allowed_cad_extensions
allowed_cad_mime_types
openlab_app_id
2020-06-08 16:15:44 +02:00
openlab_app_secret
2020-06-08 17:42:59 +02:00
openlab_default
2020-06-09 13:09:31 +02:00
online_payment_module
stripe_public_key
stripe_secret_key
2020-06-15 10:58:15 +02:00
stripe_currency
invoice_prefix
2020-06-15 12:44:43 +02:00
confirmation_required
wallet_module
statistics_module
upcoming_events_shown
2021-03-03 15:28:56 +01:00
payment_schedule_prefix
2021-03-10 15:23:56 +01:00
trainings_module
2021-03-24 14:34:24 +01:00
address_required
2021-05-24 16:34:27 +02:00
accounting_Error_code
2021-05-25 14:06:30 +02:00
accounting_Error_label
2021-03-31 16:03:51 +02:00
payment_gateway
payzen_username
payzen_password
payzen_endpoint
payzen_public_key
payzen_hmac
2021-06-15 11:57:43 +02:00
payzen_currency
2021-06-25 17:24:34 +02:00
public_agenda_module
renew_pack_threshold
pack_only_for_subscription
overlapping_categories] }
# WARNING: when adding a new key, you may also want to add it in:
# - config/locales/en.yml#settings
# - app/frontend/src/javascript/models/setting.ts#SettingName
# - db/seeds.rb (to set the default value)
# - app/policies/setting_policy.rb#public_whitelist (if the setting can be read by anyone)
2020-06-09 13:09:31 +02:00
2018-12-17 16:02:02 +01:00
def value
last_value = history_values.order(HistoryValue.arel_table['created_at'].desc).limit(1).first
2018-12-17 16:02:02 +01:00
last_value&.value
end
2016-03-23 18:39:41 +01:00
def value_at(date)
val = history_values.order(HistoryValue.arel_table['created_at'].desc).where('created_at <= ?', date).limit(1).first
val&.value
end
def first_update
first_value = history_values.order(HistoryValue.arel_table['created_at'].asc).limit(1).first
first_value&.created_at
end
def first_value
first_value = history_values.order(HistoryValue.arel_table['created_at'].asc).limit(1).first
first_value&.value
end
def last_update
last_value = history_values.order(HistoryValue.arel_table['created_at'].desc).limit(1).first
last_value&.created_at
end
def previous_update
previous_value = history_values.order(HistoryValue.arel_table['created_at'].desc).limit(2).last
previous_value&.created_at
end
2018-12-17 16:02:02 +01:00
def value=(val)
admin = User.admins.first
save && history_values.create(invoicing_profile: admin.invoicing_profile, value: val)
2018-12-17 16:02:02 +01:00
end
2020-05-13 15:02:03 +02:00
##
# Return the value of the requested setting, if any.
2020-05-13 15:02:03 +02:00
# Usage: Setting.get('my_setting')
2021-01-04 18:12:44 +01:00
# @return {String|Boolean}
2020-05-13 15:02:03 +02:00
##
def self.get(name)
res = find_by(name: name)&.value
# handle boolean values
return true if res == 'true'
return false if res == 'false'
res
2020-05-13 15:02:03 +02:00
end
##
# Create or update the provided setting with the given value
# Usage: Setting.set('my_setting', true)
# Optionally (but recommended when possible), the user updating the value can be provided as the third parameter
# Eg.: Setting.set('my_setting', true, User.find_by(slug: 'admin'))
##
def self.set(name, value, user = User.admins.first)
setting = find_or_initialize_by(name: name)
setting.save && setting.history_values.create(invoicing_profile: user.invoicing_profile, value: value.to_s)
end
2016-03-23 18:39:41 +01:00
end