debian-mirror-gitlab/lib/gitlab/ci/config/entry/variable.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

164 lines
4.7 KiB
Ruby
Raw Normal View History

2022-10-11 01:57:18 +05:30
# frozen_string_literal: true
module Gitlab
module Ci
class Config
module Entry
##
# Entry that represents a CI/CD variable.
#
class Variable < ::Gitlab::Config::Entry::Simplifiable
strategy :SimpleVariable, if: -> (config) { SimpleVariable.applies_to?(config) }
strategy :ComplexVariable, if: -> (config) { ComplexVariable.applies_to?(config) }
2022-11-25 23:54:43 +05:30
strategy :ComplexArrayVariable, if: -> (config) { ComplexArrayVariable.applies_to?(config) }
2022-10-11 01:57:18 +05:30
class SimpleVariable < ::Gitlab::Config::Entry::Node
include ::Gitlab::Config::Entry::Validatable
class << self
def applies_to?(config)
Gitlab::Config::Entry::Validators::AlphanumericValidator.validate(config)
end
end
validations do
validates :key, alphanumeric: true
validates :config, alphanumeric: true
end
def value
@config.to_s
end
def value_with_data
{ value: @config.to_s }
end
2023-01-13 00:05:48 +05:30
def value_with_prefill_data
value_with_data
end
2022-10-11 01:57:18 +05:30
end
class ComplexVariable < ::Gitlab::Config::Entry::Node
include ::Gitlab::Config::Entry::Validatable
class << self
def applies_to?(config)
2022-11-25 23:54:43 +05:30
config.is_a?(Hash) && !config[:value].is_a?(Array)
2022-10-11 01:57:18 +05:30
end
end
validations do
validates :key, alphanumeric: true
validates :config_value, alphanumeric: true, allow_nil: false, if: :config_value_defined?
validates :config_description, alphanumeric: true, allow_nil: false, if: :config_description_defined?
2023-01-13 00:05:48 +05:30
validates :config_expand, boolean: true,
allow_nil: false,
if: -> { ci_raw_variables_in_yaml_config_enabled? && config_expand_defined? }
2022-10-11 01:57:18 +05:30
validate do
allowed_value_data = Array(opt(:allowed_value_data))
if allowed_value_data.any?
extra_keys = config.keys - allowed_value_data
errors.add(:config, "uses invalid data keys: #{extra_keys.join(', ')}") if extra_keys.present?
else
errors.add(:config, "must be a string")
end
end
end
def value
config_value.to_s
end
def value_with_data
2023-01-13 00:05:48 +05:30
if ci_raw_variables_in_yaml_config_enabled?
{
value: value,
raw: (!config_expand if config_expand_defined?)
}.compact
else
{
value: value
}.compact
end
end
def value_with_prefill_data
value_with_data.merge(
description: config_description
).compact
2022-10-11 01:57:18 +05:30
end
def config_value
@config[:value]
end
def config_description
@config[:description]
end
2023-01-13 00:05:48 +05:30
def config_expand
@config[:expand]
end
2022-10-11 01:57:18 +05:30
def config_value_defined?
config.key?(:value)
end
def config_description_defined?
config.key?(:description)
end
2023-01-13 00:05:48 +05:30
def config_expand_defined?
config.key?(:expand)
end
def ci_raw_variables_in_yaml_config_enabled?
YamlProcessor::FeatureFlags.enabled?(:ci_raw_variables_in_yaml_config)
end
2022-10-11 01:57:18 +05:30
end
2022-11-25 23:54:43 +05:30
class ComplexArrayVariable < ComplexVariable
include ::Gitlab::Config::Entry::Validatable
class << self
def applies_to?(config)
config.is_a?(Hash) && config[:value].is_a?(Array)
end
end
validations do
validates :config_value, array_of_strings: true, allow_nil: false, if: :config_value_defined?
validate do
next if opt(:allow_array_value)
errors.add(:config, 'value must be an alphanumeric string')
end
end
def value
config_value.first
end
2023-01-13 00:05:48 +05:30
def value_with_prefill_data
super.merge(
value_options: config_value
).compact
2022-11-25 23:54:43 +05:30
end
end
2022-10-11 01:57:18 +05:30
class UnknownStrategy < ::Gitlab::Config::Entry::Node
def errors
["variable definition must be either a string or a hash"]
end
end
end
end
end
end
end