diff options
| author | Robert Speicher <rspeicher@gmail.com> | 2015-12-01 19:30:01 -0500 | 
|---|---|---|
| committer | Robert Speicher <rspeicher@gmail.com> | 2015-12-07 16:57:26 -0500 | 
| commit | ad6a771dc680b52e4b46c73f20bc39340d08bf32 (patch) | |
| tree | e0ad892d95a6251ede175a669ec682ec4dd771d5 | |
| parent | 96e51a0304022664c06a025f4a54c4a41c25edd2 (diff) | |
| download | gitlab-ce-ad6a771dc680b52e4b46c73f20bc39340d08bf32.tar.gz | |
Add custom LineCodeValidator
| -rw-r--r-- | app/models/note.rb | 2 | ||||
| -rw-r--r-- | app/models/sent_notification.rb | 2 | ||||
| -rw-r--r-- | app/validators/line_code_validator.rb | 12 | 
3 files changed, 14 insertions, 2 deletions
| diff --git a/app/models/note.rb b/app/models/note.rb index 239a0f77f8e..8d433c57ceb 100644 --- a/app/models/note.rb +++ b/app/models/note.rb @@ -44,7 +44,7 @@ class Note < ActiveRecord::Base    validates :note, :project, presence: true    validates :note, uniqueness: { scope: [:author, :noteable_type, :noteable_id] }, if: ->(n) { n.is_award }    validates :note, inclusion: { in: Emoji.emojis_names }, if: ->(n) { n.is_award } -  validates :line_code, format: { with: /\A[a-z0-9]+_\d+_\d+\Z/ }, allow_blank: true +  validates :line_code, line_code: true, allow_blank: true    # Attachments are deprecated and are handled by Markdown uploader    validates :attachment, file_size: { maximum: :max_attachment_size } diff --git a/app/models/sent_notification.rb b/app/models/sent_notification.rb index d8fe65b06f6..f36eda1531b 100644 --- a/app/models/sent_notification.rb +++ b/app/models/sent_notification.rb @@ -21,7 +21,7 @@ class SentNotification < ActiveRecord::Base    validates :reply_key, uniqueness: true    validates :noteable_id, presence: true, unless: :for_commit?    validates :commit_id, presence: true, if: :for_commit? -  validates :line_code, format: { with: /\A[a-z0-9]+_\d+_\d+\Z/ }, allow_blank: true +  validates :line_code, line_code: true, allow_blank: true    class << self      def reply_key diff --git a/app/validators/line_code_validator.rb b/app/validators/line_code_validator.rb new file mode 100644 index 00000000000..ed29e5aeb67 --- /dev/null +++ b/app/validators/line_code_validator.rb @@ -0,0 +1,12 @@ +# LineCodeValidator +# +# Custom validator for GitLab line codes. +class LineCodeValidator < ActiveModel::EachValidator +  PATTERN = /\A[a-z0-9]+_\d+_\d+\z/.freeze + +  def validate_each(record, attribute, value) +    unless value =~ PATTERN +      record.errors.add(attribute, "must be a valid line code") +    end +  end +end | 
