Skip to content

Latest commit

 

History

History
165 lines (125 loc) · 5.54 KB

README.ru.md

File metadata and controls

165 lines (125 loc) · 5.54 KB

gopher-bot

Бот для проверки Pull Request's в Gitea

alt text

✨ Возможности

  • Компиляция кода и проверка на ошибки сборки
  • Запуск линтера
  • Запуск автоматизированных тестов для проверки работоспособности кода
  • Анализ покрытия кода тестами
  • Может выполнять команды из Makefile (make build, lint, test)

📦 Установка

Для начала настройте Gitea. Убедитесь, что Gitea позволяет взаимодействовать с ботом. Для этого в конфиге должна быть прописана директива ALLOWED_HOST_LIST с хостом, на котором развернут gopher-bot:

cat << EOF >> /etc/gitea/app.ini
[webhook]
ALLOWED_HOST_LIST = *
EOF
  1. Для всех репозиториев, где вы хотите использовать gopher-bot, откройте настройки webhook репозитория и создайте новый Gitea webhook (Trigger On и фильтр Branch filter зависят от ваших предпочтений):
    • Target URL: URL, на котором развернут gopher-bot, вместе /hook сегментом (http://gopher-bot:8080/hook)
    • HTTP Method: POST
    • POST Content Type: application/json
    • Secret: секрет, указанный в вашей конфигурации
    • Trigger On: пользовательские события (Custom Events)…
      • Pull Request Events
        • Pull Request
        • Pull Request Synchronized
    • Branch filter: *
    • Active: ✅
  2. Добавьте пользователя gopher-bot c токеном c правами на repo.
  3. Добавьте пользователя gopher-bot в репозиторий.
  4. Установите gopher-bot.

Установку gopher-bot можно выполнить двумя способами: Docker или бинарник.

Docker

На машине выполните команды, указав gitea_host, токен пользователя gopher-bot и secret:

docker volume create gopher-bot_config
docker volume create gopher-bot_var
docker run -it --rm -v gopher-bot_config:/etc/gopher-bot busybox sh -c 'cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"[gitea_host]"=gopher-bot:[token]

[server]
DEBUG_MODE=true
SECRET=[SECRET]'
docker run --restart always -p 8080:8080 -v gopher-bot_config:/etc/gopher-bot -v gopher-bot_var:/var/gopher-bot --name gopher-bot nfort/gopher-bot:1.0.0

Бинарник

Соберите или загрузите бинарник из релиза:

CGO_ENABLED=0 GOOS=linux go build -o gopher-bot cmd/main.go

Добавьте конфиг-файл:

cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"http://[gitea_host]:[gitea_port]"=gopher-bot:[token]

[server]
DEBUG_MODE=true
SECRET=[secret]

Добавьте бинарник на сервер и запустите его. Если вы используете golangci-lint или другие инструменты в качестве зависимостей проекта, их также следует установить на сервер.

🚀 Разработка

После запуска docker compose up, нужно остановить контейнер.

  1. Выполните команду:
docker run -it --rm -v gitea_gitea-config:/etc/gitea busybox sh -c 'cat << EOF >> /etc/gitea/app.ini
[webhook]
ALLOWED_HOST_LIST = *
EOF'
  1. При настройке Gitea указажите gitea:3000 вместо localhost:3000 в качестве хоста. Добавьте пользователя gopher-bot и добавьте токен с правами на repo. Скопируйте токен.
docker volume create gopher-bot_config
docker volume create gopher-bot_var
docker run -it --rm -v gopher-bot_config:/etc/gopher-bot busybox sh -c 'cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"http://gitea:3000"=gopher-bot:[token]

[server]
DEBUG_MODE=true
SECRET=iNeydroTioUC'
docker run --restart always -p 8080:8080 -v gopher-bot_config:/etc/gopher-bot -v gopher-bot_var:/var/gopher-bot --name gopher-bot nfort/gopher-bot:1.0.0
  1. Добавьте webhook для репозитория.
  2. Укажите SECRET.
  3. В качестве хоста укажите gopher-bot:8080/hooks.
  4. Предоставьте права на PR, PR Synchronize.
  5. Добавьте пользователя gopher-bot в репозиторий.

Как добавить gopher-bot в systemd

cat << EOF >> /etc/systemd/system/gopher-bot.service
[Unit]
Description=gopher-bot

[Service]
Environment="HOME=/root"
Environment="GOPATH=/root/.go"
Environment="GOCACHE=/root/.go-cache"
ExecStart=/opt/gopher-bot/gopher-bot
Restart=always

StandardOutput=append:/var/log/gopher-bot.log
StandardError=append:/var/log/gopher-bot.log

[Install]
WantedBy=multi-user.target
EOF

Выполните перезагрузку systemd:

systemctl daemon-reload

Добавьте сервис в systemd:

systemctl enable gopher-bot