summaryrefslogtreecommitdiff
path: root/app/models/releases
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-03-24 12:09:42 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-03-24 12:09:42 +0000
commit729e3765d5feb762df1ccfbc228a8dd4662aa3f9 (patch)
treef326420fc64999c6bcc28816ed54f0972fb46459 /app/models/releases
parent6f7881ee9dcec34141a8f34fc814b56b366d2b48 (diff)
downloadgitlab-ce-729e3765d5feb762df1ccfbc228a8dd4662aa3f9.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/models/releases')
-rw-r--r--app/models/releases/evidence.rb44
1 files changed, 44 insertions, 0 deletions
diff --git a/app/models/releases/evidence.rb b/app/models/releases/evidence.rb
new file mode 100644
index 00000000000..1aac7e33e41
--- /dev/null
+++ b/app/models/releases/evidence.rb
@@ -0,0 +1,44 @@
+# frozen_string_literal: true
+
+class Releases::Evidence < ApplicationRecord
+ include ShaAttribute
+ include Presentable
+
+ belongs_to :release, inverse_of: :evidences
+
+ before_validation :generate_summary_and_sha
+
+ default_scope { order(created_at: :asc) }
+
+ sha_attribute :summary_sha
+ alias_attribute :collected_at, :created_at
+
+ def milestones
+ @milestones ||= release.milestones.includes(:issues)
+ end
+
+ ##
+ # Return `summary` without sensitive information.
+ #
+ # Removing issues from summary in order to prevent leaking confidential ones.
+ # See more https://gitlab.com/gitlab-org/gitlab/issues/121930
+ def summary
+ safe_summary = read_attribute(:summary)
+
+ safe_summary.dig('release', 'milestones')&.each do |milestone|
+ milestone.delete('issues')
+ end
+
+ safe_summary
+ end
+
+ private
+
+ def generate_summary_and_sha
+ summary = Evidences::EvidenceSerializer.new.represent(self) # rubocop: disable CodeReuse/Serializer
+ return unless summary
+
+ self.summary = summary
+ self.summary_sha = Gitlab::CryptoHelper.sha256(summary)
+ end
+end