Script for an automatic update of gitea. Should be run locally on the gitea server. Has options for updating via new binary file or build from source.
This project is on life-support. I focus on bringing new features to my paid Autoupdate tool.
If you want to update Gitea and other software (like Drone, Caddy, Podman, Python, Zitadel and Kanboard), you should check out Autoupdate.
This new tool of mine was built as a single binary with a config file and tested on multiple Linux systems.
- Get Gitea Version from the Gitea CLI and if that fails from the Gitea API
- Get latest Release via GitHub API
- Check if there is a newer Version
- If there is a newer Version:
- If binary file was selected:
- Download new version
- Check sha256
- Overwrite old version
- If build from source is active:
- Checkout new release branch
- Build binary
- Overwrite old binary
- If binary file was selected:
License: GNU General Public License
Author: Christoph Daniel Miksche (m5e.de)
Uses python version 3
Ensure pip3
, setuptools
, xz-utils
and wheel
dependencies are installed on the system you are running this script in. (Most Linux OS like Ubuntu or Debian come with these pre-installed)
Create a settings.ini file on your system. Example:
[Gitea]
site=https://your-gitea-instance.com/api/v1/version
apiUrl=https://api.github.com/repos/go-gitea/gitea/releases/latest
system=linux-amd64
file=/usr/local/bin/gitea
tmpDir=/tmp/
buildFromSource=
sourceDir=
logFile=update.log
Use the following command to install gitea-auto-update.
sudo pip3 install gitea-auto-update
Enter the command gitea-auto-update --settings=/path/to/settings.ini
in your commandline.
If you want to schedule your updates, edit your /etc/crontab file.
- English: http://blog.m5e.de/gitea/update/upgrade/bash/script/2018/11/26/gitea-auto-update-script.html
- German: https://blog.wronnay.net/automatische-gitea-updates/
The following instructions help you for developing.
- Check out the Contribution Guidelines.
- Clone this git repo
- Install pipenv:
pip install pipenv
- Install all dependencies:
pipenv install
- Install git pre-commit hooks (for pylint and gitlint) with
pre-commit install
- You can run the tests with
python -m unittest
- After pushing, you should check the build status which currently checks the tests, pylint and the commit message format.
The following steps are automatically executed via pre-commit hooks.
- You can run pylint with
pylint gitea_auto_update
- After changes and commit, you can check if your commit message follows the contribution guidelines with
gitlint
. If there is a problem, gitlint will show you a error message.
See https://github.com/CMiksche/gitea-auto-update/graphs/contributors
Thank you for your support!
Interested in contributing to this project? Check out the Contribution Guidelines.