No description
dev | ||
doc | ||
src/dda | ||
test/dda/build | ||
.cljstyle | ||
.dir-locals.el | ||
.envrc | ||
.gitattributes | ||
.gitignore | ||
build.clj | ||
CHANGELOG.md | ||
deps.edn | ||
LICENSE | ||
Makefile | ||
pom.xml | ||
README.md | ||
tests.edn |
dda-build
chat over e-mail | meissa@social.meissa-gmbh.de | Blog | Website
Rationale
build integrates all the tools we use to work with development & clouds. We know many build tools like ant, gradle, mvn, make, leiningen or pybuilder.
But we have chosen to create & use one more due to this reasons:
- No immature scripting languages: Our builds tend to be complex. So we decided that implementing build is worth to be done in real dev-language like clojure.
- Fast runtime: We like runtime with simple setup & fast startup. For this reason we've chosen babashka
- Input validation: We believe in good input validation & good messages. For this reason we use the coole clojure-spec for build config.
- Fast feedback: The DevOps experience local compared to CI should be as equal as possible. We like working local for fast feedback cycles.
- No source pollution: All generation stuff happens in a separated build dir.
- Tool Support: As DevOps we are using many tools, all of them should be supported:
- gitops & direnv: State of environments and systems is represented by a git repo. State is applied automatically.
- terragrunt + opentofu: For setting up the plain infrastructure around.
- docker + podman: For creating images
- c4k-* or helm: For generating kubernetes manifests
- provs: For one-shoot setup small single-node k3s clusters and a first application.
- gopass: For credential management on devops computers
- cloud providers: hetzner, digitalocean or aws
Status
Unstable
Try out
We use direnv for setting the environments:
export STAGE=test
export HETZNER_API_KEY=$(gopass show path-to-hetzner-api-token)
export DO_API_KEY=$(gopass show path-to-do-api-key)
export DO_SPACES_ACCESS_ID=$(gopass show path-to-do-s3-key id)
export DO_SPACES_SECRET_KEY=$(gopass show path-to-do-s3-key secret)
export TERRAGRUNT_TFPATH=tofu
export TERRAGRUNT_DOWNLOAD=~/.terragrunt
export TERRAGRUNT_PROVIDER_CACHE=1
Build taske looks like this:
{:deps {org.clojure/spec.alpha {:mvn/version "0.4.233"}
orchestra/orchestra {:mvn/version "2021.01.01-1"}
org.domaindrivenarchitecture/build {:mvn/version "0.1.1-SNAPSHOT"}}
:tasks
{:init (do (def project {:name "test"
:module (first *command-line-args*)
:project-root-path "../../.."
:build-dir-name "target"
:version "4.11.8-dev"
:debug true}))
plan
{:requires ([dda.build.terragrunt :as tg])
:task (tg/plan! project)}
apply
{:requires ([dda.build.terragrunt :as tg])
:task (tg/apply! project)}
destroy
{:requires ([dda.build.terragrunt :as tg])
:task (tg/destroy! project)}}}
Execute the build
bb plan [module]
The gitops dir layout looks like
.
├── infrastructure
│ └── tenant
│ ├── prod
│ └── test
│ ├── bb.edn
│ ├── jitsi
│ │ ├── main.tf
│ │ └── terragrunt.hcl
│ ├── statistics
│ │ ├── main.tf
│ │ └── terragrunt.hcl
│ └── terragrunt.hcl
├── modules
│ └── app
│ ├── main.tf
│ ├── registry.tf
│ ├── remote_state.tf
│ └── variables.tf
└── target
└── test
├── jitsi
│ ├── generated_backend.tf
│ ├── generated_provider.tf
│ ├── generated_registry.tf
│ ├── generated_variables.tf
│ ├── main.tf
│ └── terragrunt.hcl
└── terragrunt.hcl
Development & mirrors
Development happens at: https://repo.prod.meissa.de/meissa/build
Mirrors are:
- https://codeberg.org/meissa/dda-build (Issues and PR)
- https://gitlab.com/domaindrivenarchitecture/dda-build (CI)
For more details about our repository model see: https://repo.prod.meissa.de/meissa/federate-your-repos
License
Copyright © 2024 meissa GmbH Licensed under the Apache License, Version 2.0 (the "License") Pls. find licenses of our subcomponents here