kuby-crdb 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +5 -0
  3. data/Gemfile +7 -1
  4. data/Rakefile +7 -1
  5. data/kuby-crdb.gemspec +1 -1
  6. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster.rb +32 -22
  7. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_list.rb +29 -19
  8. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec.rb +90 -0
  9. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity.rb +33 -0
  10. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity.rb +30 -0
  11. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_exec_8b78f2b1.rb +33 -0
  12. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_exec_8d2a4565.rb +30 -0
  13. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_exec_f85e726e.rb +33 -0
  14. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_execution.rb +30 -0
  15. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execu_05ab423d.rb +33 -0
  16. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execu_48b642ac.rb +30 -0
  17. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execu_bb695e66.rb +33 -0
  18. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution.rb +27 -0
  19. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity.rb +30 -0
  20. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_preferred_during_scheduling_ignored_during_execu_17815603.rb +33 -0
  21. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_preferred_during_scheduling_ignored_during_execu_89c72c0d.rb +33 -0
  22. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_preferred_during_scheduling_ignored_during_execu_c9250bb0.rb +30 -0
  23. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_preferred_during_scheduling_ignored_during_execution.rb +30 -0
  24. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_required_during_scheduling_ignored_during_execut_288baf8e.rb +33 -0
  25. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_required_during_scheduling_ignored_during_execut_68d750ca.rb +30 -0
  26. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_affinity_required_during_scheduling_ignored_during_execution.rb +33 -0
  27. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity.rb +30 -0
  28. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_preferred_during_scheduling_ignored_during__7005510b.rb +30 -0
  29. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_preferred_during_scheduling_ignored_during__eef14bfd.rb +33 -0
  30. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_preferred_during_scheduling_ignored_during__ffa31ee1.rb +33 -0
  31. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_preferred_during_scheduling_ignored_during_execution.rb +30 -0
  32. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_required_during_scheduling_ignored_during_e_a054a9d0.rb +30 -0
  33. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_required_during_scheduling_ignored_during_e_e3e2a2ff.rb +33 -0
  34. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_affinity_pod_anti_affinity_required_during_scheduling_ignored_during_execution.rb +33 -0
  35. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store.rb +33 -0
  36. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_host_path.rb +30 -0
  37. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc.rb +30 -0
  38. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_source.rb +30 -0
  39. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_spec.rb +45 -0
  40. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_spec_data_source.rb +33 -0
  41. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_spec_resources.rb +30 -0
  42. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_spec_selector.rb +30 -0
  43. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_data_store_pvc_spec_selector_match_expressions.rb +33 -0
  44. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_image.rb +33 -0
  45. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables.rb +33 -0
  46. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables_value_from.rb +36 -0
  47. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables_value_from_config_map_key_ref.rb +33 -0
  48. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables_value_from_field_ref.rb +30 -0
  49. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables_value_from_resource_field_ref.rb +30 -0
  50. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_pod_env_variables_value_from_secret_key_ref.rb +33 -0
  51. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_resources.rb +30 -0
  52. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_spec_tolerations.rb +39 -0
  53. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_status.rb +39 -0
  54. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_status_conditions.rb +33 -0
  55. data/lib/kuby/crdb/dsl/crdb/v1alpha1/crdb_cluster_status_operator_actions.rb +36 -0
  56. data/lib/kuby/crdb/dsl/crdb/v1alpha1.rb +48 -17
  57. data/lib/kuby/crdb/version.rb +1 -1
  58. data/rbi/kuby-crdb.rbi +1177 -0
  59. metadata +51 -19
  60. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec.rb +0 -80
  61. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_affinity.rb +0 -23
  62. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_affinity_node_affinity.rb +0 -20
  63. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution.rb +0 -17
  64. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_affinity_pod_affinity.rb +0 -20
  65. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_affinity_pod_anti_affinity.rb +0 -20
  66. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store.rb +0 -23
  67. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_host_path.rb +0 -20
  68. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc.rb +0 -20
  69. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc_source.rb +0 -20
  70. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc_spec.rb +0 -35
  71. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc_spec_data_source.rb +0 -23
  72. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc_spec_resources.rb +0 -20
  73. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_data_store_pvc_spec_selector.rb +0 -20
  74. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_image.rb +0 -23
  75. data/lib/kuby/crdb/dsl/crdb/v1alpha1/spec_resources.rb +0 -20
  76. data/lib/kuby/crdb/dsl/crdb/v1alpha1/status.rb +0 -29
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 452c64d31fbe3da91cf3b12066156004ff8dcc50dcd62ce448b9e5a5e72dbb0a
4
- data.tar.gz: 55aca34f100f7cdd53869fb4ce6e675db63a65b9794e9dd001ae35aee82e7aab
3
+ metadata.gz: 8b97547db1a1d7be9ffb0d37f7d071ef8535acd3edf6e1aa39e310c979bfa139
4
+ data.tar.gz: 4d6af251b8f9ed66819e0200888ea9c632f2a3325510822ce059f1f8b89cfd6d
5
5
  SHA512:
