Compare commits

..

No commits in common. "master" and "master" have entirely different histories.

12 changed files with 13 additions and 119 deletions

View File

@ -17,7 +17,6 @@ steps:
environment: environment:
APP_INI_VERSION: v1 APP_INI_VERSION: v1
DOCKER_SETUP_SH_VERSION: v1 DOCKER_SETUP_SH_VERSION: v1
PG_BACKUP_VERSION: v1
DOMAIN: gitea.swarm-test.autonomic.zone DOMAIN: gitea.swarm-test.autonomic.zone
GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION: true GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION: true
GITEA_APP_NAME: Git with solidaritea GITEA_APP_NAME: Git with solidaritea
@ -51,7 +50,7 @@ steps:
from_secret: drone_abra-bot_token from_secret: drone_abra-bot_token
fork: true fork: true
repositories: repositories:
- toolshed/auto-recipes-catalogue-json - coop-cloud/auto-recipes-catalogue-json
trigger: trigger:
event: tag event: tag

View File

@ -3,14 +3,11 @@ TYPE=gitea
DOMAIN=gitea.example.com DOMAIN=gitea.example.com
LETS_ENCRYPT_ENV=production LETS_ENCRYPT_ENV=production
COMPOSE_FILE="compose.yml" COMPOSE_FILE="compose.yml"
ENABLE_BACKUPS=true
COMPOSE_FILE="$COMPOSE_FILE:compose.mariadb.yml" COMPOSE_FILE="$COMPOSE_FILE:compose.mariadb.yml"
# COMPOSE_FILE="$COMPOSE_FILE:compose.sqlite3.yml"
# COMPOSE_FILE="$COMPOSE_FILE:compose.postgres.yml" # COMPOSE_FILE="$COMPOSE_FILE:compose.postgres.yml"
# Enable to use forgejo instead of gitea # Enable to use forgejo instead of gitea
# COMPOSE_FILE="$COMPOSE_FILE:compose.forgejo.yml" # COMPOSE_FILE="$COMPOSE_FILE:compose.forgejo.yml"
# SECRET_LFS_JWT_SECRET_VERSION=v1 # length=43
GITEA_DOMAIN=git.example.com GITEA_DOMAIN=git.example.com
GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION=true GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION=true
@ -32,9 +29,6 @@ GITEA_DEFAULT_USER_VISIBILITY=limited
GITEA_ALLOWED_USER_VISIBILITY_MODES=limited,private GITEA_ALLOWED_USER_VISIBILITY_MODES=limited,private
GITEA_DEFAULT_ORG_VISIBILITY=limited GITEA_DEFAULT_ORG_VISIBILITY=limited
GITEA_REQUIRE_SIGNIN_VIEW=true GITEA_REQUIRE_SIGNIN_VIEW=true
GITEA_ENABLE_PUSH_CREATE_USER=false
GITEA_ENABLE_PUSH_CREATE_ORG=false
GITEA_LFS_START_SERVER=false
GITEA_REPO_UPLOAD_ENABLED=true GITEA_REPO_UPLOAD_ENABLED=true
GITEA_REPO_UPLOAD_ALLOWED_TYPES=*/* GITEA_REPO_UPLOAD_ALLOWED_TYPES=*/*
@ -56,10 +50,8 @@ SECRET_SECRET_KEY_VERSION=v1 # length=64
# SMTP Mailer # SMTP Mailer
# COMPOSE_FILE="$COMPOSE_FILE:compose.smtp.yml" # COMPOSE_FILE="$COMPOSE_FILE:compose.smtp.yml"
# GITEA_SMTP_MAILER_ENABLED=1 # GITEA_SMTP_MAILER_ENABLED=1
# GITEA_MAILER_ADDR=mail.gandi.net # GITEA_MAILER_HOST=mail.gandi.net:465
# GITEA_MAILER_PORT=465
# SECRET_SMTP_PASSWORD_VERSION=v1 # SECRET_SMTP_PASSWORD_VERSION=v1
# GITEA_MAILER_PROTOCOL=smtps
# OATH2 Options # OATH2 Options
# GITEA_REGISTER_EMAIL_CONFIRM=replace-me # GITEA_REGISTER_EMAIL_CONFIRM=replace-me
@ -69,11 +61,6 @@ SECRET_SECRET_KEY_VERSION=v1 # length=64
# GITEA_ACCOUNT_LINKING=replace-me # GITEA_ACCOUNT_LINKING=replace-me
# GITEA_OAUTH2_CLIENT_ENABLED=replace-me # GITEA_OAUTH2_CLIENT_ENABLED=replace-me
# Lifetime of an OAuth2 refresh token in hours, prolly no need to edit. We
# were hitting issues with infrequently pushed to repos that were not picked
# up by drone after a month of inactivity, hence the option.
# GITEA__oauth2__REFRESH_TOKEN_EXPIRATION_TIME=730
# Indexer (for issue search) # Indexer (for issue search)
# GITEA_REPO_INDEXER_ENABLED=false # GITEA_REPO_INDEXER_ENABLED=false
# GITEA_ISSUE_INDEXER_TYPE=db # GITEA_ISSUE_INDEXER_TYPE=db

