From 78dad1ba31abbcc6b39569942ee698904dba9570 Mon Sep 17 00:00:00 2001 From: Lucas TESSON Date: Wed, 30 Oct 2024 17:11:39 +0100 Subject: [PATCH] docs: add YAML configuration to use cases --- README.md | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 6614d57..faf8726 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,8 @@ Coverage Status
CodeQL - OpenSSF Scoreboard + OpenSSF Scoreboard + SLSA Level 3 CTFd does not have the concept of **configuration file**, leading to **deployment complications** and the **impossibility to version configurations**. @@ -17,14 +18,37 @@ Moreover, the setup API does not exist, so we had to map it to what the frontend To fit those gaps, we built `ctfd-setup` on top of the CTFd API. This utility helps setup a CTFd instance from a YAML configuration file, CLI flags and environment variables. Thanks to this, you can integrate it using **GitHub Actions**, **Drone CI** or even as part of your **IaC provisionning**. +With `ctfd-setup` you can **setup your CTFd in a second**. + ## How to use
ctfd-setup utility used in GitHub Actions, Drone CI and Docker and Kubernetes initial container
-For the CLI configuration, please refer to the binary's specific API through `ctfd-setup --help`. -In use of IaC provisionning scenario, the corresponding environment variables are also mapped to the output, so please refer to it. +### YAML + +You can use `ctfd-setup` as a CLI tool and provision it a YAML configuration file. + +```yaml +appearance: + name: 'My CTF' + description: 'My CTF description' + +admin: + name: 'admin' + email: 'admin@super.ctf' + password: 'admin_password' + +mode: users +``` + +**We encourage you to version this file** such that re-deployment is easy (e.g., for test purposes, or in case of a catastrophic failure of the infra during the event). +Nevertheless, please do not commit the admin credentials ! Use the corresponding environment variables and provide their value from a safe secret store. + +For further configuration, please refer to the binary's specific API through `ctfd-setup --help`. + +If you are using it as part of Infra as Code provisionning, you can map the values of this configuration file to environment variables (which could ease your job). ### GitHub Actions