6
- metadata.gz: 51883863a1bb078941f88c904d162a00e461d1d7d7d192909c625940cf8f9fe4b8f4dca0294ef5b70e956c8b66df539ed709bb5bfa0dec82005db9f867d33d56
7
- data.tar.gz: d2032dd54d710f1bb4ba7db4330b4c187d59c0f4504b65dfbd8337cf023ea3202fc986c0f85f37ba098c616c24b6ffa0fdc8ef6e6613604e4746ea72d84edfb3
6
+ metadata.gz: 9f4a6ba89a3b21e0daf31785ce53947420d7362fe121f7affe12cf57e21cc36fd56a12e7c5bd3b741bbae8d1f53d57a47e7c981302bf931c429e3da255eb8453
7
+ data.tar.gz: 5249c8d0fe8581d8714d7a621fe946b49add95c6d2e945043091c341d4dcf4e6594bbb9a2f22d76a6cb7895761245657f66f7fc8bd1bd8f64e49ff13ad1cb6d9
data/CHANGELOG.md CHANGED
@@ -1,2 +1,7 @@
1
+ ## 0.2.0
2
+ * Export types into the rbi/ directory using parlour.
3
+ * Use tapioca for managing type annotations in gems.
4
+ * Regenerate code using latest kube-dsl.
5
+
1
6
  ## 0.1.0
2
7
  * Birthday!
data/Gemfile CHANGED
@@ -7,10 +7,16 @@ group :development do
7
7
  end
8
8
 
9
9
  group :development, :test do
10
- gem 'kuby-core'
10
+ gem 'kube-dsl'
11
+ gem 'kuby-core', path: '../kuby-core'
11
12
  gem 'kuby-kind'
12
13
  gem 'pry-byebug'
13
14
  gem 'rake'
15
+
16
+ gem 'sorbet'
17
+ gem 'sorbet-runtime'
18
+ gem 'tapioca', '~> 0.7'
19
+ gem 'parlour', github: 'camertron/parlour', branch: 'initialize_void'
14
20
  end
15
21
 
16
22
  group :test do
data/Rakefile CHANGED
@@ -2,6 +2,7 @@ require 'bundler'
2
2
  require 'rspec/core/rake_task'
3
3
  require 'rubygems/package_task'
4
4
 
5
+ require 'sorbet-runtime'
5
6
  require 'kuby/crdb'
6
7
  require 'pry-byebug'
7
8
 
@@ -143,7 +144,12 @@ task :codegen do
143
144
  )
144
145
 
145
146
  ns = external_ref.ruby_namespace + [external_ref.kind]
146
- exists = ns.inject(Object) { |mod, n| mod.const_get(n, false) } rescue false
147
+ exists = begin
148
+ ns.inject(Object) { |mod, n| mod.const_get(n, false) }
149
+ true
150
+ rescue => e
151
+ false
152
+ end
147
153
  exists ? external_ref : builder.parse_ref(ref_str)
148
154
  end
149
155
 
data/kuby-crdb.gemspec CHANGED
@@ -15,5 +15,5 @@ Gem::Specification.new do |s|
15
15
  s.add_dependency 'kube-dsl', '~> 0.7'
16
16
 
17
17
  s.require_path = 'lib'
