Course Outline
Source Code Sovereignty
- Why cloud Git platforms pose risks to proprietary code and trade secrets.
- Gitea architecture and a comparison with GitHub, GitLab, and Forgejo.
- Licensing, terms of service, and data export considerations.
Installation and Configuration
- Deploying via Docker Compose with PostgreSQL and Redis.
- Binary installation on Linux using systemd services.
- Configuring reverse proxies, TLS, and SSH ports.
- Completing the initial setup wizard: database configuration, admin account creation, and app.ini tuning.
Repository Management
- Creating organizations, teams, and repositories.
- Implementing branch protection, required reviews, and signed commits.
- Utilizing issue tracking, labels, milestones, and Kanban boards.
- Hosting wikis and release artifacts.
CI/CD with Gitea Actions
- Enabling Gitea Actions and registering act runners.
- Writing YAML workflows for building, testing, and deploying.
- Ensuring self-hosted runner security and container isolation.
- Implementing artifact caching and matrix builds.
Migration from Cloud Forges
- Mirroring and importing repositories from GitHub or GitLab.
- Migrating issues, pull requests, and release notes.
- Preserving commit signatures and GPG key trust.
Authentication and Access Control
- Integrating with LDAP, Active Directory, and OpenID Connect.
- Managing two-factor authentication and deploy tokens.
- Setting repository visibility scopes: public, internal, and private.
Security and Compliance
- Enforcing commit signing using GPG and SSH keys.
- Maintaining audit logs for repository access and administrative changes.
- Conducting dependency scanning and receiving vulnerability webhook alerts.
Maintenance and Scaling
- Implementing backup strategies for Git data, issues, and attachments.
- Optimizing databases and offloading attachments to S3.
- Upgrading Gitea and managing breaking changes.
Requirements
- Intermediate understanding of Git and version control concepts.
- Experience with Linux server administration, including Docker.
- Familiarity with CI/CD pipelines and webhooks.
Audience
- Development teams looking to replace GitHub or GitLab.com.
- Organizations requiring on-premise custody of source code.
- Government entities and defense contractors subject to code export restrictions.
Testimonials (4)
I like that I've got immediately answer to my questions.
Szabolcs Kriston - Ericsson
Course - Advanced GitLab
Repeat the important takeaway
Milly Chen - Logitech
Course - Gerrit Code Review
Exercises that we were able to do on VMs
Atif Bhatti
Course - Git Hands-on Workshop with Azure DevOps
I liked the easy communication between trainer and us, care given to our problems, insights and additional knowledge provided in anwers to our questions. I liked the pace, it didn't feel rushed at any point, even with technical problems. Each subject was taken care of properly.