Skip to content
This repository has been archived by the owner on Dec 3, 2024. It is now read-only.

Latest commit

 

History

History
175 lines (141 loc) · 8.26 KB

README.md

File metadata and controls

175 lines (141 loc) · 8.26 KB

ArgoCD resources for my homelab

This repository is part of my homelab_v2 setup, please check the following repository for more information: https://github.com/diademiemi/homelab_v2

The project is structured with two main directories: manifests and helm. These directories contain the manifests and helm charts to be deployed.

Helm values files and manifest directories are called either local or cloud to determine which environment they are for.

Directory structure
├── helm/[1]
│   ├── namespace/
│   │   ├── project/
│   │   │   ├── chart/
│   │   │   │   ├── Chart.yaml
│   │   │   │   ├── Chart.lock
│   │   │   │   ├── values.yaml (optional)
│   │   │   │   ├── templates/
│   │   │   ├── values/
│   │   │   │   ├── local.yaml[2]
│   │   │   │   ├── cloud.yaml
├── manifests/[1]
│   ├── namespace/
│   │   ├── project/
│   │   │   ├── prod/[3]
│   │   │   │   ├── manifest01.yaml
│   │   │   │   ├── manifest02.yaml
├── projects/[4]
│   ├── prod.yaml
│   ├── stage.yaml (optional)
│   ├── test.yaml (optional)
│   ├── dev.yaml (optional)

[1] The manifests and helm directories are split into namespaces, projects and environments.
[2] For Helm, the environments are found in the values directory. An Application is made when a file called cloud.yaml/local.yaml (Or other environment) is found in a directory of a project.
[3] For manifests, an Application is made when a directory called cloud/local (Or other environment) is found in a directory of a project.
[4] The projects directory contains the ApplicationSets to deploy the applications.

Some files in this repository are encrypted with SOPS. They are using the age encryption method.

Secrets can be managed with SOPS.
There is a SOPS plugin for Kustomize which makes ArgoCD automatically decrypt the secrets when given a key. You can read more about this in This Red Hat Article

To read more about manifests, see #manifests.

Make sure you have kustomize, sops and age installed on your machine.

Follow the instructions here to install the plugin for kustomize on your machine. Set $XDG_CONFIG_HOME to ~/.config if it is not set.

Generate a new age keypair.

age-keygen -o <path to age private key file>

This will return a public key and write the private key to the file. Make sure not to commit the private key to the repository, and keep it safe.

To use SOPS in this repository, create a .sops.yaml in the root of the repository.

creation_rules:
  - path_regex: .*\.sops\.ya?ml
    encrypted_regex: "^(data|stringData)$"
    age: <age publickey>

This will encrypt the data or stringData fields in all files ending in .sops.yaml or .sops.yml with the age public key. You will need the private key to decrypt the secrets.

Create a kustomization.yaml file in the environment directory.

generators:
  - ./kustomize-secret-generator.yaml

Create a kustomize-secret-generator.yaml file in the project/environment directory. Where the files key is a list of files to encrypt/decrypt with SOPS.

apiVersion: viaduct.ai/v1
kind: ksops
metadata:
  # Specify a name
  name: sops-secret-generator
files:
  - ./secret-manifest.sops.yaml

Encrypt the secret manifest file with SOPS. This will use the age public key in the .sops.yaml file.

sops --encrypt --in-place ./secret-manifest.sops.yaml

Decrypt the secret manifest file with SOPS.

export SOPS_AGE_KEY_FILE=<path to age private key file> 
sops --decrypt --in-place ./secret-manifest.sops.yaml

Make sure to encrypt any secrets before committing them to a repository!

Manifests are stored in the manifests directory. They are processed as follows:

Directory structure
manifests/cert-manager/deploy/cloud/manifest.yaml
│         │       │      │    │
│         │       │      │    └─── manifest file
│         │       │      └──────── environment
│         │       └─────────────── project
│         └─────────────────────── namespace
└───────────────────────────────── root

Kustomize may also be used if a kustomization.yaml file is present in the environment directory. Be aware that this will cause Kustomize to manage the entire directory, so any manifests not configured in the kustomization.yaml will be ignored.

Helm charts are stored in the helm directory. They are processed as follows:

Directory structure
helm/cert-manager/deploy/chart/Chart.yaml
│    │       │              │     │
│    │       │              │     └─── helm chart file
│    │       │              └───────── chart directory
│    │       └──────────────────────── project
│    └──────────────────────────────── namespace
└───────────────────────────────────── root
helm/cert-manager/deploy/values/cloud.yaml
│    │       │      │      │
│    │       │      │      └─── values file
│    │       │      └────────── environment
│    │       └───────────────── project
│    └───────────────────────── namespace
└────────────────────────────── root

To use external helm charts, add them under dependencies in the Chart.yaml file. The Chart.yaml must still be a valid helm chart, so you will need to pass values like apiVersion, name, description and version.
This will include the helm chart as a subchart in the chart. Be aware that values for the subchart will need to be scoped to the subchart. For example, for cert-manager, the usual values would be:

installCRDs: true

But when it is included as a subchart called cert-manager, the values would be:

cert-manager:
  installCRDs: true

You can find more information about this in the Helm documentation.

Projects are stored in the projects directory. They are processed as follows:

Directory structure
projects/cloud.yaml
│        │
│        └─── project file of this environment
└──────────── root

The ApplicationSets in this file will traverse the manifests and helm directories and search for files matching values/cloud.yaml and manifests with a cloud/ directory. Application objects will be created using a combination of the namespace, project and environment retrieved from these filenames.
For more information, read through the ApplicationSet documentation and the cloud.yaml file.