18
- s.files = Dir['{lib,spec}/**/*', 'Gemfile', 'LICENSE', 'CHANGELOG.md', 'README.md', 'Rakefile', 'kuby-crdb.gemspec']
18
+ s.files = Dir['{lib,spec,rbi}/**/*', 'Gemfile', 'LICENSE', 'CHANGELOG.md', 'README.md', 'Rakefile', 'kuby-crdb.gemspec']
19
19
  end
@@ -1,27 +1,37 @@
1
- module Kuby::CRDB::DSL::CRDB::V1alpha1
2
- class CrdbCluster < ::KubeDSL::DSLObject
3
- object_field(:status) { Kuby::CRDB::DSL::CRDB::V1alpha1::Status.new }
4
- object_field(:spec) { Kuby::CRDB::DSL::CRDB::V1alpha1::Spec.new }
5
- value_field :api_version
6
- object_field(:metadata) { KubeDSL::DSL::Meta::V1::ObjectMeta.new }
1
+ # typed: true
7
2
 
8
- validates :status, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::Status }
9
- validates :spec, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::Spec }
10
- validates :api_version, field: { format: :string }, presence: false
11
- validates :metadata, object: { kind_of: KubeDSL::DSL::Meta::V1::ObjectMeta }
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbCluster < ::KubeDSL::DSLObject
9
+ object_field(:status) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterStatus.new }
10
+ object_field(:spec) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpec.new }
11
+ value_field :api_version
12
+ object_field(:metadata) { KubeDSL::DSL::Meta::V1::ObjectMeta.new }
12
13
 
13
- def serialize
14
- {}.tap do |result|
15
- result[:status] = status.serialize
16
- result[:kind] = "CrdbCluster"
17
- result[:spec] = spec.serialize
18
- result[:apiVersion] = api_version
19
- result[:metadata] = metadata.serialize
20
- end
21
- end
14
+ validates :status, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterStatus }
15
+ validates :spec, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpec }
16
+ validates :api_version, field: { format: :string }, presence: false
17
+ validates :metadata, object: { kind_of: KubeDSL::DSL::Meta::V1::ObjectMeta }
22
18
 
23
- def kind_sym
24
- :crdb_cluster
19
+ def serialize
20
+ {}.tap do |result|
21
+ result[:status] = status.serialize
22
+ result[:kind] = "CrdbCluster"
23
+ result[:spec] = spec.serialize
24
+ result[:apiVersion] = api_version
25
+ result[:metadata] = metadata.serialize
26
+ end
27
+ end
28
+
29
+ def kind_sym
30
+ :crdb_cluster
31
+ end
32
+ end
33
+ end
34
+ end
25
35
  end
26
36
  end
27
- end
37
+ end
@@ -1,24 +1,34 @@
1
- module Kuby::CRDB::DSL::CRDB::V1alpha1
2
- class CrdbClusterList < ::KubeDSL::DSLObject
3
- array_field(:item) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbCluster.new }
4
- value_field :api_version
5
- object_field(:metadata) { KubeDSL::DSL::Meta::V1::ListMeta.new }
1
+ # typed: true
6
2
 
7
- validates :items, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbCluster }, presence: false
8
- validates :api_version, field: { format: :string }, presence: false
9
- validates :metadata, object: { kind_of: KubeDSL::DSL::Meta::V1::ListMeta }
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterList < ::KubeDSL::DSLObject
9
+ array_field(:item) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbCluster.new }
10
+ value_field :api_version
11
+ object_field(:metadata) { KubeDSL::DSL::Meta::V1::ListMeta.new }
10
12
 
11
- def serialize
12
- {}.tap do |result|
13
- result[:items] = items.map(&:serialize)
14
- result[:kind] = "CrdbClusterList"
15
- result[:apiVersion] = api_version
16
- result[:metadata] = metadata.serialize
17
- end
18
- end
13
+ validates :items, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbCluster }, presence: false
14
+ validates :api_version, field: { format: :string }, presence: false
15
+ validates :metadata, object: { kind_of: KubeDSL::DSL::Meta::V1::ListMeta }
19
16
 
