kubes 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.
- checksums.yaml +5 -5
- data/.gitignore +15 -7
- data/.rspec +3 -0
- data/CHANGELOG.md +10 -0
- data/Gemfile +3 -1
- data/Guardfile +19 -0
- data/LICENSE.txt +201 -0
- data/README.md +46 -18
- data/Rakefile +13 -1
- data/docs/.gitignore +5 -0
- data/docs/CNAME +1 -0
- data/docs/Gemfile +16 -0
- data/docs/LICENSE +201 -0
- data/docs/Procfile +2 -0
- data/docs/README.md +24 -0
- data/docs/Rakefile +38 -0
- data/docs/_config.yml +71 -0
- data/docs/_docs/auto-context.md +47 -0
- data/docs/_docs/config.md +9 -0
- data/docs/_docs/config/docker.md +70 -0
- data/docs/_docs/config/env.md +58 -0
- data/docs/_docs/config/kubectl.md +61 -0
- data/docs/_docs/contributing.md +98 -0
- data/docs/_docs/dsl.md +66 -0
- data/docs/_docs/dsl/multiple-resources.md +114 -0
- data/docs/_docs/dsl/resources.md +12 -0
- data/docs/_docs/dsl/resources/backend_config.md +45 -0
- data/docs/_docs/dsl/resources/config_map.md +84 -0
- data/docs/_docs/dsl/resources/daemon_set.md +58 -0
- data/docs/_docs/dsl/resources/deployment.md +142 -0
- data/docs/_docs/dsl/resources/generic.md +58 -0
- data/docs/_docs/dsl/resources/ingress.md +103 -0
- data/docs/_docs/dsl/resources/managed_certificate.md +39 -0
- data/docs/_docs/dsl/resources/namespace.md +34 -0
- data/docs/_docs/dsl/resources/network_policy.md +45 -0
- data/docs/_docs/dsl/resources/pod.md +82 -0
- data/docs/_docs/dsl/resources/role.md +44 -0
- data/docs/_docs/dsl/resources/role_binding.md +55 -0
- data/docs/_docs/dsl/resources/secret.md +87 -0
- data/docs/_docs/dsl/resources/service.md +60 -0
- data/docs/_docs/dsl/resources/service_account.md +37 -0
- data/docs/_docs/extra-env.md +23 -0
- data/docs/_docs/extra-env/dsl.md +86 -0
- data/docs/_docs/extra-env/yaml.md +67 -0
- data/docs/_docs/helpers.md +18 -0
- data/docs/_docs/intro.md +15 -0
- data/docs/_docs/intro/concepts.md +37 -0
- data/docs/_docs/intro/how-kubes-works.md +29 -0
- data/docs/_docs/intro/install.md +6 -0
- data/docs/_docs/intro/ordering.md +63 -0
- data/docs/_docs/intro/ordering/custom.md +25 -0
- data/docs/_docs/intro/structure.md +43 -0
- data/docs/_docs/kustomize.md +54 -0
- data/docs/_docs/layering.md +8 -0
- data/docs/_docs/layering/dsl.md +5 -0
- data/docs/_docs/layering/merge.md +96 -0
- data/docs/_docs/layering/yaml.md +5 -0
- data/docs/_docs/learn/dsl.md +5 -0
- data/docs/_docs/learn/dsl/change.md +16 -0
- data/docs/_docs/learn/dsl/cluster.md +5 -0
- data/docs/_docs/learn/dsl/delete.md +30 -0
- data/docs/_docs/learn/dsl/deploy.md +61 -0
- data/docs/_docs/learn/dsl/install.md +5 -0
- data/docs/_docs/learn/dsl/new-project.md +33 -0
- data/docs/_docs/learn/dsl/next-steps.md +5 -0
- data/docs/_docs/learn/dsl/review-project.md +52 -0
- data/docs/_docs/learn/dsl/update.md +53 -0
- data/docs/_docs/learn/yaml.md +5 -0
- data/docs/_docs/learn/yaml/change.md +17 -0
- data/docs/_docs/learn/yaml/cluster.md +5 -0
- data/docs/_docs/learn/yaml/delete.md +30 -0
- data/docs/_docs/learn/yaml/deploy.md +62 -0
- data/docs/_docs/learn/yaml/install.md +5 -0
- data/docs/_docs/learn/yaml/new-project.md +36 -0
- data/docs/_docs/learn/yaml/next-steps.md +5 -0
- data/docs/_docs/learn/yaml/review-project.md +97 -0
- data/docs/_docs/learn/yaml/update.md +54 -0
- data/docs/_docs/next-steps.md +13 -0
- data/docs/_docs/patterns.md +7 -0
- data/docs/_docs/patterns/clock-web-worker.md +71 -0
- data/docs/_docs/resources.md +11 -0
- data/docs/_docs/resources/base.md +33 -0
- data/docs/_docs/resources/role.md +41 -0
- data/docs/_docs/resources/shared.md +36 -0
- data/docs/_docs/yaml.md +46 -0
- data/docs/_includes/commands.html +131 -0
- data/docs/_includes/content.html +25 -0
- data/docs/_includes/dsl/methods.md +1 -0
- data/docs/_includes/dsl/rolling_deployment.md +1 -0
- data/docs/_includes/dsl/suffix_hash.md +8 -0
- data/docs/_includes/example.html +12 -0
- data/docs/_includes/footer.html +37 -0
- data/docs/_includes/google_analytics.html +10 -0
- data/docs/_includes/header.html +31 -0
- data/docs/_includes/intro/install.md +15 -0
- data/docs/_includes/js.html +3 -0
- data/docs/_includes/kubes-steps.md +3 -0
- data/docs/_includes/layering/layers.md +64 -0
- data/docs/_includes/learn/cluster.md +22 -0
- data/docs/_includes/learn/next-steps.md +6 -0
- data/docs/_includes/learn/review.md +25 -0
- data/docs/_includes/learn/start.md +3 -0
- data/docs/_includes/reference.md +3 -0
- data/docs/_includes/sidebar.html +113 -0
- data/docs/_layouts/default.html +35 -0
- data/docs/_reference/kubes-apply.md +24 -0
- data/docs/_reference/kubes-clean.md +22 -0
- data/docs/_reference/kubes-compile.md +22 -0
- data/docs/_reference/kubes-completion.md +42 -0
- data/docs/_reference/kubes-completion_script.md +25 -0
- data/docs/_reference/kubes-delete.md +23 -0
- data/docs/_reference/kubes-deploy.md +35 -0
- data/docs/_reference/kubes-docker-build.md +20 -0
- data/docs/_reference/kubes-docker-help.md +15 -0
- data/docs/_reference/kubes-docker-push.md +20 -0
- data/docs/_reference/kubes-docker.md +25 -0
- data/docs/_reference/kubes-init.md +26 -0
- data/docs/_reference/kubes-version.md +21 -0
- data/docs/_sass/bootstrap-overrides.scss +17 -0
- data/docs/_sass/buttons.scss +62 -0
- data/docs/_sass/caret.scss +39 -0
- data/docs/_sass/content.scss +21 -0
- data/docs/_sass/cta.scss +39 -0
- data/docs/_sass/default.scss +103 -0
- data/docs/_sass/footer.scss +66 -0
- data/docs/_sass/masthead.scss +77 -0
- data/docs/_sass/mixins.scss +79 -0
- data/docs/_sass/sidebar.scss +107 -0
- data/docs/_sass/syntax.scss +89 -0
- data/docs/_sass/table.scss +30 -0
- data/docs/_sass/theme.scss +292 -0
- data/docs/_sass/variables.scss +24 -0
- data/docs/bin/build +4 -0
- data/docs/bin/rerun +2 -0
- data/docs/bin/web +8 -0
- data/docs/css/main.scss +24 -0
- data/docs/docs.md +7 -0
- data/docs/getting-started.md +12 -0
- data/docs/img/logos/boltops-logo-full.png +0 -0
- data/docs/img/logos/boltops-logo.png +0 -0
- data/docs/img/logos/filler-logo.png +0 -0
- data/docs/img/logos/kubes-black.png +0 -0
- data/docs/img/logos/kubes-sign.png +0 -0
- data/docs/index.html +34 -0
- data/docs/js/app.js +39414 -0
- data/docs/opal/app.rb +16 -0
- data/docs/opal/pager.rb +90 -0
- data/docs/opal/sidebar.rb +94 -0
- data/docs/opal/sidebar/expander.rb +51 -0
- data/docs/reference.md +15 -0
- data/docs/support.md +19 -0
- data/docs/vendor/bootstrap/css/bootstrap-grid.css +3719 -0
- data/docs/vendor/bootstrap/css/bootstrap-grid.css.map +1 -0
- data/docs/vendor/bootstrap/css/bootstrap-grid.min.css +7 -0
- data/docs/vendor/bootstrap/css/bootstrap-grid.min.css.map +1 -0
- data/docs/vendor/bootstrap/css/bootstrap-reboot.css +331 -0
- data/docs/vendor/bootstrap/css/bootstrap-reboot.css.map +1 -0
- data/docs/vendor/bootstrap/css/bootstrap-reboot.min.css +8 -0
- data/docs/vendor/bootstrap/css/bootstrap-reboot.min.css.map +1 -0
- data/docs/vendor/bootstrap/css/bootstrap.css +10038 -0
- data/docs/vendor/bootstrap/css/bootstrap.css.map +1 -0
- data/docs/vendor/bootstrap/css/bootstrap.min.css +7 -0
- data/docs/vendor/bootstrap/css/bootstrap.min.css.map +1 -0
- data/docs/vendor/bootstrap/js/bootstrap.bundle.js +7013 -0
- data/docs/vendor/bootstrap/js/bootstrap.bundle.js.map +1 -0
- data/docs/vendor/bootstrap/js/bootstrap.bundle.min.js +7 -0
- data/docs/vendor/bootstrap/js/bootstrap.bundle.min.js.map +1 -0
- data/docs/vendor/bootstrap/js/bootstrap.js +4435 -0
- data/docs/vendor/bootstrap/js/bootstrap.js.map +1 -0
- data/docs/vendor/bootstrap/js/bootstrap.min.js +7 -0
- data/docs/vendor/bootstrap/js/bootstrap.min.js.map +1 -0
- data/docs/vendor/font-awesome/css/font-awesome.css +2337 -0
- data/docs/vendor/font-awesome/css/font-awesome.min.css +4 -0
- data/docs/vendor/font-awesome/fonts/FontAwesome.otf +0 -0
- data/docs/vendor/font-awesome/fonts/fontawesome-webfont.eot +0 -0
- data/docs/vendor/font-awesome/fonts/fontawesome-webfont.svg +2671 -0
- data/docs/vendor/font-awesome/fonts/fontawesome-webfont.ttf +0 -0
- data/docs/vendor/font-awesome/fonts/fontawesome-webfont.woff +0 -0
- data/docs/vendor/font-awesome/fonts/fontawesome-webfont.woff2 +0 -0
- data/docs/vendor/font-awesome/less/animated.less +34 -0
- data/docs/vendor/font-awesome/less/bordered-pulled.less +25 -0
- data/docs/vendor/font-awesome/less/core.less +12 -0
- data/docs/vendor/font-awesome/less/fixed-width.less +6 -0
- data/docs/vendor/font-awesome/less/font-awesome.less +18 -0
- data/docs/vendor/font-awesome/less/icons.less +789 -0
- data/docs/vendor/font-awesome/less/larger.less +13 -0
- data/docs/vendor/font-awesome/less/list.less +19 -0
- data/docs/vendor/font-awesome/less/mixins.less +60 -0
- data/docs/vendor/font-awesome/less/path.less +15 -0
- data/docs/vendor/font-awesome/less/rotated-flipped.less +20 -0
- data/docs/vendor/font-awesome/less/screen-reader.less +5 -0
- data/docs/vendor/font-awesome/less/stacked.less +20 -0
- data/docs/vendor/font-awesome/less/variables.less +799 -0
- data/docs/vendor/font-awesome/scss/_animated.scss +34 -0
- data/docs/vendor/font-awesome/scss/_bordered-pulled.scss +25 -0
- data/docs/vendor/font-awesome/scss/_core.scss +12 -0
- data/docs/vendor/font-awesome/scss/_fixed-width.scss +6 -0
- data/docs/vendor/font-awesome/scss/_icons.scss +789 -0
- data/docs/vendor/font-awesome/scss/_larger.scss +13 -0
- data/docs/vendor/font-awesome/scss/_list.scss +19 -0
- data/docs/vendor/font-awesome/scss/_mixins.scss +60 -0
- data/docs/vendor/font-awesome/scss/_path.scss +15 -0
- data/docs/vendor/font-awesome/scss/_rotated-flipped.scss +20 -0
- data/docs/vendor/font-awesome/scss/_screen-reader.scss +5 -0
- data/docs/vendor/font-awesome/scss/_stacked.scss +20 -0
- data/docs/vendor/font-awesome/scss/_variables.scss +799 -0
- data/docs/vendor/font-awesome/scss/font-awesome.scss +18 -0
- data/docs/vendor/jquery/jquery.js +10598 -0
- data/docs/vendor/jquery/jquery.min.js +2 -0
- data/docs/vendor/jquery/jquery.min.map +1 -0
- data/docs/vendor/jquery/jquery.slim.js +8495 -0
- data/docs/vendor/jquery/jquery.slim.min.js +2 -0
- data/docs/vendor/jquery/jquery.slim.min.map +1 -0
- data/docs/vendor/simple-line-icons/css/simple-line-icons.css +778 -0
- data/docs/vendor/simple-line-icons/fonts/Simple-Line-Icons.eot +0 -0
- data/docs/vendor/simple-line-icons/fonts/Simple-Line-Icons.svg +200 -0
- data/docs/vendor/simple-line-icons/fonts/Simple-Line-Icons.ttf +0 -0
- data/docs/vendor/simple-line-icons/fonts/Simple-Line-Icons.woff +0 -0
- data/docs/vendor/simple-line-icons/fonts/Simple-Line-Icons.woff2 +0 -0
- data/docs/vendor/simple-line-icons/less/simple-line-icons.less +982 -0
- data/docs/vendor/simple-line-icons/scss/simple-line-icons.scss +979 -0
- data/exe/kubes +14 -0
- data/kubes.gemspec +29 -19
- data/lib/kubes.rb +21 -1
- data/lib/kubes/args/custom.rb +30 -0
- data/lib/kubes/args/dsl.rb +14 -0
- data/lib/kubes/auth.rb +21 -0
- data/lib/kubes/auth/ecr.rb +55 -0
- data/lib/kubes/autoloader.rb +21 -0
- data/lib/kubes/aws_services.rb +14 -0
- data/lib/kubes/cli.rb +93 -0
- data/lib/kubes/cli/apply.rb +9 -0
- data/lib/kubes/cli/base.rb +9 -0
- data/lib/kubes/cli/build.rb +8 -0
- data/lib/kubes/cli/clean.rb +9 -0
- data/lib/kubes/cli/compile.rb +8 -0
- data/lib/kubes/cli/delete.rb +11 -0
- data/lib/kubes/cli/deploy.rb +13 -0
- data/lib/kubes/cli/describe.rb +8 -0
- data/lib/kubes/cli/docker.rb +20 -0
- data/lib/kubes/cli/get.rb +8 -0
- data/lib/kubes/cli/help.rb +11 -0
- data/lib/kubes/cli/help/completion.md +20 -0
- data/lib/kubes/cli/help/completion_script.md +3 -0
- data/lib/kubes/cli/help/deploy.md +10 -0
- data/lib/kubes/cli/init.rb +69 -0
- data/lib/kubes/cli/sequence.rb +27 -0
- data/lib/kubes/command.rb +100 -0
- data/lib/kubes/compiler.rb +71 -0
- data/lib/kubes/compiler/decorator.rb +17 -0
- data/lib/kubes/compiler/decorator/base.rb +16 -0
- data/lib/kubes/compiler/decorator/compile.rb +12 -0
- data/lib/kubes/compiler/decorator/resources/base.rb +13 -0
- data/lib/kubes/compiler/decorator/resources/container.rb +76 -0
- data/lib/kubes/compiler/decorator/resources/container/mapping.rb +28 -0
- data/lib/kubes/compiler/decorator/resources/deployment.rb +10 -0
- data/lib/kubes/compiler/decorator/resources/pod.rb +10 -0
- data/lib/kubes/compiler/decorator/resources/secret.rb +23 -0
- data/lib/kubes/compiler/decorator/write.rb +14 -0
- data/lib/kubes/compiler/dsl/core/base.rb +27 -0
- data/lib/kubes/compiler/dsl/core/blocks.rb +55 -0
- data/lib/kubes/compiler/dsl/core/fields.rb +78 -0
- data/lib/kubes/compiler/dsl/core/files.rb +28 -0
- data/lib/kubes/compiler/dsl/core/helpers.rb +4 -0
- data/lib/kubes/compiler/dsl/core/parser.rb +43 -0
- data/lib/kubes/compiler/dsl/syntax/backend_config.rb +10 -0
- data/lib/kubes/compiler/dsl/syntax/cluster_role.rb +4 -0
- data/lib/kubes/compiler/dsl/syntax/cluster_role_binding.rb +4 -0
- data/lib/kubes/compiler/dsl/syntax/config_map.rb +20 -0
- data/lib/kubes/compiler/dsl/syntax/daemon_set.rb +23 -0
- data/lib/kubes/compiler/dsl/syntax/deployment.rb +163 -0
- data/lib/kubes/compiler/dsl/syntax/ingress.rb +41 -0
- data/lib/kubes/compiler/dsl/syntax/managed_certificate.rb +18 -0
- data/lib/kubes/compiler/dsl/syntax/namespace.rb +13 -0
- data/lib/kubes/compiler/dsl/syntax/network_policy.rb +30 -0
- data/lib/kubes/compiler/dsl/syntax/pod.rb +81 -0
- data/lib/kubes/compiler/dsl/syntax/resource.rb +70 -0
- data/lib/kubes/compiler/dsl/syntax/role.rb +40 -0
- data/lib/kubes/compiler/dsl/syntax/role_binding.rb +43 -0
- data/lib/kubes/compiler/dsl/syntax/secret.rb +22 -0
- data/lib/kubes/compiler/dsl/syntax/service.rb +68 -0
- data/lib/kubes/compiler/dsl/syntax/service_account.rb +20 -0
- data/lib/kubes/compiler/layering.rb +39 -0
- data/lib/kubes/compiler/shared/helpers.rb +30 -0
- data/lib/kubes/compiler/strategy.rb +27 -0
- data/lib/kubes/compiler/strategy/base.rb +13 -0
- data/lib/kubes/compiler/strategy/dsl.rb +32 -0
- data/lib/kubes/compiler/strategy/erb.rb +42 -0
- data/lib/kubes/compiler/strategy/pass.rb +9 -0
- data/lib/kubes/compiler/strategy/result.rb +26 -0
- data/lib/kubes/compiler/util/normalize.rb +11 -0
- data/lib/kubes/compiler/util/yaml_dump.rb +23 -0
- data/lib/kubes/completer.rb +159 -0
- data/lib/kubes/completer/script.rb +6 -0
- data/lib/kubes/completer/script.sh +10 -0
- data/lib/kubes/config.rb +82 -0
- data/lib/kubes/core.rb +32 -0
- data/lib/kubes/docker/args/default.rb +39 -0
- data/lib/kubes/docker/base.rb +88 -0
- data/lib/kubes/docker/build.rb +33 -0
- data/lib/kubes/docker/push.rb +33 -0
- data/lib/kubes/hooks/builder.rb +41 -0
- data/lib/kubes/hooks/dsl.rb +19 -0
- data/lib/kubes/kubectl.rb +87 -0
- data/lib/kubes/kubectl/args/base.rb +12 -0
- data/lib/kubes/kubectl/args/kustomize.rb +28 -0
- data/lib/kubes/kubectl/args/standard.rb +32 -0
- data/lib/kubes/kubectl/batch.rb +49 -0
- data/lib/kubes/kubectl/decider.rb +15 -0
- data/lib/kubes/kubectl/kustomize.rb +13 -0
- data/lib/kubes/kubectl/ordering.rb +27 -0
- data/lib/kubes/logger.rb +26 -0
- data/lib/kubes/logging.rb +7 -0
- data/lib/kubes/util/consider.rb +9 -0
- data/lib/kubes/util/sh.rb +43 -0
- data/lib/kubes/util/sure.rb +17 -0
- data/lib/kubes/util/time.rb +14 -0
- data/lib/kubes/version.rb +1 -1
- data/lib/templates/base/.kubes/config.rb.tt +9 -0
- data/lib/templates/base/.kubes/config/env/dev.rb +6 -0
- data/lib/templates/base/.kubes/config/env/prod.rb +6 -0
- data/lib/templates/docker/Dockerfile +4 -0
- data/lib/templates/dsl/.kubes/resources/base/all.rb.tt +2 -0
- data/lib/templates/dsl/.kubes/resources/web/deployment.rb.tt +7 -0
- data/lib/templates/dsl/.kubes/resources/web/deployment/dev.rb +1 -0
- data/lib/templates/dsl/.kubes/resources/web/deployment/prod.rb +1 -0
- data/lib/templates/dsl/.kubes/resources/web/service.rb.tt +8 -0
- data/lib/templates/yaml/.kubes/resources/base/all.yaml.tt +2 -0
- data/lib/templates/yaml/.kubes/resources/base/deployment.yaml.tt +11 -0
- data/lib/templates/yaml/.kubes/resources/web/deployment.yaml.tt +24 -0
- data/lib/templates/yaml/.kubes/resources/web/deployment/dev.yaml +2 -0
- data/lib/templates/yaml/.kubes/resources/web/deployment/prod.yaml +2 -0
- data/lib/templates/yaml/.kubes/resources/web/service.yaml.tt +14 -0
- data/spec/cli_spec.rb +8 -0
- data/spec/fixtures/artifacts/demo-web/deployment.yaml +26 -0
- data/spec/fixtures/artifacts/demo-web/service.yaml +16 -0
- data/spec/fixtures/blocks/deployments.rb +9 -0
- data/spec/fixtures/decorators/deployment/configMap/envFrom.yaml +27 -0
- data/spec/fixtures/decorators/deployment/configMap/valueFrom.yaml +30 -0
- data/spec/fixtures/decorators/deployment/configMap/volumes.yaml +34 -0
- data/spec/fixtures/decorators/deployment/secret/envFrom.yaml +27 -0
- data/spec/fixtures/decorators/deployment/secret/valueFrom.yaml +30 -0
- data/spec/fixtures/decorators/deployment/secret/volumes.yaml +34 -0
- data/spec/fixtures/decorators/pod/configMap/envFrom.yaml +12 -0
- data/spec/fixtures/decorators/pod/configMap/valueFrom.yaml +16 -0
- data/spec/fixtures/decorators/pod/configMap/volumes.yaml +19 -0
- data/spec/fixtures/decorators/pod/secret/envFrom.yaml +12 -0
- data/spec/fixtures/decorators/pod/secret/valueFrom.yaml +16 -0
- data/spec/fixtures/decorators/pod/secret/volumes.yaml +19 -0
- data/spec/fixtures/deployments/minimum.rb +5 -0
- data/spec/fixtures/deployments/props.rb +7 -0
- data/spec/fixtures/deployments/setter/container.rb +11 -0
- data/spec/fixtures/deployments/setter/containers.rb +14 -0
- data/spec/fixtures/deployments/setter/metadata.rb +15 -0
- data/spec/fixtures/deployments/setter/sidecar.rb +12 -0
- data/spec/fixtures/deployments/setter/spec.rb +10 -0
- data/spec/fixtures/multiple-files/deployment-1.rb +4 -0
- data/spec/fixtures/multiple-files/deployment-2.rb +4 -0
- data/spec/fixtures/project/.gitignore +1 -0
- data/spec/fixtures/project/.kubes/resources/deployment.rb +32 -0
- data/spec/fixtures/project/.kubes/resources/foobar.rb +0 -0
- data/spec/fixtures/project/.kubes/resources/service.rb +3 -0
- data/spec/fixtures/services/minimum.rb +3 -0
- data/spec/fixtures/syntax/network_policy.rb +3 -0
- data/spec/fixtures/syntax/pod.rb +1 -0
- data/spec/kubes/compiler/decorator/resources/deployment_spec.rb +92 -0
- data/spec/kubes/compiler/decorator/resources/pod_spec.rb +92 -0
- data/spec/kubes/compiler/strategy/dsl_spec.rb +36 -0
- data/spec/kubes/compiler_spec.rb +10 -0
- data/spec/kubes/dsl/daemon_set.rb +11 -0
- data/spec/kubes/dsl/deployment_spec.rb +60 -0
- data/spec/kubes/dsl/network_policy_spec.rb +14 -0
- data/spec/kubes/dsl/pod_spec.rb +11 -0
- data/spec/kubes/dsl/service_spec.rb +12 -0
- data/spec/kubes/kubectl/batch_spec.rb +24 -0
- data/spec/spec_helper.rb +34 -0
- metadata +602 -22
- data/bin/console +0 -14
- data/bin/setup +0 -8
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Secret
|
|
3
|
+
categories: dsl
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
## Example
|
|
7
|
+
|
|
8
|
+
Here's an example of a Secret.
|
|
9
|
+
|
|
10
|
+
.kubes/resources/shared/secret.rb
|
|
11
|
+
|
|
12
|
+
```ruby
|
|
13
|
+
name "demo-secret"
|
|
14
|
+
data(
|
|
15
|
+
username: base64("user"),
|
|
16
|
+
password: base64("pass"),
|
|
17
|
+
)
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Produces:
|
|
21
|
+
|
|
22
|
+
.kubes/output/shared/service.yaml
|
|
23
|
+
|
|
24
|
+
```yaml
|
|
25
|
+
apiVersion: v1
|
|
26
|
+
kind: Secret
|
|
27
|
+
metadata:
|
|
28
|
+
name: demo-secret-cfbd534f91
|
|
29
|
+
labels:
|
|
30
|
+
app: demo
|
|
31
|
+
namespace: default
|
|
32
|
+
data:
|
|
33
|
+
username: dXNlcg==
|
|
34
|
+
password: cGFzcw==
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Suffix Hash
|
|
38
|
+
|
|
39
|
+
{% include dsl/rolling_deployment.md kind="Secret" %}
|
|
40
|
+
|
|
41
|
+
.kubes/output/web/deployment.yaml:
|
|
42
|
+
|
|
43
|
+
```yaml
|
|
44
|
+
# ..
|
|
45
|
+
spec:
|
|
46
|
+
template:
|
|
47
|
+
spec:
|
|
48
|
+
containers:
|
|
49
|
+
- name: demo-shared
|
|
50
|
+
image: nginx
|
|
51
|
+
envFrom:
|
|
52
|
+
- secretRef:
|
|
53
|
+
name: demo-secret-cfbd534f91
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
{% include dsl/suffix_hash.md %}
|
|
57
|
+
|
|
58
|
+
## Files Helper
|
|
59
|
+
|
|
60
|
+
You can use a `files` helper to load secrets values from one or more files.
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
.kubes/resources/shared/secret.rb
|
|
64
|
+
|
|
65
|
+
```ruby
|
|
66
|
+
name "demo-secret"
|
|
67
|
+
files("files/secrets.txt")
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
The `files/secrets.txt` should be in the same folder as the `secret.rb` definition. Example:
|
|
71
|
+
|
|
72
|
+
.kubes/resources/shared/files/secret.txt
|
|
73
|
+
|
|
74
|
+
SECRET1=value1
|
|
75
|
+
SECRET2=value2
|
|
76
|
+
|
|
77
|
+
You do not have to worry about base64 encoding the values. Kubes automatically base64 encodes the values.
|
|
78
|
+
|
|
79
|
+
## DSL Methods
|
|
80
|
+
|
|
81
|
+
Here's a list of more common methods:
|
|
82
|
+
|
|
83
|
+
* data
|
|
84
|
+
* stringData
|
|
85
|
+
* type
|
|
86
|
+
|
|
87
|
+
{% include dsl/methods.md name="secret" %}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Service
|
|
3
|
+
categories: dsl
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
## Example
|
|
7
|
+
|
|
8
|
+
Here's an example of a Service.
|
|
9
|
+
|
|
10
|
+
.kubes/resources/web/service.rb
|
|
11
|
+
|
|
12
|
+
```ruby
|
|
13
|
+
name "demo-web"
|
|
14
|
+
labels(role: "web")
|
|
15
|
+
namespace "default"
|
|
16
|
+
|
|
17
|
+
# Optional since these are the defaults
|
|
18
|
+
# port 80
|
|
19
|
+
# targetPort 80
|
|
20
|
+
#
|
|
21
|
+
# type "NodePort"
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
Produces:
|
|
25
|
+
|
|
26
|
+
.kubes/output/web/service.yaml
|
|
27
|
+
|
|
28
|
+
```yaml
|
|
29
|
+
---
|
|
30
|
+
apiVersion: v1
|
|
31
|
+
kind: Service
|
|
32
|
+
metadata:
|
|
33
|
+
name: demo-web
|
|
34
|
+
labels:
|
|
35
|
+
app: demo
|
|
36
|
+
namespace: demo
|
|
37
|
+
spec:
|
|
38
|
+
ports:
|
|
39
|
+
- port: 80
|
|
40
|
+
protocol: TCP
|
|
41
|
+
targetPort: 8080
|
|
42
|
+
selector:
|
|
43
|
+
app: demo
|
|
44
|
+
type: NodePort
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
## DSL Methods
|
|
48
|
+
|
|
49
|
+
Here's a list of more common methods:
|
|
50
|
+
|
|
51
|
+
* nodePort
|
|
52
|
+
* port
|
|
53
|
+
* portName: Note this field doesn't match the original field name. It's more qualified.
|
|
54
|
+
* ports
|
|
55
|
+
* protocol
|
|
56
|
+
* selector
|
|
57
|
+
* targetPort
|
|
58
|
+
* type
|
|
59
|
+
|
|
60
|
+
{% include dsl/methods.md name="service" %}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: ServiceAccount
|
|
3
|
+
categories: dsl
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
## Example
|
|
7
|
+
|
|
8
|
+
Here's an example of a ServiceAccount.
|
|
9
|
+
|
|
10
|
+
.kubes/resources/shared/service_account.rb
|
|
11
|
+
|
|
12
|
+
```ruby
|
|
13
|
+
name "demo"
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
Produces:
|
|
17
|
+
|
|
18
|
+
.kubes/output/shared/service_account.yaml
|
|
19
|
+
|
|
20
|
+
```yaml
|
|
21
|
+
apiVersion: v1
|
|
22
|
+
kind: ServiceAccount
|
|
23
|
+
metadata:
|
|
24
|
+
name: demo
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## DSL Methods
|
|
28
|
+
|
|
29
|
+
Here's a list of more common methods:
|
|
30
|
+
|
|
31
|
+
Top-level methods:
|
|
32
|
+
|
|
33
|
+
* automountServiceAccountToken
|
|
34
|
+
* imagePullSecrets
|
|
35
|
+
* secrets
|
|
36
|
+
|
|
37
|
+
{% include dsl/methods.md name="service_account" %}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Extra Environments
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Kubes adds the concept of extra environments. Let say, you have a demo-web app with a deployment and service.
|
|
6
|
+
|
|
7
|
+
.kubes/resources
|
|
8
|
+
└── web
|
|
9
|
+
├── deployment.rb
|
|
10
|
+
└── service.rb
|
|
11
|
+
|
|
12
|
+
You can create additional environments using the same resource files with a few minor changes.
|
|
13
|
+
|
|
14
|
+
* [DSL Example]({% link _docs/extra-env/dsl.md %})
|
|
15
|
+
* [YAML Example]({% link _docs/extra-env/yaml.md %})
|
|
16
|
+
|
|
17
|
+
## Deploy
|
|
18
|
+
|
|
19
|
+
Then to create an additional environment, it's simple:
|
|
20
|
+
|
|
21
|
+
KUBES_EXTRA=2 kubes deploy
|
|
22
|
+
KUBES_EXTRA=3 kubes deploy
|
|
23
|
+
# etc
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: DSL Example
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Kubes provides helper methods to make creating extra environments easy: `with_extra`. We'll create extra environments under different namespaces.
|
|
6
|
+
|
|
7
|
+
Here's how you achieve extra environments with the DSL form:
|
|
8
|
+
|
|
9
|
+
.kubes/resources/web/deployment.rb
|
|
10
|
+
|
|
11
|
+
```ruby
|
|
12
|
+
name "demo-web"
|
|
13
|
+
labels(role: "web")
|
|
14
|
+
namespace with_extra("default")
|
|
15
|
+
|
|
16
|
+
replicas 1
|
|
17
|
+
image built_image # IE: user/demo-web:kubes-2020-06-13T19-55-16-43afc6e
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
.kubes/resources/web/service.rb
|
|
21
|
+
|
|
22
|
+
```ruby
|
|
23
|
+
name "demo-web"
|
|
24
|
+
labels(role: "web")
|
|
25
|
+
namespace with_extra("default")
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
The `name` helper accounts for `KUBES_EXTRA` and appends the value.
|
|
29
|
+
|
|
30
|
+
## Deployment
|
|
31
|
+
|
|
32
|
+
Then to create an additional environment, it's simple:
|
|
33
|
+
|
|
34
|
+
kubectl create ns default-2
|
|
35
|
+
KUBES_EXTRA=2 kubes deploy
|
|
36
|
+
|
|
37
|
+
To check on the resources:
|
|
38
|
+
|
|
39
|
+
kubectl get all -n default-2
|
|
40
|
+
|
|
41
|
+
## Using Different Name Instead
|
|
42
|
+
|
|
43
|
+
The example on this page uses the `with_extra` helper to create the deployment and service in another namespace. Another approach is to use the same namespace but different names based on `KUBES_EXTRA`. We also used the `extra` helper here, which is the `KUBES_EXTRA` value. Examples:
|
|
44
|
+
|
|
45
|
+
.kubes/resources/web/deployment.rb
|
|
46
|
+
|
|
47
|
+
```ruby
|
|
48
|
+
name with_extra("demo-web")
|
|
49
|
+
labels(app: name, extra: extra)
|
|
50
|
+
namespace "default"
|
|
51
|
+
|
|
52
|
+
replicas 1
|
|
53
|
+
image built_image # IE: user/demo-web:kubes-2020-06-13T19-55-16-43afc6e
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
.kubes/resources/web/service.rb
|
|
57
|
+
|
|
58
|
+
```ruby
|
|
59
|
+
name with_extra("demo-web")
|
|
60
|
+
labels(app: name, extra: extra)
|
|
61
|
+
namespace "default"
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
Adding label with the `extra` key is optional, but helps with filtering the resources.
|
|
65
|
+
|
|
66
|
+
kubectl get all -l extra=2
|
|
67
|
+
kubectl get all -l extra=3
|
|
68
|
+
|
|
69
|
+
Example:
|
|
70
|
+
|
|
71
|
+
$ kubectl get all -l extra=2
|
|
72
|
+
NAME READY STATUS RESTARTS AGE
|
|
73
|
+
pod/demo-web-2-5f8b8cbcdc-dmbjj 1/1 Running 0 78s
|
|
74
|
+
pod/demo-web-2-5f8b8cbcdc-kg8hf 1/1 Running 0 78s
|
|
75
|
+
|
|
76
|
+
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|
77
|
+
service/demo-web-2 NodePort 172.16.158.166 <none> 80:30148/TCP 78s
|
|
78
|
+
|
|
79
|
+
NAME READY UP-TO-DATE AVAILABLE AGE
|
|
80
|
+
deployment.apps/demo-web-2 2/2 2 2 78s
|
|
81
|
+
|
|
82
|
+
NAME DESIRED CURRENT READY AGE
|
|
83
|
+
replicaset.apps/demo-web-2-5f8b8cbcdc 2 2 2 79s
|
|
84
|
+
$
|
|
85
|
+
|
|
86
|
+
The `extra` and `with_extra` helper methods provide flexibility to create these extra environments with either approach.
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: YAML Example
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Kubes provides helper methods to make creating extra environments easy: `with_extra`. We'll create extra environments under different namespaces.
|
|
6
|
+
|
|
7
|
+
Here's how you achieve extra environments with the YAML form:
|
|
8
|
+
|
|
9
|
+
.kubes/resources/web/deployment.rb
|
|
10
|
+
|
|
11
|
+
```ruby
|
|
12
|
+
---
|
|
13
|
+
apiVersion: apps/v1
|
|
14
|
+
kind: Deployment
|
|
15
|
+
metadata:
|
|
16
|
+
name: demo-web
|
|
17
|
+
labels:
|
|
18
|
+
app: demo
|
|
19
|
+
namespace: <%= with_extra("default") %>
|
|
20
|
+
spec:
|
|
21
|
+
replicas: 2
|
|
22
|
+
selector:
|
|
23
|
+
matchLabels:
|
|
24
|
+
app: demo
|
|
25
|
+
template:
|
|
26
|
+
metadata:
|
|
27
|
+
labels:
|
|
28
|
+
app: demo
|
|
29
|
+
spec:
|
|
30
|
+
containers:
|
|
31
|
+
- image: <%= built_image %>
|
|
32
|
+
name: demo-web
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
.kubes/resources/web/service.rb
|
|
36
|
+
|
|
37
|
+
```ruby
|
|
38
|
+
---
|
|
39
|
+
apiVersion: v1
|
|
40
|
+
kind: Service
|
|
41
|
+
metadata:
|
|
42
|
+
name: demo-web
|
|
43
|
+
labels:
|
|
44
|
+
app: demo
|
|
45
|
+
namespace: <%= with_extra("default") %>
|
|
46
|
+
spec:
|
|
47
|
+
ports:
|
|
48
|
+
- port: 80
|
|
49
|
+
protocol: TCP
|
|
50
|
+
targetPort: 8080
|
|
51
|
+
selector:
|
|
52
|
+
app: demo
|
|
53
|
+
type: NodePort
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
It's important to use the `with_extra` helper to set the namesapce. The helper accounts for `KUBES_EXTRA` and appends the value.
|
|
57
|
+
|
|
58
|
+
## Deployment
|
|
59
|
+
|
|
60
|
+
Then to create an additional environment, it's simple:
|
|
61
|
+
|
|
62
|
+
kubectl create ns default-2
|
|
63
|
+
KUBES_EXTRA=2 kubes deploy
|
|
64
|
+
|
|
65
|
+
To check on the resources:
|
|
66
|
+
|
|
67
|
+
kubectl get all -n default-2
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Helpers
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Kubes provides some helper methods to help write Kubernetes YAML files. Here's a list of the helper methods. These are available whether you write your resources in YAML or DSL.
|
|
6
|
+
|
|
7
|
+
Helper | Description
|
|
8
|
+
--- | ---
|
|
9
|
+
built_image | Method refers to the latest Docker image built by Kubes. This spares you from having to update the image manually in the deployment resource.
|
|
10
|
+
with_extra | Appends the `KUBES_ENV` value to a string if it's set. It's covered in the [Extra Env Docs]({% link _docs/extra-env.md %}).
|
|
11
|
+
extra | The `KUBES_ENV` value.
|
|
12
|
+
|
|
13
|
+
Here's also the source code with the helpers: [helpers.rb](https://github.com/boltops-tools/kubes/blob/master/lib/kubes/compiler/shared/helpers.rb).
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
## DSL Specific Methods
|
|
17
|
+
|
|
18
|
+
Each DSL resource has it's own specific methods. Refer to the [DSL Docs]({% link _docs/dsl.md %}) for their methods.
|
data/docs/_docs/intro.md
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: What is Kubes?
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
{% include reference.md %}
|
|
6
|
+
|
|
7
|
+
## Features:
|
|
8
|
+
|
|
9
|
+
* Automation: [Builds the Docker image]({% link _docs/config/docker.md %}) and updates the compiled YAML files
|
|
10
|
+
* Syntactic Sugar: Use an [ERB/YAML]({% link _docs/yaml.md %}) or a [DSL]({% link _docs/dsl.md %}) to write your Kubernetes YAML files. You can use a mix of DSL and YAML definitions in the `.kubes/resources` folder.
|
|
11
|
+
* Layering: Use the same Kubernetes YAML to build multiple environments like dev and prod with [layering]({% link _docs/layering.md %}).
|
|
12
|
+
* CLI Customizations: You can customize the [cli args]({% link _docs/config/kubectl.md %}). You can also run hooks before and after kubectl commands.
|
|
13
|
+
* Automated Suffix Hashes: Automatically appends a suffix hash to ConfigMap and Secret resources. More details in [ConfigMap]({% link _docs/dsl/resources/config_map.md %}) and [Secret]({% link _docs/dsl/resources/secret.md %}) docs.
|
|
14
|
+
* Kustomize Support: If you’re a kustomization user, you can use it with Kubes. More details in [Kustomize Support Docs]({% link _docs/kustomize.md %}).
|
|
15
|
+
* Auto Context Switching: Map dev to a specific kubectl context and prod to another kubectl context and Kubes can switch them automatically so you won't have to remember. More details in [Auto Context Docs]({% link _docs/auto-context.md %}).
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Kubes Concepts
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
## Resources Files
|
|
6
|
+
|
|
7
|
+
The `.kubes/resources` where you organized Kubernetes resources. Different subfolders within the resources folder represent your app. Example:
|
|
8
|
+
|
|
9
|
+
.kubes
|
|
10
|
+
└── resources
|
|
11
|
+
├── clock
|
|
12
|
+
│ └── deployment.yaml
|
|
13
|
+
├── worker
|
|
14
|
+
│ └── deployment.yaml
|
|
15
|
+
└── web
|
|
16
|
+
├── deployment.yaml
|
|
17
|
+
└── service.yaml
|
|
18
|
+
|
|
19
|
+
Each folder contains your Kubernetes deployment definition, either in [YAML]({% link _docs/yaml.md %}) or [DSL]({% link _docs/dsl.md %}) form. Both can be used together.
|
|
20
|
+
|
|
21
|
+
## Conventions Over Configuration
|
|
22
|
+
|
|
23
|
+
Kubes uses Conventions Over Configuration structure to remove boilerplate setup and mental overhead.
|
|
24
|
+
|
|
25
|
+
You can deploy just the demo-web app
|
|
26
|
+
|
|
27
|
+
kubes deploy web
|
|
28
|
+
|
|
29
|
+
Or you can deploy all 3 with:
|
|
30
|
+
|
|
31
|
+
kubes deploy
|
|
32
|
+
|
|
33
|
+
The deploy command automatically builds the Docker image and replaces the image in the YAML file with the latest built image.
|
|
34
|
+
|
|
35
|
+
## Layering
|
|
36
|
+
|
|
37
|
+
Kubes supports layering files together so you can use the same Kubernetes files to build multiple environments like dev and prod. More details in the [Layering Docs]({% link _docs/layering.md %}).
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: How Kubes Works
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Kubes is pretty straightforward. Kubes first builds the Docker image. Then it compiles Kubernetes YAML files. Lastly, it merely calls out to `kubectl`.
|
|
6
|
+
|
|
7
|
+
In fact, you can use Kubes to build the files first, and then run `kubectl` directly. Example:
|
|
8
|
+
|
|
9
|
+
kubes docker build
|
|
10
|
+
kubes docker push
|
|
11
|
+
kubes compile # compiles the .kubes/resources files to .kubes/output
|
|
12
|
+
|
|
13
|
+
Now, use `kubectl` directly. This will apply all the files:
|
|
14
|
+
|
|
15
|
+
kubectl apply --recursive -f .kubes/output
|
|
16
|
+
|
|
17
|
+
You can also selectively apply specific files:
|
|
18
|
+
|
|
19
|
+
kubectl apply -f .kubes/output/web/deployment.yaml
|
|
20
|
+
kubectl apply -f .kubes/output/web/service.yaml
|
|
21
|
+
|
|
22
|
+
You can also apply with kubes. This will compile the files automatically also.
|
|
23
|
+
|
|
24
|
+
kubes apply
|
|
25
|
+
|
|
26
|
+
The deploy command, does all 3 steps: builds the docker image, compiles the `.kubes/resources` files, and runs kubectl apply.
|
|
27
|
+
|
|
28
|
+
kubes deploy
|
|
29
|
+
|