Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/telkomindonesia/ddcompose
https://github.com/telkomindonesia/ddcompose
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/telkomindonesia/ddcompose
- Owner: TelkomIndonesia
- Created: 2022-08-05T06:54:36.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-02-01T08:36:29.000Z (almost 2 years ago)
- Last Synced: 2023-03-05T12:50:56.700Z (almost 2 years ago)
- Language: CUE
- Size: 53.7 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# DDCompose
A [Dagger](https://dagger.io/) module for managing and deploying [Docker Compose](https://docs.docker.com/compose/) manifests through SSH connection.
## Getting Started
1. [Initiate](https://docs.dagger.io/1239/making-reusable-package#create-the-base-dagger-project) a dagger project.
1. Create `manifests` directory under root fo the project directory and puts all docker compose and all related files there. You can create as many subfolder as needed.
1. Create `.ssh` folder that _at minimum_ contains ssh private key named `id_rsa`.
1. Import and unify the [`#DDCompose.plan`](./ddcompose.cue#L15) with [`dagger.#Plan`](https://docs.dagger.io/1202/plan)
1. Fill [`#DDCompose.manifests`](./ddcompose.cue#L8) with information related to all manifests in `manifests` directory. See [#Manifest](./input.cue#L8) for all avaialable fields.
1. Execute `dagger do deploy` to deploy all defined manifests.### Example
Suppose there is an `awesome-service` with the following docker compose related files:
```bash
$ find manifests
manifests
manifests/host1.example.test/awesome-service
manifests/host1.example.test/awesome-service/settings.conf
manifests/host1.example.test/awesome-service/docker-compose.yml
```To deploy this manifest to `host1.example.test` and put all the manifest files inside `/opt/docker/awesome-service`, the cue file should look like this
```cue
package mainimport (
"dagger.io/dagger""github.com/telkomindonesia/ddcompose"
)dagger.#Plan & (ddcompose.#DDCompose & { manifests: [
{
name: "awesome-service"
path: "host1.example.test/awesome-service"
remoteHost: "host1.example.test"
remotePath: "/opt/docker/awesome-service"
},
]}).plan
```Checkout [examples](./examples/) for more sample on how to use this module.
### The `deploy` action
The `deploy` actions is composed with sub-actions structured in the following manner:
- `deploy` : `` : `` : `` : ``
This allow for controlling which manifest(s) to be deployed. For example:
- `dagger do deploy awesome-service` will deploy all manifest named `awesome-service`.
- `dagger do deploy awesome-service host1.example.test` will deploy all manifest named `awesome-service` only to `host1.example.test`.
- `dagger do deploy awesome-service host1.example.test /opt/docker/awesome-service` will deploy all manifest named `awesome-service` only to `host1.example.test` and only to path `/opt/docker/awesome-service`.#### Manifest Files Synchronization
Since 0.8.0, synchronization is done using rsync with `--delete` flag. Exclusion is possible by creating `.rsync-exclude` file inside the root dir of each manifest path, which will be passed as argument to `--exclude-from` flag.
#### Docker config
Under the hood, the `deploy` action wraps `docker compose` command to deploy the manifest. To add additional config for the docker client (such as authentication for remote registry), set [`#DDCompose.docker.config`](/ddcompose.cue#14) to `true` and put the config inside `.docker/config.json`.
#### Local Docker Daemon
It is also possible to deploy the manifest to the local host where the command is executed. To do this, do not set the `remoteHost` `remotePath` attribute of the manifest.
In this mode, a docker volume will be generated that will contain the modified manifest filesß. This volume can then be used in docker-compose by using `DDCOMPOSE_MANIFEST_VOLUME` env variable, for example
```yaml
services:
certain-service:
volumes:
- ${DDCOMPOSE_MANIFEST_VOLUME:-.}:/src
```### The `fenvname` action
The `fenvname` action is used to generate a text file containing a list of files or folders inside `manifests` folders with their respective generated-variable name. This variable name can be included in docker compose file to force recreate the related container when the content of the correlated file or folder changes. See [examples](./examples/simple-with-builders/manifests/service/) for more detail on how to include the [fenv](./examples/simple-with-builders/_output/fenv.txt) inside [docker compose file](./examples/simple-with-builders/manifests/service/docker-compose.yml#L6).
### SOPS decryption
The module support automatic file decryption for all files with `__sops__` prefix encountered inside `manifests` dir using [sops](https://github.com/mozilla/sops) and [age](https://github.com/FiloSottile/age) encryption. To enable this feature, set [`#DDCompose.sops.age`](./ddcompose.cue#L11) to `true` and put the private key inside `.sops/age/keys.txt` file.
### Manifest builders
An optional action named `build` can be enabled by setting [`#DDCompose.builders`](./ddcompose.cue#L13) to `true` which allow an execution of [terraform](https://github.com/hashicorp/terraform) scripts inside `builders` folder. During execution, the terraform scripts will have access to the manifests directory whose path can be accessed by defining a variable named [`manifests_dir`](./terraform.cue#L75).
If `#DDCompose.sops.config` is set to `true` (which require `.sops.yaml` file to be available on the root directory), then `terraform.tfstate` will be encrypted as `__sops__terraform.tfstate` after each execution and the original `terraform.tfstate` will be deleted. See [examples](./examples/simple-with-builders/builders/) for more detail.