|
|
@ -59,7 +59,9 @@ class Account < ApplicationRecord
|
|
|
|
include Attachmentable
|
|
|
|
include Attachmentable
|
|
|
|
include Paginable
|
|
|
|
include Paginable
|
|
|
|
|
|
|
|
|
|
|
|
MAX_NOTE_LENGTH = 500
|
|
|
|
MAX_DISPLAY_NAME_LENGTH = (ENV['MAX_DISPLAY_NAME_CHARS'] || 30).to_i
|
|
|
|
|
|
|
|
MAX_NOTE_LENGTH = (ENV['MAX_BIO_CHARS'] || 500).to_i
|
|
|
|
|
|
|
|
MAX_FIELDS = (ENV['MAX_PROFILE_FIELDS'] || 4).to_i
|
|
|
|
|
|
|
|
|
|
|
|
enum protocol: [:ostatus, :activitypub]
|
|
|
|
enum protocol: [:ostatus, :activitypub]
|
|
|
|
|
|
|
|
|
|
|
@ -76,9 +78,9 @@ class Account < ApplicationRecord
|
|
|
|
validates :username, format: { with: /\A[a-z0-9_]+\z/i }, length: { maximum: 30 }, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates :username, format: { with: /\A[a-z0-9_]+\z/i }, length: { maximum: 30 }, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates_with UniqueUsernameValidator, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates_with UniqueUsernameValidator, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates_with UnreservedUsernameValidator, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates_with UnreservedUsernameValidator, if: -> { local? && will_save_change_to_username? }
|
|
|
|
validates :display_name, length: { maximum: 30 }, if: -> { local? && will_save_change_to_display_name? }
|
|
|
|
validates :display_name, length: { maximum: MAX_DISPLAY_NAME_LENGTH }, if: -> { local? && will_save_change_to_display_name? }
|
|
|
|
validate :note_length_does_not_exceed_length_limit, if: -> { local? && will_save_change_to_note? }
|
|
|
|
validate :note_length_does_not_exceed_length_limit, if: -> { local? && will_save_change_to_note? }
|
|
|
|
validates :fields, length: { maximum: 4 }, if: -> { local? && will_save_change_to_fields? }
|
|
|
|
validates :fields, length: { maximum: MAX_FIELDS }, if: -> { local? && will_save_change_to_fields? }
|
|
|
|
|
|
|
|
|
|
|
|
# Timelines
|
|
|
|
# Timelines
|
|
|
|
has_many :stream_entries, inverse_of: :account, dependent: :destroy
|
|
|
|
has_many :stream_entries, inverse_of: :account, dependent: :destroy
|
|
|
@ -246,14 +248,12 @@ class Account < ApplicationRecord
|
|
|
|
self[:fields] = fields
|
|
|
|
self[:fields] = fields
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
DEFAULT_FIELDS_SIZE = 4
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def build_fields
|
|
|
|
def build_fields
|
|
|
|
return if fields.size >= DEFAULT_FIELDS_SIZE
|
|
|
|
return if fields.size >= MAX_FIELDS
|
|
|
|
|
|
|
|
|
|
|
|
tmp = self[:fields] || []
|
|
|
|
tmp = self[:fields] || []
|
|
|
|
|
|
|
|
|
|
|
|
(DEFAULT_FIELDS_SIZE - tmp.size).times do
|
|
|
|
(MAX_FIELDS - tmp.size).times do
|
|
|
|
tmp << { name: '', value: '' }
|
|
|
|
tmp << { name: '', value: '' }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|