Gitea repo init; Woodpecker pipeline init; much CI/CD structure outlined in ./infra, incl. docker-compose.yaml, cicd-playbook.yaml, new cicd vault, & config files for gitea, woodpecker & ansible
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
This commit is contained in:
4
infra/cicd/.env.j2
Normal file
4
infra/cicd/.env.j2
Normal file
@@ -0,0 +1,4 @@
|
||||
WOODPECKER_ADMIN={{ woodpecker_admin }}
|
||||
WOODPECKER_AGENT_SECRET={{ woodpecker_agent_secret }}
|
||||
WOODPECKER_GITEA_CLIENT={{ woodpecker_gitea_client }}
|
||||
WOODPECKER_GITEA_SECRET={{ woodpecker_gitea_secret }}
|
||||
58
infra/cicd/docker-compose.yaml
Normal file
58
infra/cicd/docker-compose.yaml
Normal file
@@ -0,0 +1,58 @@
|
||||
services:
|
||||
gitea:
|
||||
image: docker.gitea.com/gitea:1.24
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- USER_UID=1000
|
||||
- USER_GID=1000
|
||||
- GITEA__server__ROOT_URL=https://gitea.earthmanrpg.me/
|
||||
- GITEA__server__DOMAIN=gitea.earthmanrpg.me
|
||||
- GITEA__server__SSH_DOMAIN=gitea.earthmanrpg.me
|
||||
- GITEA__webhook__ALLOWED_HOST_LIST=external,loopback
|
||||
volumes:
|
||||
- ./data/gitea:/data # Gitea stores repos, db, config here
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
ports:
|
||||
- "127.0.0.1:3000:3000" # http (only localhost, nginx proxies)
|
||||
- "222:22" # ssh (public, for git push)
|
||||
networks:
|
||||
- cicd
|
||||
|
||||
woodpecker-server:
|
||||
image: woodpeckerci/woodpecker-server:v3
|
||||
restart: unless-stopped
|
||||
depends_on:
|
||||
- gitea
|
||||
environment:
|
||||
- WOODPECKER_HOST=https://ci.earthmanrpg.me
|
||||
- WOODPECKER_OPEN=false
|
||||
- WOODPECKER_ADMIN=${WOODPECKER_ADMIN}
|
||||
- WOODPECKER_GITEA=true
|
||||
- WOODPECKER_GITEA_URL=https://gitea.earthmanrpg.me
|
||||
- WOODPECKER_GITEA_CLIENT=${WOODPECKER_GITEA_CLIENT}
|
||||
- WOODPECKER_GITEA_SECRET=${WOODPECKER_GITEA_SECRET}
|
||||
- WOODPECKER_AGENT_SECRET=${WOODPECKER_AGENT_SECRET}
|
||||
volumes:
|
||||
- ./data/woodpecker-server:/var/lib/woodpecker
|
||||
ports:
|
||||
- "127.0.0.1:8000:8000" # (only nginx proxies)
|
||||
networks:
|
||||
- cicd
|
||||
|
||||
woodpecker-agent:
|
||||
image: woodpeckerci/woodpecker-agent:v3
|
||||
restart: unless-stopped
|
||||
depends_on:
|
||||
- woodpecker-server
|
||||
environment:
|
||||
- WOODPECKER_SERVER=woodpecker-server:9000
|
||||
- WOODPECKER_AGENT_SECRET=${WOODPECKER_AGENT_SECRET}
|
||||
- WOODPECKER_MAX_WORKFLOWS=2
|
||||
volumes:
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
networks:
|
||||
- cicd
|
||||
|
||||
networks:
|
||||
cicd:
|
||||
14
infra/cicd/nginx/gitea.conf
Normal file
14
infra/cicd/nginx/gitea.conf
Normal file
@@ -0,0 +1,14 @@
|
||||
server {
|
||||
listen 80;
|
||||
server_name gitea.earthmanrpg.me;
|
||||
|
||||
client_max_body_size 100m;
|
||||
|
||||
location / {
|
||||
proxy_pass http://127.0.0.1:3000;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
}
|
||||
}
|
||||
16
infra/cicd/nginx/woodpecker.conf
Normal file
16
infra/cicd/nginx/woodpecker.conf
Normal file
@@ -0,0 +1,16 @@
|
||||
server {
|
||||
listen 80;
|
||||
server_name ci.earthmanrpg.me;
|
||||
|
||||
location / {
|
||||
proxy_pass http://127.0.0.1:8000;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
|
||||
# WebSocket support (Woodpecker live log streaming)
|
||||
proxy_set_header Upgrade $http_upgrade;
|
||||
proxy_set_header Connection "upgrade";
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user