Skip to main content

Monitor GitLab projects and automatically process issues and merge requests

Project description

GitLab Watcher

Monitor GitLab projects and automatically process issues and merge requests using AI tools. It features built-in support for automated branch management, AI-driven code generation, and Discord notifications.

What the Watcher Does

Issue Processing (Automatic)

When an issue is assigned to the configured user without workflow labels:

  1. Adds "In progress" label
  2. Creates branch <issue-id>-<slug> from default branch
  3. Runs AI tool with the issue description
  4. Pushes changes and creates merge request
  5. Moves issue to "Review" label
  6. Sends optional Discord notification

MR Comment Processing (Automatic)

When a new comment appears on an open MR (not from the bot user):

  1. Checks out the MR's source branch
  2. Runs AI tool with the comment as feedback
  3. Pushes the changes to the remote branch
  4. Notifies Discord channels about applied changes

Post-Merge Cleanup (Automatic)

When an MR is merged:

  1. Updates default branch (e.g., master/main)
  2. Deletes the merged feature branch
  3. Sends Discord notification to confirm cleanup

Prerequisites

  • Python 3.11 or higher
  • Git installed and available in your system path
  • GitLab Access Token with API access
  • Claude CLI (or opencode) must be installed and available in your PATH. (ollama is optional but supported for launching Claude).

Installation

# From PyPI (recommended)
pip install gitlab-watcher

# From source (development mode)
git clone https://git.gyengus.hu/gyengus/gitlab-watcher.git
cd gitlab-watcher
pip install -e ".[dev]"

Usage

# Run with default config
gitlab-watcher

# Custom config file
gitlab-watcher -c /path/to/config.conf

# Verbose mode
gitlab-watcher --verbose

Configuration

Create the default configuration directory:

mkdir -p ~/.config/gitlab-watcher

Create ~/.config/gitlab-watcher/config.conf with your environment details:

# Your GitLab instance URL
GITLAB_URL="https://git.example.com"

# Personal or Group Access Token
GITLAB_TOKEN="your_token_here"

# (Optional) Discord Webhook for detailed event notifications
DISCORD_WEBHOOK="https://discord.com/api/webhooks/your_webhook_id"

# Monitoring interval in seconds
POLL_INTERVAL=30

# AI Tool implementation style (ollama, direct, opencode, custom)
AI_TOOL_MODE="ollama"

# List of absolute paths to project directories to monitor
PROJECT_DIRS=(
  "/path/to/project1"
  "/path/to/project2"
)

(Note: If GITLAB_URL and GITLAB_TOKEN are not provided in the configuration, the watcher will attempt to extract them from your git remotes automatically.)

Each monitored project directory must have a PROJECT.md, AGENTS.md, or CLAUDE.md file with a corresponding Project ID:

Project ID: 31

Supported AI Tools

The watcher supports multiple AI tools:

Mode Description
ollama Launches Claude via Ollama (requires both ollama and claude) (default)
direct Direct Claude CLI execution (claude)
opencode Opencode CLI execution (opencode)
custom Custom command for any AI tool

Configure in config.conf:

AI_TOOL_MODE="ollama"  # or "direct", "opencode", "custom"

Development

# Install dev dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Run tests with coverage
pytest --cov=gitlab_watcher

Support & Donations

If you find this tool helpful and would like to support its continued development, crypto donations are very much appreciated!

  • Bitcoin (BTC): bc1qx4q5epl7nsyu9mum8edrvp2my8tut0enrz7kcn
  • Dogecoin (DOGE): DS62HBswTfAJLadRcMyrUJq6CAE8XV6SqC
  • EVM (ETH/BSC/Polygon): 0x9F0a70A7306DF3fc072446cAF540F6766a4CC4E8
  • Web3 Domain: gyengus.sendme1satoshi.wallet

Thank you for your support!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gitlab_watcher-1.0.0.tar.gz (34.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gitlab_watcher-1.0.0-py3-none-any.whl (23.7 kB view details)

Uploaded Python 3

File details

Details for the file gitlab_watcher-1.0.0.tar.gz.

File metadata

  • Download URL: gitlab_watcher-1.0.0.tar.gz
  • Upload date:
  • Size: 34.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for gitlab_watcher-1.0.0.tar.gz
Algorithm Hash digest
SHA256 d4f0282a85e7cb6df062bffe482b0719aedea2df6e0a4d9155282c87483200b6
MD5 c0df31ce54a8b625bb1bae960cf9e113
BLAKE2b-256 7ff6c1ce17fd7c29f166144ec77de0ff1ff1c1cc65a144d80baebe0984ae5b21

See more details on using hashes here.

File details

Details for the file gitlab_watcher-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: gitlab_watcher-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 23.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for gitlab_watcher-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 02e2f0ccfc0e55dda9da48b439ba105cbde8c5fb5b5b91d9ef21d89e1c3ab4c8
MD5 4e6df6e0b1d5a8481f626ac86e376d6d
BLAKE2b-256 1b7ce2bc5c34e7f56a66c6759243f814eff1bc1725645867f4d25dbe03948cce

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page