Compare commits

...

20 Commits

Author SHA1 Message Date
f
6a0339d3f2 BREAKING CHANGE: remove forgejo 2026-06-16 18:33:21 -03:00
ce4de9e645 Merge pull request 'feat: support Git LFS on plain gitea' (#57) from lfs into master
Some checks failed
continuous-integration/drone/push Build is failing
Reviewed-on: #57
Reviewed-by: ammaratef45 <ammaratef45@proton.me>
2026-06-15 21:08:52 +00:00
357926f26e feat: support Git LFS on plain gitea
All checks were successful
continuous-integration/drone/tag Build is passing
Add an opt-in compose.lfs.yml that mounts the lfs_jwt_secret secret and
enables GITEA_LFS_START_SERVER for plain gitea (forgejo already bundles
LFS). Emit LFS_JWT_SECRET in app.ini whenever the LFS server is on so the
JWT secret is stable across redeploys instead of being regenerated on
every restart (app.ini is a read-only config mount).

Bump version 3.5.2 -> 3.6.0.
2026-06-15 19:33:03 +00:00
e6a1cc79e9 Merge pull request 'change deploy logic to stop-first instead of start-first' (#53) from stop-first into master
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/tag Build is passing
Reviewed-on: #53
2026-06-04 16:47:00 +00:00
34dd04ac99 Merge branch 'master' into stop-first 2026-06-04 16:46:28 +00:00
6aa52c1e73 fix abra command in documentation
Some checks failed
continuous-integration/drone/push Build is failing
2026-05-19 03:43:34 +00:00
e7c4999f78 bump version number to 3.5.3 2026-05-18 12:59:07 -04:00
c63e1cdd04 change deploy logic to stop-first instead of start-first 2026-05-18 12:51:20 -04:00
3wc
db92e97071 docs: Fix broken README links, appease markdown linter 2026-01-08 21:29:48 -05:00
d86d742ed1 Adds missing access controll headers
All checks were successful
continuous-integration/drone/push Build is passing
2025-10-27 18:29:54 +01:00
f
989294173e chore: publish 3.5.2+1.24.2-rootless release
All checks were successful
continuous-integration/drone/tag Build is passing
continuous-integration/drone/push Build is passing
2025-09-01 07:44:54 -03:00
f
4e789bf977 fix: forgejo 12.0.2 2025-09-01 07:38:52 -03:00
f
485fa32512 chore: publish 3.5.1+1.24.2-rootless release
All checks were successful
continuous-integration/drone/tag Build is passing
continuous-integration/drone/push Build is passing
2025-07-26 01:35:54 -03:00
f
54fd30f38a fix: forgejo 12.0.1 2025-07-26 01:33:48 -03:00
f
6d586f6ad3 chore: publish 3.5.0+1.24.2-rootless release
All checks were successful
continuous-integration/drone/tag Build is passing
continuous-integration/drone/push Build is passing
2025-07-19 11:42:35 -03:00
f
8c9793ace9 feat: upgrade to forgejo 12 2025-07-19 11:41:41 -03:00
3wc
4cfc2ac2e0 chore: publish 3.4.0+1.24.2-rootless release
All checks were successful
continuous-integration/drone/tag Build is passing
continuous-integration/drone/push Build is passing
2025-06-25 18:34:34 +01:00
f
ca4733a0b0 fix: upgrade forgejo to 11.0.2
All checks were successful
continuous-integration/drone/push Build is passing
2025-06-19 10:26:08 -03:00
5a65ef04c5 Merge pull request 'feat: forgejo 11' (#45) from forgejo into master
All checks were successful
continuous-integration/drone/push Build is passing
Reviewed-on: #45
2025-06-19 13:21:57 +00:00
f
94af9cea9e feat: forgejo 11 2025-05-15 14:36:29 -03:00
7 changed files with 33 additions and 20 deletions

View File

@ -8,8 +8,9 @@ COMPOSE_FILE="$COMPOSE_FILE:compose.mariadb.yml"
# COMPOSE_FILE="$COMPOSE_FILE:compose.sqlite3.yml"
# COMPOSE_FILE="$COMPOSE_FILE:compose.postgres.yml"
# Enable to use forgejo instead of gitea
# COMPOSE_FILE="$COMPOSE_FILE:compose.forgejo.yml"
# Enable Git LFS on plain gitea (not needed with forgejo, which bundles it).
# Mounts the lfs_jwt_secret secret and sets GITEA_LFS_START_SERVER=true.
# COMPOSE_FILE="$COMPOSE_FILE:compose.lfs.yml"
# SECRET_LFS_JWT_SECRET_VERSION=v1 # length=43
GITEA_DOMAIN=git.example.com

View File

@ -15,7 +15,7 @@
## Basic usage
1. Set up Docker Swarm and [`abra`][abra]
1. [Set up Docker Swarm and `abra`][operators-tutorial]
2. Deploy [`coop-cloud/traefik`][cc-traefik]
3. `abra app new gitea --secrets` (optionally with `--pass` if you'd like
to save secrets in `pass`)
@ -23,12 +23,15 @@
your Docker swarm box
5. `abra app deploy YOURAPPDOMAIN`
[operators-tutorial]: https://docs.coopcloud.tech/operators/tutorial/
[cc-traefik]: https://git.coopcloud.tech/coop-cloud/traefik/
## Create first user
Run
```bash
abra app run YOURAPPNAME app gitea -c /etc/gitea/app.ini admin user create --username USERNAME --admin --random-password --email EMAIL
abra app run YOURAPPNAME app -- gitea -c /etc/gitea/app.ini admin user create --username USERNAME --admin --random-password --email EMAIL
```
See the [Gitea command-line documentation](https://docs.gitea.io/en-us/command-line/) for more options. Make sure not to forget the `-c /etc/gitea/app.ini`.
@ -36,25 +39,34 @@ See the [Gitea command-line documentation](https://docs.gitea.io/en-us/command-l
## Enable SSH
You most certainly want to be able to access your repository over SSH. To do so, make sure you uncomment the right lines in the configuration for `traefik`.
```
```sh
abra app config YOURTRAEFIKAPP
```
There uncomment or add these lines:
```
```sh
GITEA_SSH_ENABLED=1
COMPOSE_FILE="compose.yml:compose.gitea.yml"
```
Then redeploy traefik:
```
```sh
abra app undeploy YOURTRAEFIKAPP
abra app deploy YOURTRAEFIKAPP
```
You might need to wait a bit. To check if it worked, you can run
```
```sh
telnet my.gitea.example.com 2222
```
Once you have added a public SSH key, you can check that you can connect to your gitea server with
```
```sh
ssh -T -p 2222 git@my.gitea.example.com
```

View File

@ -1,4 +1,4 @@
export APP_INI_VERSION=v21
export APP_INI_VERSION=v22
export DOCKER_SETUP_SH_VERSION=v1
export PG_BACKUP_VERSION=v1

View File

@ -61,7 +61,7 @@ SSH_LISTEN_PORT = {{ env "GITEA_SSH_PORT" }}
SSH_PORT = {{ env "GITEA_SSH_PORT" }}
START_SSH_SERVER = true
LFS_START_SERVER = {{ env "GITEA_LFS_START_SERVER" }}
{{ if eq (env "FORGE") "forgejo" }}
{{ if (eq (env "GITEA_LFS_START_SERVER") "true") }}
LFS_JWT_SECRET = {{ secret "lfs_jwt_secret" }}
{{ end }}

View File

@ -1,12 +1,12 @@
version: '3.8'
version: "3.8"
services:
app:
image: codeberg.org/forgejo/forgejo:10.0.1-rootless
environment:
- FORGE=forgejo
- GITEA_LFS_START_SERVER=true
secrets:
- lfs_jwt_secret
- lfs_jwt_secret
secrets:
lfs_jwt_secret:
name: ${STACK_NAME}_lfs_jwt_secret_${SECRET_LFS_JWT_SECRET_VERSION}

View File

@ -10,7 +10,7 @@ services:
secrets:
- db_password
db:
image: postgres:15.10
image: postgres:15.13
deploy:
labels:
backupbot.backup.pre-hook: "/pg_backup.sh backup"

View File

@ -3,7 +3,7 @@ version: "3.8"
services:
app:
image: "gitea/gitea:1.23.8-rootless"
image: "gitea/gitea:1.24.2-rootless"
configs:
- source: app_ini
target: /etc/gitea/app.ini
@ -15,7 +15,6 @@ services:
- jwt_secret
- secret_key
environment:
- FORGE=gitea
- GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION
- GITEA_APP_NAME
- GITEA_AUTO_WATCH_NEW_REPOS
@ -71,7 +70,7 @@ services:
deploy:
update_config:
failure_action: rollback
order: start-first
order: stop-first
labels:
- "backupbot.backup=${ENABLE_BACKUPS:-true}"
- "traefik.enable=true"
@ -84,10 +83,11 @@ services:
- "traefik.tcp.services.${STACK_NAME}-ssh.loadbalancer.server.port=${GITEA_SSH_PORT}"
- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}_cors"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.accesscontrolallowmethods=GET,OPTIONS,PUT"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.accesscontrolallowheaders=content-type,authorization"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.accesscontrolalloworiginlist=https://${GITEA_CORS_ALLOW_DOMAIN}"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.accesscontrolmaxage=100"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.addvaryheader=true"
- coop-cloud.${STACK_NAME}.version=3.3.1+1.23.8-rootless
- coop-cloud.${STACK_NAME}.version=3.6.0+1.24.2-rootless
networks: