Add validation coverage for CustomEmoji
shortcode value (#31906)
This commit is contained in:
parent
822e918a56
commit
abd2f5654a
2 changed files with 11 additions and 1 deletions
|
@ -25,6 +25,7 @@ class CustomEmoji < ApplicationRecord
|
|||
include Attachmentable
|
||||
|
||||
LIMIT = 256.kilobytes
|
||||
MINIMUM_SHORTCODE_SIZE = 2
|
||||
|
||||
SHORTCODE_RE_FRAGMENT = '[a-zA-Z0-9_]{2,}'
|
||||
|
||||
|
@ -44,7 +45,7 @@ class CustomEmoji < ApplicationRecord
|
|||
normalizes :domain, with: ->(domain) { domain.downcase }
|
||||
|
||||
validates_attachment :image, content_type: { content_type: IMAGE_MIME_TYPES }, presence: true, size: { less_than: LIMIT }
|
||||
validates :shortcode, uniqueness: { scope: :domain }, format: { with: SHORTCODE_ONLY_RE }, length: { minimum: 2 }
|
||||
validates :shortcode, uniqueness: { scope: :domain }, format: { with: SHORTCODE_ONLY_RE }, length: { minimum: MINIMUM_SHORTCODE_SIZE }
|
||||
|
||||
scope :local, -> { where(domain: nil) }
|
||||
scope :remote, -> { where.not(domain: nil) }
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue