2018-12-13 13:39:08 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
# Gitaly note: JV: does not need to be migrated, works without a repo.
|
|
|
|
|
2015-04-26 12:48:37 +05:30
|
|
|
module Gitlab
|
|
|
|
module GitRefValidator
|
|
|
|
extend self
|
2019-06-05 12:25:43 +05:30
|
|
|
|
|
|
|
EXPANDED_PREFIXES = %w[refs/heads/ refs/remotes/].freeze
|
|
|
|
DISALLOWED_PREFIXES = %w[-].freeze
|
|
|
|
|
2015-04-26 12:48:37 +05:30
|
|
|
# Validates a given name against the git reference specification
|
|
|
|
#
|
|
|
|
# Returns true for a valid reference name, false otherwise
|
|
|
|
def validate(ref_name)
|
2019-06-05 12:25:43 +05:30
|
|
|
return false if ref_name.start_with?(*(EXPANDED_PREFIXES + DISALLOWED_PREFIXES))
|
2018-11-18 11:00:15 +05:30
|
|
|
return false if ref_name == 'HEAD'
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
begin
|
|
|
|
Rugged::Reference.valid_name?("refs/heads/#{ref_name}")
|
|
|
|
rescue ArgumentError
|
|
|
|
return false
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2019-06-05 12:25:43 +05:30
|
|
|
|
|
|
|
def validate_merge_request_branch(ref_name)
|
|
|
|
return false if ref_name.start_with?(*DISALLOWED_PREFIXES)
|
|
|
|
|
|
|
|
expanded_name = if ref_name.start_with?(*EXPANDED_PREFIXES)
|
|
|
|
ref_name
|
|
|
|
else
|
|
|
|
"refs/heads/#{ref_name}"
|
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
Rugged::Reference.valid_name?(expanded_name)
|
|
|
|
rescue ArgumentError
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|