Add Gitea server setup guide
- Document GITEA_TOKEN secret configuration - Provide API token creation instructions - Include Gitea Actions enablement steps - Add runner verification and setup instructions - Include testing procedures for the complete setup - Add troubleshooting for common configuration issues - Explain the workflow execution flow after setup
This commit is contained in:
151
GITEA_SETUP.md
Normal file
151
GITEA_SETUP.md
Normal file
@@ -0,0 +1,151 @@
|
||||
# Gitea Actions Setup - Server Configuration Checklist
|
||||
|
||||
This document outlines the changes needed on your Gitea server to make the CI/CD pipeline work.
|
||||
|
||||
## What You Need to Do
|
||||
|
||||
### 1. Add GITEA_TOKEN Secret to Repository
|
||||
|
||||
1. **Log into Gitea** with your user account
|
||||
2. **Navigate to** your nerd-monitor repository
|
||||
3. **Go to Settings → Secrets**
|
||||
4. **Create a new secret**:
|
||||
- Name: `GITEA_TOKEN`
|
||||
- Value: [Your Gitea API token - see below for how to create]
|
||||
5. **Save the secret**
|
||||
|
||||
### 2. Create an API Token (if you haven't already)
|
||||
|
||||
1. **Log into Gitea** with your user account
|
||||
2. **Go to Settings → Applications**
|
||||
3. **Click "Generate New Token"**
|
||||
4. **Fill in the form**:
|
||||
- Token Name: `release-automation`
|
||||
- Scopes: Select at least `repo` (full repository access)
|
||||
5. **Click "Generate"**
|
||||
6. **Copy the token immediately** (you won't see it again)
|
||||
7. **Use this token** for the secret in step 1
|
||||
|
||||
### 3. Verify Gitea Actions is Enabled (Server Admin)
|
||||
|
||||
These steps require SSH access to your Gitea server:
|
||||
|
||||
```bash
|
||||
# SSH into your Gitea server
|
||||
ssh user@your-gitea-server
|
||||
|
||||
# Edit the Gitea configuration
|
||||
sudo vi /etc/gitea/app.ini
|
||||
|
||||
# Verify or add this section:
|
||||
[actions]
|
||||
ENABLED = true
|
||||
|
||||
# Save and exit (Esc, :wq, Enter)
|
||||
|
||||
# Restart Gitea for changes to take effect
|
||||
sudo systemctl restart gitea
|
||||
```
|
||||
|
||||
### 4. Verify Your Runner is Online (Server Admin)
|
||||
|
||||
1. **Log into Gitea** as admin
|
||||
2. **Go to Administration → Actions → Runners**
|
||||
3. **Verify** at least one runner is listed and shows as "Online" or "Idle"
|
||||
4. If no runners:
|
||||
- You need to set up a Gitea Actions runner on a machine with Docker and Go
|
||||
- See "Setting Up a Runner" below
|
||||
|
||||
## Setting Up a Runner (if needed)
|
||||
|
||||
If you don't have any runners yet, you need to set one up. This can be on the Gitea server itself or any machine with Docker/Go.
|
||||
|
||||
### Quick Runner Setup
|
||||
|
||||
1. **On your Gitea server or runner machine**:
|
||||
|
||||
```bash
|
||||
# Download the Gitea Actions runner
|
||||
wget https://github.com/gitea/act_runner/releases/download/v0.6.10/act_runner-0.6.10-linux-amd64
|
||||
chmod +x act_runner-0.6.10-linux-amd64
|
||||
|
||||
# Register the runner with your Gitea instance
|
||||
./act_runner-0.6.10-linux-amd64 register \
|
||||
--instance https://git.nerdnest.dev \
|
||||
--token <your-runner-token>
|
||||
|
||||
# Run the runner in the background
|
||||
./act_runner-0.6.10-linux-amd64 daemon &
|
||||
```
|
||||
|
||||
To get a runner token:
|
||||
1. Log into Gitea as **admin**
|
||||
2. Go to **Administration → Actions → Runners**
|
||||
3. Click **Create new runner**
|
||||
4. Follow the registration steps
|
||||
|
||||
## Testing the Setup
|
||||
|
||||
Once everything is configured:
|
||||
|
||||
1. **Push a test tag**:
|
||||
```bash
|
||||
git tag -a v0.0.1-test -m "Test release"
|
||||
git push origin v0.0.1-test
|
||||
```
|
||||
|
||||
2. **Monitor the build**:
|
||||
- Go to Actions tab
|
||||
- You should see the workflow running
|
||||
- Check logs for any errors
|
||||
|
||||
3. **Verify the release**:
|
||||
- Go to Releases tab
|
||||
- You should see a new release with binaries and checksums
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
### "Action not found" error
|
||||
- Make sure Gitea Actions is enabled
|
||||
- Restart Gitea if you just enabled it: `sudo systemctl restart gitea`
|
||||
|
||||
### No runners available
|
||||
- Runner must be registered: Administration → Actions → Runners
|
||||
- Runner machine must have Docker and Go installed
|
||||
- Check if runner is online in the UI
|
||||
|
||||
### "GITEA_TOKEN" not found
|
||||
- Make sure the secret is named exactly `GITEA_TOKEN` (case-sensitive)
|
||||
- Go to Settings → Secrets and verify it's there
|
||||
- If it's there, try re-running the workflow
|
||||
|
||||
### Build fails with permission denied
|
||||
- Make sure the runner has permission to run Docker commands
|
||||
- On the runner machine: `sudo usermod -aG docker $USER`
|
||||
- Logout and log back in for the group change to take effect
|
||||
|
||||
## What Happens Next
|
||||
|
||||
Once you've set everything up:
|
||||
|
||||
1. **Every push to main/master** triggers the build job:
|
||||
- Compiles all platform binaries
|
||||
- Builds Docker images
|
||||
- Uploads artifacts as build artifacts
|
||||
|
||||
2. **Every git tag push** (e.g., `v1.0.0`) triggers the full release:
|
||||
- Does all of the above
|
||||
- Creates a Gitea Release
|
||||
- Uploads all binaries and Docker images to the release
|
||||
- Generates SHA256 checksums
|
||||
|
||||
3. **Releases are available in**:
|
||||
- Repository Releases tab in Gitea
|
||||
- Binaries ready for download
|
||||
- Docker images ready for import
|
||||
|
||||
## Support
|
||||
|
||||
- Gitea Actions Docs: https://docs.gitea.io/en-us/actions/
|
||||
- Act Runner Docs: https://gitea.com/gitea/act_runner
|
||||
- For issues with the workflow itself, check the Actions tab logs
|
||||
Reference in New Issue
Block a user