52 lines
2 KiB
Ruby
52 lines
2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module GithubImport
|
|
module Representation
|
|
class ProtectedBranch
|
|
include ToHash
|
|
include ExposeAttribute
|
|
|
|
attr_reader :attributes
|
|
|
|
expose_attribute :id, :allow_force_pushes, :required_conversation_resolution, :required_signatures,
|
|
:required_pull_request_reviews, :require_code_owner_reviews
|
|
|
|
# Builds a Branch Protection info from a GitHub API response.
|
|
# Resource structure details:
|
|
# https://docs.github.com/en/rest/branches/branch-protection#get-branch-protection
|
|
# branch_protection - An instance of `Hash` containing the protection details.
|
|
def self.from_api_response(branch_protection, _additional_object_data = {})
|
|
branch_name = branch_protection[:url].match(%r{/branches/(\S{1,255})/protection$})[1]
|
|
|
|
hash = {
|
|
id: branch_name,
|
|
allow_force_pushes: branch_protection.dig(:allow_force_pushes, :enabled),
|
|
required_conversation_resolution: branch_protection.dig(:required_conversation_resolution, :enabled),
|
|
required_signatures: branch_protection.dig(:required_signatures, :enabled),
|
|
required_pull_request_reviews: branch_protection[:required_pull_request_reviews].present?,
|
|
require_code_owner_reviews: branch_protection.dig(:required_pull_request_reviews,
|
|
:require_code_owner_reviews).present?
|
|
}
|
|
|
|
new(hash)
|
|
end
|
|
|
|
# Builds a new Protection using a Hash that was built from a JSON payload.
|
|
def self.from_json_hash(raw_hash)
|
|
new(Representation.symbolize_hash(raw_hash))
|
|
end
|
|
|
|
# attributes - A Hash containing the raw Protection details. The keys of this
|
|
# Hash (and any nested hashes) must be symbols.
|
|
def initialize(attributes)
|
|
@attributes = attributes
|
|
end
|
|
|
|
def github_identifiers
|
|
{ id: id }
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|