1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
# 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) }
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
def value_with_prefill_data
value_with_data
end
end
class ComplexVariable < ::Gitlab::Config::Entry::Node
include ::Gitlab::Config::Entry::Validatable
include ::Gitlab::Config::Entry::Attributable
class << self
def applies_to?(config)
config.is_a?(Hash)
end
end
attributes :value, :description, :expand, :options, prefix: :config
validations do
validates :key, alphanumeric: true
validates :config_value, alphanumeric: true, allow_nil: true
validates :config_description, alphanumeric: true, allow_nil: true
validates :config_expand, boolean: true, allow_nil: true
validates :config_options, array_of_strings: true, allow_nil: true
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
if config_options.present? && config_options.exclude?(config_value)
errors.add(:config, 'value must be present in options')
end
end
end
def value
# Needed since the `Entry::Node` provides `value` (which is current hash)
config_value.to_s
end
def value_with_data
{
value: config_value.to_s,
raw: (!config_expand if has_config_expand?)
}.compact
end
def value_with_prefill_data
value_with_data.merge(
description: config_description,
options: config_options
).compact
end
end
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
|