View File

@ -1,6 +1,5 @@
export APP_INI_VERSION=v21 export APP_INI_VERSION=v17
export DOCKER_SETUP_SH_VERSION=v1 export DOCKER_SETUP_SH_VERSION=v1
export PG_BACKUP_VERSION=v1
abra_backup_app() { abra_backup_app() {
_abra_backup_dir "app:/var/lib/gitea" _abra_backup_dir "app:/var/lib/gitea"

View File

@ -2,15 +2,10 @@ APP_NAME = {{ env "GITEA_APP_NAME" }}
[database] [database]
DB_TYPE = {{ env "GITEA_DB_TYPE" }} DB_TYPE = {{ env "GITEA_DB_TYPE" }}
{{ if ne (env "GITEA_DB_TYPE") "sqlite3" }}
HOST = {{ env "GITEA_DB_HOST" }} HOST = {{ env "GITEA_DB_HOST" }}
NAME = {{ env "GITEA_DB_NAME" }} NAME = {{ env "GITEA_DB_NAME" }}
PASSWD = {{ secret "db_password" }} PASSWD = {{ secret "db_password" }}
USER = {{ env "GITEA_DB_USER" }} USER = {{ env "GITEA_DB_USER" }}
{{ else }}
SQLITE_JOURNAL_MODE = {{ env "GITEA_SQLITE_JOURNAL_MODE" }}
PATH = {{ env "GITEA_PATH" }}
{{ end }}
[picture] [picture]
DISABLE_GRAVATAR = {{ env "GITEA_DISABLE_GRAVATAR" }} DISABLE_GRAVATAR = {{ env "GITEA_DISABLE_GRAVATAR" }}
@ -35,8 +30,6 @@ ENABLE_OPENID_SIGNUP = {{ env "GITEA_ENABLE_OPENID_SIGNUP" }}
[repository] [repository]
DEFAULT_BRANCH = main DEFAULT_BRANCH = main
ENABLE_PUSH_CREATE_USER = {{ env "GITEA_ENABLE_PUSH_CREATE_USER" }}
ENABLE_PUSH_CREATE_ORG = {{ env "GITEA_ENABLE_PUSH_CREATE_ORG" }}
[repository.upload] [repository.upload]
ENABLED = {{ env "GITEA_REPO_UPLOAD_ENABLED" }} ENABLED = {{ env "GITEA_REPO_UPLOAD_ENABLED" }}
@ -60,10 +53,6 @@ SSH_DOMAIN = {{ env "GITEA_DOMAIN" }}
SSH_LISTEN_PORT = {{ env "GITEA_SSH_PORT" }} SSH_LISTEN_PORT = {{ env "GITEA_SSH_PORT" }}
SSH_PORT = {{ env "GITEA_SSH_PORT" }} SSH_PORT = {{ env "GITEA_SSH_PORT" }}
START_SSH_SERVER = true START_SSH_SERVER = true
LFS_START_SERVER = {{ env "GITEA_LFS_START_SERVER" }}
{{ if eq (env "FORGE") "forgejo" }}
LFS_JWT_SECRET = {{ secret "lfs_jwt_secret" }}
{{ end }}
[security] [security]
INSTALL_LOCK = true INSTALL_LOCK = true
@ -82,12 +71,11 @@ JWT_SECRET = {{ secret "jwt_secret" }}
[mailer] [mailer]
ENABLED = true ENABLED = true
FROM = {{ env "GITEA_MAILER_FROM" }} FROM = {{ env "GITEA_MAILER_FROM" }}
PROTOCOL = {{ env "GITEA_MAILER_PROTOCOL" }} HOST = {{ env "GITEA_MAILER_HOST" }}
SMTP_ADDR = {{ env "GITEA_MAILER_ADDR" }}
SMTP_PORT = {{ env "GITEA_MAILER_PORT" }}
USER = {{ env "GITEA_MAILER_USER" }} USER = {{ env "GITEA_MAILER_USER" }}
PASSWD = {{ secret "smtp_password" }} PASSWD = {{ secret "smtp_password" }}
MAILER_TYPE = smtp MAILER_TYPE = smtp
IS_TLS_ENABLED = true
{{ end }} {{ end }}
{{ if eq (env "GITEA_OAUTH2_CLIENT_ENABLED") "1" }} {{ if eq (env "GITEA_OAUTH2_CLIENT_ENABLED") "1" }}

View File

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

View File

@ -7,15 +7,8 @@ services:
- GITEA_DB_HOST="db:3306" - GITEA_DB_HOST="db:3306"
- GITEA_DB_NAME=gitea - GITEA_DB_NAME=gitea
- GITEA_DB_USER=gitea - GITEA_DB_USER=gitea
secrets:
- db_password
db: db:
image: "mariadb:10.11.2" image: "mariadb:10.11.2"
deploy:
labels:
backupbot.backup.pre-hook: 'mysqldump --single-transaction -u root -p"$$(cat /run/secrets/db_root_password)" gitea > /var/lib/mysql/backup.sql'
backupbot.backup.volumes.mariadb.path: "backup.sql"
backupbot.restore.post-hook: "mariadb -u root -p\"$$(cat /run/secrets/db_root_password)\" gitea < /var/lib/mysql/backup.sql"
command: | command: |
mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
environment: environment:
@ -41,3 +34,4 @@ secrets:
volumes: volumes:
mariadb: mariadb:
internal:

View File

@ -7,15 +7,8 @@ services:
- GITEA_DB_HOST="db:5432" - GITEA_DB_HOST="db:5432"
- GITEA_DB_NAME=gitea - GITEA_DB_NAME=gitea
- GITEA_DB_USER=gitea - GITEA_DB_USER=gitea
secrets:
- db_password
db: db:
image: postgres:15.10 image: postgres:15.5
deploy:
labels:
backupbot.backup.pre-hook: "/pg_backup.sh backup"
backupbot.backup.volumes.db.path: "backup.sql"
backupbot.restore.post-hook: '/pg_backup.sh restore'
environment: environment:
- POSTGRES_DB=gitea - POSTGRES_DB=gitea
- POSTGRES_USER=gitea - POSTGRES_USER=gitea
@ -26,10 +19,6 @@ services:
- db:/var/lib/postgresql/data - db:/var/lib/postgresql/data
networks: networks:
- internal - internal
configs:
- source: pg_backup
target: /pg_backup.sh
mode: 0555
secrets: secrets:
db_password: db_password:
@ -38,8 +27,4 @@ secrets:
volumes: volumes:
db: db:
internal:
configs:
pg_backup:
name: ${STACK_NAME}_pg_backup_${PG_BACKUP_VERSION}
file: pg_backup.sh

View File

@ -5,10 +5,8 @@ services:
app: app:
environment: environment:
- GITEA_MAILER_FROM - GITEA_MAILER_FROM
- GITEA_MAILER_ADDR - GITEA_MAILER_HOST
- GITEA_MAILER_PORT
- GITEA_MAILER_USER - GITEA_MAILER_USER
- "GITEA_MAILER_PROTOCOL=${GITEA_MAILER_PROTOCOL:-smtps}"
secrets: secrets:
- smtp_password - smtp_password

View File

@ -1,8 +0,0 @@
version: '3.8'
services:
app:
environment:
- GITEA_DB_TYPE=sqlite3
- GITEA_SQLITE_JOURNAL_MODE=wal
- GITEA_PATH=/var/lib/gitea/gitea.db

View File

@ -3,7 +3,7 @@ version: "3.8"
services: services:
app: app:
image: "gitea/gitea:1.23.8-rootless" image: "gitea/gitea:1.21.10-rootless"
configs: configs:
- source: app_ini - source: app_ini
target: /etc/gitea/app.ini target: /etc/gitea/app.ini
@ -11,11 +11,11 @@ services:
target: /usr/local/bin/docker-setup.sh target: /usr/local/bin/docker-setup.sh
mode: 0555 mode: 0555
secrets: secrets:
- db_password
- internal_token - internal_token
- jwt_secret - jwt_secret
- secret_key - secret_key
environment: environment:
- FORGE=gitea
- GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION - GITEA_ALLOW_ONLY_EXTERNAL_REGISTRATION
- GITEA_APP_NAME - GITEA_APP_NAME
- GITEA_AUTO_WATCH_NEW_REPOS - GITEA_AUTO_WATCH_NEW_REPOS
@ -52,8 +52,6 @@ services:
- GITEA_ALLOWED_USER_VISIBILITY_MODES - GITEA_ALLOWED_USER_VISIBILITY_MODES
- GITEA_DEFAULT_ORG_VISIBILITY - GITEA_DEFAULT_ORG_VISIBILITY
- GITEA_REQUIRE_SIGNIN_VIEW - GITEA_REQUIRE_SIGNIN_VIEW
- GITEA__oauth2__REFRESH_TOKEN_EXPIRATION_TIME
- GITEA_LFS_START_SERVER=${GITEA_LFS_START_SERVER:-false}
volumes: volumes:
- data:/var/lib/gitea - data:/var/lib/gitea
- config:/etc/gitea - config:/etc/gitea
@ -73,7 +71,6 @@ services:
failure_action: rollback failure_action: rollback
order: start-first order: start-first
labels: labels:
- "backupbot.backup=${ENABLE_BACKUPS:-true}"
- "traefik.enable=true" - "traefik.enable=true"
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`)" - "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`)"
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure" - "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
@ -87,7 +84,7 @@ services:
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.accesscontrolalloworiginlist=https://${GITEA_CORS_ALLOW_DOMAIN}" - "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.accesscontrolmaxage=100"
- "traefik.http.middlewares.${STACK_NAME}_cors.headers.addvaryheader=true" - "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=2.6.2+1.21.10-rootless
networks: networks:

View File

@ -1,34 +0,0 @@
#!/bin/bash
set -e
BACKUP_FILE='/var/lib/postgresql/data/backup.sql'
function backup {
export PGPASSWORD=$(cat $POSTGRES_PASSWORD_FILE)
pg_dump -U ${POSTGRES_USER} ${POSTGRES_DB} > $BACKUP_FILE
}
function restore {
cd /var/lib/postgresql/data/
restore_config(){
# Restore allowed connections
cat pg_hba.conf.bak > pg_hba.conf
su postgres -c 'pg_ctl reload'
}
# Don't allow any other connections than local
cp pg_hba.conf pg_hba.conf.bak
echo "local all all trust" > pg_hba.conf
su postgres -c 'pg_ctl reload'
trap restore_config EXIT INT TERM
# Recreate Database
psql -U ${POSTGRES_USER} -d postgres -c "DROP DATABASE ${POSTGRES_DB} WITH (FORCE);"
createdb -U ${POSTGRES_USER} ${POSTGRES_DB}
psql -U ${POSTGRES_USER} -d ${POSTGRES_DB} -1 -f $BACKUP_FILE
trap - EXIT INT TERM
restore_config
}
$@

View File

@ -1,3 +0,0 @@
BEWARE! 🚨 This release updates to the newer Gitea SMTP settings format.
If you are using SMTP, you will need to split the old GITEA_MAILER_HOST into separate GITEA_MAILER_ADDR (hostname) and GITEA_MAILER_PORT settings.