kube_cluster 0.2.1 → 0.3.1
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.
- checksums.yaml +4 -4
- data/Gemfile.lock +8 -10
- data/examples/01-basic-redis-pod/manifest.rb +3 -3
- data/examples/02-manifest-with-middleware/manifest.rb +37 -0
- data/examples/02-manifest-with-middleware/middleware/labels.rb +4 -0
- data/examples/02-manifest-with-middleware/middleware/namespace.rb +4 -0
- data/examples/02-manifest-with-middleware/templates/config_map.rb +13 -0
- data/examples/02-manifest-with-middleware/templates/deployment.rb +59 -0
- data/examples/02-manifest-with-middleware/templates/horizontal_pod_autoscaler.rb +30 -0
- data/examples/02-manifest-with-middleware/templates/ingress.rb +38 -0
- data/examples/02-manifest-with-middleware/templates/service.rb +12 -0
- data/examples/{version2 → 03-app-with-database}/demo.rb +2 -2
- data/examples/{version2 → 03-app-with-database}/postgresql.rb +4 -4
- data/examples/{version2 → 03-app-with-database}/ruby_on_rails.rb +1 -1
- data/kube_cluster.gemspec +1 -1
- data/lib/kube/cluster/manifest.rb +13 -64
- data/lib/kube/cluster/middleware/annotations.rb +32 -0
- data/lib/kube/cluster/middleware/hpa_for_deployment.rb +111 -0
- data/lib/kube/cluster/{manifest/middleware → middleware}/ingress_for_service.rb +36 -34
- data/lib/kube/cluster/middleware/labels.rb +59 -0
- data/lib/kube/cluster/middleware/namespace.rb +31 -0
- data/lib/kube/cluster/middleware/pod_anti_affinity.rb +61 -0
- data/lib/kube/cluster/middleware/resource_preset.rb +64 -0
- data/lib/kube/cluster/middleware/security_context.rb +84 -0
- data/lib/kube/cluster/middleware/service_for_deployment.rb +71 -0
- data/lib/kube/cluster/middleware/stack.rb +43 -0
- data/lib/kube/cluster/middleware.rb +69 -0
- data/lib/kube/cluster/resource.rb +78 -0
- data/lib/kube/cluster/version.rb +1 -1
- data/lib/kube/cluster.rb +21 -0
- metadata +27 -21
- data/examples/database/manifest.rb +0 -238
- data/examples/web-app/manifest.rb +0 -215
- data/lib/kube/cluster/manifest/middleware/annotations.rb +0 -32
- data/lib/kube/cluster/manifest/middleware/hpa_for_deployment.rb +0 -109
- data/lib/kube/cluster/manifest/middleware/labels.rb +0 -59
- data/lib/kube/cluster/manifest/middleware/namespace.rb +0 -31
- data/lib/kube/cluster/manifest/middleware/pod_anti_affinity.rb +0 -61
- data/lib/kube/cluster/manifest/middleware/resource_preset.rb +0 -64
- data/lib/kube/cluster/manifest/middleware/security_context.rb +0 -84
- data/lib/kube/cluster/manifest/middleware/service_for_deployment.rb +0 -69
- data/lib/kube/cluster/manifest/middleware.rb +0 -178
- data/lib/kube/cluster/manifest/stack.rb +0 -56
- /data/examples/{version2 → 03-app-with-database}/helpers.rb +0 -0
- /data/examples/{version2 → 03-app-with-database}/my_app.rb +0 -0
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
module Kube
|
|
4
|
-
module Cluster
|
|
5
|
-
class Manifest < Kube::Schema::Manifest
|
|
6
|
-
# An ordered pipeline of middleware that processes the full manifest
|
|
7
|
-
# at each stage. Each stage flat_maps individual resources through
|
|
8
|
-
# a single middleware — so generative middleware can introduce new
|
|
9
|
-
# resources that subsequent stages will see and process.
|
|
10
|
-
#
|
|
11
|
-
# stack = Kube::Cluster::Manifest::Stack.new do
|
|
12
|
-
# use Middleware::ServiceForDeployment # generates Services
|
|
13
|
-
# use Middleware::Labels, app: "web" # labels everything, including generated Services
|
|
14
|
-
# use Middleware::ResourcePreset # sizes everything
|
|
15
|
-
# end
|
|
16
|
-
#
|
|
17
|
-
# processed = stack.call(resources)
|
|
18
|
-
#
|
|
19
|
-
class Stack
|
|
20
|
-
def initialize(&block)
|
|
21
|
-
@middleware = []
|
|
22
|
-
instance_eval(&block) if block
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
# Register a middleware class with optional positional and keyword arguments.
|
|
26
|
-
#
|
|
27
|
-
# @param klass [Class] a Middleware subclass
|
|
28
|
-
# @param args [Array] positional arguments forwarded to klass.new
|
|
29
|
-
# @param kwargs [Hash] keyword arguments forwarded to klass.new
|
|
30
|
-
def use(klass, *args, **kwargs)
|
|
31
|
-
@middleware << [klass, args, kwargs]
|
|
32
|
-
end
|
|
33
|
-
|
|
34
|
-
# Run the full resource array through every middleware stage in order.
|
|
35
|
-
# At each stage, every resource is passed individually through the
|
|
36
|
-
# middleware. Middleware can return a single resource (transform) or
|
|
37
|
-
# an array of resources (generative). The results are collected into
|
|
38
|
-
# the array for the next stage.
|
|
39
|
-
#
|
|
40
|
-
# @param resources [Array<Kube::Schema::Resource>]
|
|
41
|
-
# @return [Array<Kube::Schema::Resource>]
|
|
42
|
-
def call(resources)
|
|
43
|
-
@middleware.reduce(resources) do |current, (klass, args, kwargs)|
|
|
44
|
-
middleware = klass.new(*args, **kwargs)
|
|
45
|
-
current.flat_map { |r| Array(middleware.call(r)) }
|
|
46
|
-
end
|
|
47
|
-
end
|
|
48
|
-
|
|
49
|
-
# True when no middleware has been registered.
|
|
50
|
-
def empty?
|
|
51
|
-
@middleware.empty?
|
|
52
|
-
end
|
|
53
|
-
end
|
|
54
|
-
end
|
|
55
|
-
end
|
|
56
|
-
end
|
|
File without changes
|
|
File without changes
|