Getting started¶
Prerequisites¶
- A Kubernetes cluster
- [Optional for testing, necessary for production use] A storage bucket in a cloud provider (AWS, GCP, Azure)
- [Optional, recommended for production use] cert-manager installed in your cluster (for internal encryption of plans and logs & provider cache)
Requirements¶
- helm CLI
- Have a kubeconfig file (default location is
~/.kube/config
) to access your Kubernetes cluster
1. Install Burrito¶
Copy and modify the default values to match your requirements.
Make sure to configure a tenant by updating the tenant
field in the values.yaml
file. The associated namespace will be created automatically and used to deploy Burrito resources in step 3.
For example, here is a default values.yaml
file:
config:
datastore:
storage:
mock: true
tenants:
- namespace:
create: true
name: "burrito-project-1"
serviceAccounts:
- name: "runner-project-1"
Info
To try Burrito without setting up a remote storage, set the config.burrito.datastore.storage.mock
field to true
in the values.yaml
file. To persist data such as Terraform logs, you must configure a storage bucket field. Make sure to specify a service account that has the necessary permissions to read/write to your remote bucket.
Then, install Burrito using the following command:
helm install burrito oci://ghcr.io/padok-team/charts/burrito --create-namespace -n burrito-system -f ./values.yaml
This will create a new namespace, burrito-system
, where Burrito services will be deployed.
2. Create a connection to a private repository¶
Create a Kubernetes Secret
to reference the necessary credentials to clone your IaC repository (GitHub or GitLab)
Info
Supported authentication methods are:
- Username and password
- SSH private key
- GitHub App
- GitHub API token
- GitLab API token
More information on how to create a secret can be found in the Git Authentication section.
kind: Secret
metadata:
name: burrito-repo
namespace: <tenant-namespace>
type: Opaque
stringData:
username: <my-username>
password: <my-password | my-access-token>
sshPrivateKey: |
-----BEGIN OPENSSH PRIVATE KEY-----
...
-----END OPENSSH PRIVATE KEY-----
Then, create a TerraformRepository
Kubernetes resource. The spec.terraform.enabled
sets the repository as a Terraform repository (as opposed to an OpenTofu repository). This setting will propagate to all layers linked to this repository by default, but can be overridden at the layer level.
apiVersion: config.terraform.padok.cloud/v1alpha1
kind: TerraformRepository
metadata:
name: burrito
namespace: <tenant-namespace>
spec:
repository:
url: <https-or-ssh-repository-url>
secretName: burrito-repo
terraform:
enabled: true
Info
You can also connect to a public repository by omitting spec.repository.secretName
in your TerraformRepository
definition.
3. Synchronize a Terraform layer¶
After creating a TerraformRepository
you can create a TerraformLayer
resource which looks like:
apiVersion: config.terraform.padok.cloud/v1alpha1
kind: TerraformLayer
metadata:
name: random-pets
namespace: burrito
spec:
terraform:
version: "1.3.1"
path: "internal/e2e/testdata/terraform/random-pets"
branch: "main"
repository:
name: burrito
namespace: burrito
The controller will create a runner pod in your tenant namespace to synchronize the repository and apply the Terraform code.
Guides¶
- For detailed guides on how to use Burrito, see the Guides section.
- To learn more about advanced configuration and features, see the Operator Manual section.