Skip to content

An example repository to illustrate how configuration files can be version controlled and served using the 'simple-configuration-server', using CI/CD to test the configuration and build the server docker image.

License

Notifications You must be signed in to change notification settings

simple-configuration-server/example-configuration

Repository files navigation

SCS Example Configuration Repository

This repository contains an example of how you can version-control simple system configurations and host them using the Simple Configuration Server (SCS). It contains examples of using CI/CD and githooks to validate configurations prior to deployment, and build a SCS docker image that includes the configuration. This repository only showcases a subset of the features of SCS. For a full description of the possibilities of SCS, please see the SCS Website

Note that this repository is meant as an example, and should not be copied directly. If you want to apply the structure described in this repository in your own project, you have to review all settings and configuration files. Considerations for deployment can be found on the SCS Website.

1. Contents

This repository contains the following:

  • .githooks/: Folder containing a pre-commit githook to run the SCS validation script locally using Docker, so the integrity of the files is validated before a commit.
  • configuration/: Folder containing all configuration files for the SCS, with the exception of secrets, since secrets should never be stored in a git repository. For a description of what every configuration file does, please read the server configuration documentation and configuration validation documentation.
  • .github/workflows/main.yml: An example CI/CD configuration for GitHub actions, that builds a Docker image with the configuration, and uses the included validation script to validate the configuration.
  • .gitlab-ci.yml: An example GitLab CI/CD configuration that's functionally equivalent to the GitHub configuration
  • Dockerfile: Example of you can build a Docker image that includes the configuration from this repository. This is used by the CI/CD pipeline to built the image.
  • docker-compose.yml: Example docker docker-compose configuration that uses the image build using CI/CD to create and start a Docker container
  • enable_githooks.sh: Simple convenience script to enable pre-commit tests for the repository

WARNING: Don't store secrets in GIT
It is bad practice to store secrets in git repositories. In case you run the 'validate' script, scs-configuration.yaml contains a 'directories.secrets' variable and this directory is not empty, validation will fail. Although this example does include 'scs-users.yaml', all tokens are sourced from a secrets file (using the !scs-secret yaml tag) that is not in this repository. Based on your own consideration, you can also choose not to include 'scs-users.yaml' in your repository, since this is not required to run the 'validate' script. An SSL private key is also considered a secret and should never be in a git repository.

1.1 Configuration directories

This /common and /endpoints directories provide some examples of how to structure your data and endpoints in SCS.

1.1.1 common/

The common directory can be used to store configuration variables that are used by multiple endpoints, as described in the documentation.

The configuration/common directory contains some examples of how this directory can be used:

  • remote-files/: This is an example of how configuration files from other sources, such as other git repositories, can be used by SCS. You can for example choose to include a global configuration file describing the properties of different environments, as a git submodule inside your configuration repository
  • users/: Another example where a 'common' directory comes in handy, is to specify users of one or multiple systems in a central location. In this example the elasticsearch.yaml contains all user-data, which is used in the /elasticsearch/create_users.json endpoint as well as in the endpoints for individual servers (e.g. /servers/first/es-credentials.json).
  • global.yaml: Another example is just having a simple global configuration file, so you can specify variables in one place.

1.1.2 endpoints/

The endpoints directory defines the server endpoints as described in the documentation.

The configuration/endpoints directory contains some different examples of how you can structure the endpoints of your SCS deployment. For example you can use paths for specific systems (elasticsearch/), paths for specific servers (servers/) and a section with global variables accessible by all users (var/).

Note since you have to define path authorizations for each user in scs-users.yaml (If you're using the built-in SCS auth module), you should design your configuration directory structure in such a way that you can authorize users properly.

Below is a list of the functionality illustrated by some of the endpoints:

  • /var/hostname-prefix: this is the simplest way an endpoint can be defined. It uses no templating features, but rather just contains a constant.
  • /elasticsearch/jvm.custom.options: This endpoint only allows POST requests. Note that the 'heap_size_gb' variable is not set in the env file, and therefore needs to be provided in a POST request JSON body. By default, all endpoints allow GET and POST requests by default, allowing you to override any context variables.
  • /elasticsearch/create_users.json && /servers/first/es-credentials.json: The ElasticSearch users defined in the 'common' directory are used by ElasticSearch to determine the users to create, and each server can only retrieve the user data for that server specifically.
  • /var/domains-redirect: By setting a 301 status code and the Location header, you can create redirects (Please consider the note in the env file before implementing this)
  • /var/domain-name: This does not have an env file specifically for this endpoint, but rather uses the 'domains' variable from the root-level scs-env file.

2 Usage

2.1 CI/CD

The GitHub workflow definition file contains the steps that are executed on GitHub each time a new git tag is added to the repository. Each time, a new Docker image is built including the configuration in this repository, having the version number of the git tag. After building, the 'validate.py' script is run in the container to test if the configuration is valid. When valid, the Docker image is uploaded to the GitHub Container Registry.

For GitLab users, and equivalent CI/CD configuration can be found in .gitlab-ci.yml.

2.2 Running the Docker container

The docker-compose.yml file contains an example configuration for running a docker container using the Docker image that is built by the CI/CD pipeline.

Since secrets are not included in the repository, they are added to the container using a bind-mount from the .local/secrets directory. If you want to test the Docker image generated from this repository locally, open a terminal window on a Linux or Mac machine and do

mkdir -p .local/secrets
# Note .TEMPLATE is included in the filename to prevent people from mounting
# them directly in Docker, and risk storing secrets to the repository on the
# next commit
cp ./templates/secrets/elasticsearch.TEMPLATE.yaml ./.local/secrets/elasticsearch.yaml
cp ./templates/secrets/scs-tokens.TEMPLATE.yaml ./.local/secrets/scs-tokens.yaml
docker compose up -d # Run it on the background

Note you need to have docker and docker compose (v2) installed

Since all 'secrets' in the above YAML templates use the '!scs-gen-secret' tag, these are auto-generated and saved when first running the container.

Now you can use e.g. curl to get data from the server. Note that you can find the token for the superuser in your .local/secrets/scs-tokens.yaml file:

curl --header "Authorization: Bearer SUPERUSER_TOKEN" http://127.0.0.1:3000/configs/var/timezone

Run docker compose down to remove the container again.

3 Development

Before commiting any changes to the repositories, make sure to run the ./enable_githooks.sh script to ensure the pre-commit tests are run.

To trigger the build of a new Docker container, assign a git tag to your commit and push it to GitHub, e.g.: git tag 1.2.3 && git push --tags (Note that prior to doing this you need to have pushed your commits already).

About

An example repository to illustrate how configuration files can be version controlled and served using the 'simple-configuration-server', using CI/CD to test the configuration and build the server docker image.

Resources

License

Stars

Watchers

Forks

Packages