From 170f0bdcdef9c9b226abfe0a50d6687c65e8d613 Mon Sep 17 00:00:00 2001 From: GitLab Bot Date: Mon, 21 Oct 2019 21:06:14 +0000 Subject: Add latest changes from gitlab-org/gitlab@master --- .../same_project_association_validator.rb | 21 +++++++++++++++++++++ app/validators/zoom_url_validator.rb | 13 +++++++++++++ 2 files changed, 34 insertions(+) create mode 100644 app/validators/same_project_association_validator.rb create mode 100644 app/validators/zoom_url_validator.rb (limited to 'app/validators') diff --git a/app/validators/same_project_association_validator.rb b/app/validators/same_project_association_validator.rb new file mode 100644 index 00000000000..2af2a21fa9a --- /dev/null +++ b/app/validators/same_project_association_validator.rb @@ -0,0 +1,21 @@ +# frozen_string_literal: true + +# SameProjectAssociationValidator +# +# Custom validator to validate that the same project associated with +# the record is also associated with the value +# +# Example: +# class ZoomMeeting < ApplicationRecord +# belongs_to :project, optional: false +# belongs_to :issue, optional: false + +# validates :issue, same_project_association: true +# end +class SameProjectAssociationValidator < ActiveModel::EachValidator + def validate_each(record, attribute, value) + return if record.project == value&.project + + record.errors[attribute] << 'must associate the same project' + end +end diff --git a/app/validators/zoom_url_validator.rb b/app/validators/zoom_url_validator.rb new file mode 100644 index 00000000000..dc4ca6b9501 --- /dev/null +++ b/app/validators/zoom_url_validator.rb @@ -0,0 +1,13 @@ +# frozen_string_literal: true + +# ZoomUrlValidator +# +# Custom validator for zoom urls +# +class ZoomUrlValidator < ActiveModel::EachValidator + def validate_each(record, attribute, value) + return if Gitlab::ZoomLinkExtractor.new(value).links.size == 1 + + record.errors.add(:url, 'must contain one valid Zoom URL') + end +end -- cgit v1.2.3