Model Context Protocol server for Gitea (and Forgejo, Codeberg).
Project description
gitea-mcp
A Model Context Protocol server for Gitea — lets AI assistants (Claude, ChatGPT, Copilot, and anything else that speaks MCP) read, create, and manage issues, repositories, and releases on any Gitea instance you can reach.
Also works against Forgejo and Codeberg (API-compatible).
Why
Self-hosted Gitea is a popular GitHub alternative for solo developers, small teams, and privacy-conscious organizations. With this MCP server installed, your AI assistant can:
- File audit findings or refactor notes as Gitea issues without you leaving the chat
- Triage a repo's open issues in natural language
- Cut a release at the end of a coding session
- Comment on issues across multiple repos in one pass
Features
| Resource | Tools |
|---|---|
| Issues | create_issue, list_issues, get_issue, update_issue, add_comment |
| Repos | list_repos, list_labels, list_milestones |
| Releases | list_releases, create_release |
- Bearer authentication via Personal Access Token (PAT)
- Async HTTP via
httpxandFastMCP - Works with self-hosted Gitea, Forgejo, and Codeberg
Quick Start
1. Install
pip install gitea-mcp
Or with uv:
uv pip install gitea-mcp
2. Generate a Personal Access Token
In your Gitea instance, go to Settings → Applications → Generate New Token and grant at least:
read:repositorywrite:issueread:user
Add write:repository if you also want to create releases.
3. Configure your MCP client
Claude Desktop (interactive): run
gitea-mcp init
It prompts for the Gitea URL and Personal Access Token, verifies the connection, and writes (or merges into) the right claude_desktop_config.json for your OS. Restart Claude Desktop and you're done.
To check that the server can reach your Gitea instance at any time:
gitea-mcp doctor
doctor reads GITEA_URL and GITEA_TOKEN from the environment, runs a GET /api/v1/user, and reports the authenticated username plus the state of the MCP tool surface. Exit 0 = ready; exit 1 = connection/load failure; exit 2 = missing config.
Any MCP client (manual): add gitea-mcp to the client's MCP config:
{
"mcpServers": {
"gitea": {
"command": "gitea-mcp",
"env": {
"GITEA_URL": "https://your-gitea-instance.example.com",
"GITEA_TOKEN": "your-personal-access-token"
}
}
}
}
See mcp.json for a complete example. The same shape works for Claude Desktop, VS Code, Cowork, Claude Code, and any other MCP-compatible client.
Configuration
Configuration is read from environment variables.
| Variable | Required | Default | Description |
|---|---|---|---|
GITEA_URL |
Yes | — | Base URL of your Gitea instance (e.g., https://gitea.example.com) |
GITEA_TOKEN |
Yes | — | Personal Access Token from your Gitea user settings |
GITEA_TIMEOUT |
No | 30 |
HTTP request timeout in seconds |
Compatibility
| Server | Status |
|---|---|
| Gitea (self-hosted) | ✅ Primary target |
| Forgejo | ✅ Expected to work (API-compatible) |
| Codeberg | ✅ Expected to work (Codeberg runs Forgejo) |
Development
git clone https://github.com/werebear73/gitea-mcp.git
cd gitea-mcp
pip install -e ".[dev]"
pytest
Versioning
Semantic versioning, derived from git tags via setuptools_scm. See VERSIONING.md for the release process.
Contributing
Issues and pull requests welcome. For substantial changes, please open an issue first to discuss the approach.
License
MIT — use it however you like, including commercial products.
Built by Waretech Services.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gitea_mcp-0.1.2.tar.gz.
File metadata
- Download URL: gitea_mcp-0.1.2.tar.gz
- Upload date:
- Size: 35.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
341ac93dd277630d72a3f862cf1bee9d00e1d333dfe5ed1e5a6790e99187a82a
|
|
| MD5 |
20b34e342ed2b87fca41288bbce3a8c9
|
|
| BLAKE2b-256 |
fa09534766b760a698594e52f764a5346f5ce8b1d660403d924eea7a6bf17120
|
Provenance
The following attestation bundles were made for gitea_mcp-0.1.2.tar.gz:
Publisher:
release.yml on werebear73/gitea-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitea_mcp-0.1.2.tar.gz -
Subject digest:
341ac93dd277630d72a3f862cf1bee9d00e1d333dfe5ed1e5a6790e99187a82a - Sigstore transparency entry: 1563012420
- Sigstore integration time:
-
Permalink:
werebear73/gitea-mcp@c0f4c62edc1c3d1e3c231ab113f836e33dde35ed -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/werebear73
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c0f4c62edc1c3d1e3c231ab113f836e33dde35ed -
Trigger Event:
push
-
Statement type:
File details
Details for the file gitea_mcp-0.1.2-py3-none-any.whl.
File metadata
- Download URL: gitea_mcp-0.1.2-py3-none-any.whl
- Upload date:
- Size: 20.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
397ce7fb58ed73682905c8000f369e95d5adc2fb6cb249cf73f2f826bcd13e13
|
|
| MD5 |
e5dcc7931e66ba3d75d547ca9208cac1
|
|
| BLAKE2b-256 |
0d59df5442c31a910cadf4463c90c940c88ca0070dc1a20d59a25e783102dede
|
Provenance
The following attestation bundles were made for gitea_mcp-0.1.2-py3-none-any.whl:
Publisher:
release.yml on werebear73/gitea-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitea_mcp-0.1.2-py3-none-any.whl -
Subject digest:
397ce7fb58ed73682905c8000f369e95d5adc2fb6cb249cf73f2f826bcd13e13 - Sigstore transparency entry: 1563012502
- Sigstore integration time:
-
Permalink:
werebear73/gitea-mcp@c0f4c62edc1c3d1e3c231ab113f836e33dde35ed -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/werebear73
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c0f4c62edc1c3d1e3c231ab113f836e33dde35ed -
Trigger Event:
push
-
Statement type: