An easy-to-use website to create submission-based challenges that will be evaluated together in real-time. Any user is allowed to create challenges with a fixed start and end date while others join and contribute. Currently supported challenges are:
- 📸 Photo Challenge
The configuration is usally located under /app/config.yaml
.
We also support configuration via environment variabels with a GC_
prefix:
GC_SERVER_PORT
GC_DB_USER
GC_DB_PASSWORD
All available configuration options:
server:
port: 8080
staticFilesDir: "./static"
db:
user: postgres
password: postgres # prefered method: use env variable GC_DB_PASSWORD
database: group_challenge
host: "localhost:5432"
poolSize: 50
logQueries: false
challenges:
liveParty:
defaultTimePerSubmissionSeconds: 45
imgProxy:
enabled: true
url: "http://localhost:8081"
localFilePath: "/tmp/group-challenge-cache"
thumbnailQuality: 90
maxThumbnailWidth: 420
maxThumbnailHeight: 420
fullSizeQuality: 75
maxFullWidth: 1280
maxFullHeight: 1280
This project includes pre-configured configuration files to launch the api, frontend, and postgres in VS Code. Alternatively you can start all services with the following commands:
- Postgres: start a postgres db at port
5432
.
mkdir /tmp/group-challenge-cache
docker compose up
- API: start the go api server at port
8080
.
cd api && go mod tidy && go run main.go
- Frontend: start the frontend at port
3000
.
cd frontend && npm i && npm run dev
For official container images visit https://github.com/subshell/group-challenge/pkgs/container/group-challenge
The container contains the frontend as well as the backend.
docker build . --tag group-challenge
Before you can run the group-challenge
container, make sure that postgresql and optionally imgProxy is running.
You can start both applications with mkdir /tmp/group-challenge-cache && docker-compose up
.
By default you can open your browser at http://localhost:8080/ to see the running group-challenge app.
docker run --network=host group-challenge
docker run --network=host ghcr.io/subshell/group-challenge:latest
The helm chart is available under https://subshell.github.io/helm-charts-lab/
helm repo add subshell-public https://subshell.github.io/helm-charts-lab
helm install -f gc-values.yaml group-challenge subshell-public/group-challenge
This chart uses the Bitnami Postgres Helm Chart as a dependency. Configure it with postgresql
in your values.yaml
file.
You definitely want to change the password using global.postgresql.postgresqlPassword
or a secret. You have to install the pgcrypto
extension manually.
- Open the browser at
http://localhost:8080
.
To reduce the size of all uploaded images, we support imgProxy. See imgProxy
for its configuration.
Take a look at this project from the subshell team. We make Sophora: a content management software for content creation, curation, and distribution. Join our team! | Imprint