debian-mirror-gitlab/app/models/merge_request_diff_commit.rb

43 lines
1.3 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2019-07-07 11:18:12 +05:30
class MergeRequestDiffCommit < ApplicationRecord
2017-09-10 17:25:29 +05:30
include ShaAttribute
belongs_to :merge_request_diff
sha_attribute :sha
alias_attribute :id, :sha
def self.create_bulk(merge_request_diff_id, commits)
sha_attribute = Gitlab::Database::ShaAttribute.new
rows = commits.map.with_index do |commit, index|
# See #parent_ids.
commit_hash = commit.to_hash.except(:parent_ids)
sha = commit_hash.delete(:id)
commit_hash.merge(
merge_request_diff_id: merge_request_diff_id,
relative_order: index,
2018-05-09 12:01:36 +05:30
sha: sha_attribute.serialize(sha), # rubocop:disable Cop/ActiveRecordSerialize
2018-03-17 18:26:18 +05:30
authored_date: Gitlab::Database.sanitize_timestamp(commit_hash[:authored_date]),
committed_date: Gitlab::Database.sanitize_timestamp(commit_hash[:committed_date])
2017-09-10 17:25:29 +05:30
)
end
Gitlab::Database.bulk_insert(self.table_name, rows)
end
def to_hash
Gitlab::Git::Commit::SERIALIZE_KEYS.each_with_object({}) do |key, hash|
2018-03-17 18:26:18 +05:30
hash[key] = public_send(key) # rubocop:disable GitlabSecurity/PublicSend
2017-09-10 17:25:29 +05:30
end
end
# We don't save these, because they would need a table or a serialised
# field. They aren't used anywhere, so just pretend the commit has no parents.
def parent_ids
[]
end
end