20
- def kind_sym
21
- :crdb_cluster_list
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:items] = items.map(&:serialize)
20
+ result[:kind] = "CrdbClusterList"
21
+ result[:apiVersion] = api_version
22
+ result[:metadata] = metadata.serialize
23
+ end
24
+ end
25
+
26
+ def kind_sym
27
+ :crdb_cluster_list
28
+ end
29
+ end
30
+ end
31
+ end
22
32
  end
23
33
  end
24
- end
34
+ end
@@ -0,0 +1,90 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpec < ::KubeDSL::DSLObject
9
+ object_field(:image) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecImage.new }
10
+ value_field :additional_args
11
+ value_field :min_available
12
+ value_field :max_sql_memory
13
+ value_field :cache
14
+ value_field :tls_enabled
15
+ key_value_field(:node_selector, format: :string)
16
+ value_field :http_port
17
+ object_field(:affinity) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinity.new }
18
+ array_field(:toleration) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecTolerations.new }
19
+ value_field :nodes
20
+ value_field :cockroach_db_version
21
+ object_field(:resources) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecResources.new }
22
+ key_value_field(:additional_annotations, format: :string)
23
+ value_field :client_tls_secret
24
+ key_value_field(:additional_labels, format: :string)
25
+ value_field :sql_port
26
+ value_field :max_unavailable
27
+ value_field :node_tls_secret
28
+ array_field(:pod_env_variable) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecPodEnvVariables.new }
29
+ object_field(:data_store) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecDataStore.new }
30
+ value_field :grpc_port
31
+
32
+ validates :image, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecImage }
33
+ validates :additional_args, field: { format: :string }, presence: false
34
+ validates :min_available, field: { format: :integer }, presence: true
35
+ validates :max_sql_memory, field: { format: :string }, presence: false
36
+ validates :cache, field: { format: :string }, presence: false
37
+ validates :tls_enabled, field: { format: :boolean }, presence: true
38
+ validates :node_selector, kv: { value_format: :string }, presence: true
39
+ validates :http_port, field: { format: :integer }, presence: true
40
+ validates :affinity, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinity }
41
+ validates :tolerations, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecTolerations }, presence: false
42
+ validates :nodes, field: { format: :integer }, presence: true
43
+ validates :cockroach_db_version, field: { format: :string }, presence: false
44
+ validates :resources, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecResources }
45
+ validates :additional_annotations, kv: { value_format: :string }, presence: true
46
+ validates :client_tls_secret, field: { format: :string }, presence: false
47
+ validates :additional_labels, kv: { value_format: :string }, presence: true
48
+ validates :sql_port, field: { format: :integer }, presence: true
49
+ validates :max_unavailable, field: { format: :integer }, presence: true
50
+ validates :node_tls_secret, field: { format: :string }, presence: false
51
+ validates :pod_env_variables, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecPodEnvVariables }, presence: false
52
+ validates :data_store, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecDataStore }
53
+ validates :grpc_port, field: { format: :integer }, presence: true
54
+
55
+ def serialize
56
+ {}.tap do |result|
57
+ result[:image] = image.serialize
58
+ result[:additionalArgs] = additional_args
59
+ result[:minAvailable] = min_available
60
+ result[:maxSQLMemory] = max_sql_memory
61
+ result[:cache] = cache
62
+ result[:tlsEnabled] = tls_enabled
63
+ result[:nodeSelector] = node_selector.serialize
64
+ result[:httpPort] = http_port
65
+ result[:affinity] = affinity.serialize
66
+ result[:tolerations] = tolerations.map(&:serialize)
67
+ result[:nodes] = nodes
68
+ result[:cockroachDBVersion] = cockroach_db_version
69
+ result[:resources] = resources.serialize
70
+ result[:additionalAnnotations] = additional_annotations.serialize
71
+ result[:clientTLSSecret] = client_tls_secret
72
+ result[:additionalLabels] = additional_labels.serialize
73
+ result[:sqlPort] = sql_port
74
+ result[:maxUnavailable] = max_unavailable
75
+ result[:nodeTLSSecret] = node_tls_secret
76
+ result[:podEnvVariables] = pod_env_variables.map(&:serialize)
77
+ result[:dataStore] = data_store.serialize
78
+ result[:grpcPort] = grpc_port
79
+ end
80
+ end
81
+
82
+ def kind_sym
83
+ :crdb_cluster_spec
84
+ end
85
+ end
86
+ end
87
+ end
88
+ end
89
+ end
90
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinity < ::KubeDSL::DSLObject
9
+ object_field(:pod_affinity) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinity.new }
10
+ object_field(:node_affinity) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinity.new }
11
+ object_field(:pod_anti_affinity) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAntiAffinity.new }
12
+
13
+ validates :pod_affinity, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinity }
14
+ validates :node_affinity, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinity }
15
+ validates :pod_anti_affinity, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAntiAffinity }
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:podAffinity] = pod_affinity.serialize
20
+ result[:nodeAffinity] = node_affinity.serialize
21
+ result[:podAntiAffinity] = pod_anti_affinity.serialize
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,30 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinity < ::KubeDSL::DSLObject
9
+ object_field(:required_during_scheduling_ignored_during_execution) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecution.new }
10
+ array_field(:preferred_during_scheduling_ignored_during_execution) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecution.new }
11
+
12
+ validates :required_during_scheduling_ignored_during_execution, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecution }
13
+ validates :preferred_during_scheduling_ignored_during_executions, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecution }, presence: false
14
+
15
+ def serialize
16
+ {}.tap do |result|
17
+ result[:requiredDuringSchedulingIgnoredDuringExecution] = required_during_scheduling_ignored_during_execution.serialize
18
+ result[:preferredDuringSchedulingIgnoredDuringExecution] = preferred_during_scheduling_ignored_during_executions.map(&:serialize)
19
+ end
20
+ end
21
+
22
+ def kind_sym
23
+ :crdb_cluster_spec_affinity_node_affinity
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchFields < ::KubeDSL::DSLObject
9
+ value_field :operator
10
+ value_field :values
11
+ value_field :key
12
+
13
+ validates :operator, field: { format: :string }, presence: true
14
+ validates :values, field: { format: :string }, presence: false
15
+ validates :key, field: { format: :string }, presence: true
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:operator] = operator
20
+ result[:values] = values
21
+ result[:key] = key
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_execution_preference_match_fields
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,30 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreference < ::KubeDSL::DSLObject
9
+ array_field(:match_field) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchFields.new }
10
+ array_field(:match_expression) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchExpressions.new }
11
+
12
+ validates :match_fields, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchFields }, presence: false
13
+ validates :match_expressions, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchExpressions }, presence: false
14
+
15
+ def serialize
16
+ {}.tap do |result|
17
+ result[:matchFields] = match_fields.map(&:serialize)
18
+ result[:matchExpressions] = match_expressions.map(&:serialize)
19
+ end
20
+ end
21
+
22
+ def kind_sym
23
+ :crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_execution_preference
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreferenceMatchExpressions < ::KubeDSL::DSLObject
9
+ value_field :operator
10
+ value_field :values
11
+ value_field :key
12
+
13
+ validates :operator, field: { format: :string }, presence: true
14
+ validates :values, field: { format: :string }, presence: false
15
+ validates :key, field: { format: :string }, presence: true
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:operator] = operator
20
+ result[:values] = values
21
+ result[:key] = key
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_execution_preference_match_expressions
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,30 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecution < ::KubeDSL::DSLObject
9
+ object_field(:preference) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreference.new }
10
+ value_field :weight
11
+
12
+ validates :preference, object: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityPreferredDuringSchedulingIgnoredDuringExecutionPreference }
13
+ validates :weight, field: { format: :integer }, presence: true
14
+
15
+ def serialize
16
+ {}.tap do |result|
17
+ result[:preference] = preference.serialize
18
+ result[:weight] = weight
19
+ end
20
+ end
21
+
22
+ def kind_sym
23
+ :crdb_cluster_spec_affinity_node_affinity_preferred_during_scheduling_ignored_during_execution
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchFields < ::KubeDSL::DSLObject
9
+ value_field :operator
10
+ value_field :values
11
+ value_field :key
12
+
13
+ validates :operator, field: { format: :string }, presence: true
14
+ validates :values, field: { format: :string }, presence: false
15
+ validates :key, field: { format: :string }, presence: true
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:operator] = operator
20
+ result[:values] = values
21
+ result[:key] = key
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution_node_selector_terms_match_fields
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,30 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTerms < ::KubeDSL::DSLObject
9
+ array_field(:match_field) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchFields.new }
10
+ array_field(:match_expression) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchExpressions.new }
11
+
12
+ validates :match_fields, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchFields }, presence: false
13
+ validates :match_expressions, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchExpressions }, presence: false
14
+
15
+ def serialize
16
+ {}.tap do |result|
17
+ result[:matchFields] = match_fields.map(&:serialize)
18
+ result[:matchExpressions] = match_expressions.map(&:serialize)
19
+ end
20
+ end
21
+
22
+ def kind_sym
23
+ :crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution_node_selector_terms
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTermsMatchExpressions < ::KubeDSL::DSLObject
9
+ value_field :operator
10
+ value_field :values
11
+ value_field :key
12
+
13
+ validates :operator, field: { format: :string }, presence: true
14
+ validates :values, field: { format: :string }, presence: false
15
+ validates :key, field: { format: :string }, presence: true
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:operator] = operator
20
+ result[:values] = values
21
+ result[:key] = key
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution_node_selector_terms_match_expressions
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,27 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecution < ::KubeDSL::DSLObject
9
+ array_field(:node_selector_term) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTerms.new }
10
+
11
+ validates :node_selector_terms, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityNodeAffinityRequiredDuringSchedulingIgnoredDuringExecutionNodeSelectorTerms }, presence: true
12
+
13
+ def serialize
14
+ {}.tap do |result|
15
+ result[:nodeSelectorTerms] = node_selector_terms.map(&:serialize)
16
+ end
17
+ end
18
+
19
+ def kind_sym
20
+ :crdb_cluster_spec_affinity_node_affinity_required_during_scheduling_ignored_during_execution
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,30 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityPodAffinity < ::KubeDSL::DSLObject
9
+ array_field(:required_during_scheduling_ignored_during_execution) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinityRequiredDuringSchedulingIgnoredDuringExecution.new }
10
+ array_field(:preferred_during_scheduling_ignored_during_execution) { Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinityPreferredDuringSchedulingIgnoredDuringExecution.new }
11
+
12
+ validates :required_during_scheduling_ignored_during_executions, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinityRequiredDuringSchedulingIgnoredDuringExecution }, presence: false
13
+ validates :preferred_during_scheduling_ignored_during_executions, array: { kind_of: Kuby::CRDB::DSL::CRDB::V1alpha1::CrdbClusterSpecAffinityPodAffinityPreferredDuringSchedulingIgnoredDuringExecution }, presence: false
14
+
15
+ def serialize
16
+ {}.tap do |result|
17
+ result[:requiredDuringSchedulingIgnoredDuringExecution] = required_during_scheduling_ignored_during_executions.map(&:serialize)
18
+ result[:preferredDuringSchedulingIgnoredDuringExecution] = preferred_during_scheduling_ignored_during_executions.map(&:serialize)
19
+ end
20
+ end
21
+
22
+ def kind_sym
23
+ :crdb_cluster_spec_affinity_pod_affinity
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,33 @@
1
+ # typed: true
2
+
3
+ module Kuby
4
+ module CRDB
5
+ module DSL
6
+ module CRDB
7
+ module V1alpha1
8
+ class CrdbClusterSpecAffinityPodAffinityPreferredDuringSchedulingIgnoredDuringExecutionPodAffinityTermLabelSelectorMatchExpressions < ::KubeDSL::DSLObject
9
+ value_field :operator
10
+ value_field :values
11
+ value_field :key
12
+
13
+ validates :operator, field: { format: :string }, presence: true
14
+ validates :values, field: { format: :string }, presence: false
15
+ validates :key, field: { format: :string }, presence: true
16
+
17
+ def serialize
18
+ {}.tap do |result|
19
+ result[:operator] = operator
20
+ result[:values] = values
21
+ result[:key] = key
22
+ end
23
+ end
24
+
25
+ def kind_sym
26
+ :crdb_cluster_spec_affinity_pod_affinity_preferred_during_scheduling_ignored_during_execution_pod_affinity_term_label_selector_match_expressions
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end