Our review
This skill enables interaction with a self-hosted Gitea Git service using its REST API or the tea CLI tool for repository, issue, and pull request management.
Strengths
- Complete automation of common Gitea operations (creation, update, PR merge)
- Support for both REST API and official `tea` CLI client
- Secure handling via tokens and environment variables
- Full CRUD operations on issues, pull requests, and repositories
Limitations
- Requires the user to provide an API token and the Gitea instance URL
- Depends on the availability of `curl` or `tea` on the execution environment
- Gitea API rate limits may restrict heavy automation
Use this skill when you need to automate project management tasks on a self-hosted Gitea instance (creating repos, tracking tickets, code review).
Do not use it if you are working with GitHub, GitLab, or other Git services with different APIs, or if the user lacks proper API access.
Security analysis
SafeThe skill provides legitimate instructions for interacting with the Gitea API using curl and tea CLI. It advises against hardcoding tokens and recommends using environment variables. No destructive or exfiltrating actions are described.
No concerns found
Examples
Create a new private repository named 'my-project' on my Gitea instance at https://gitea.mydomain.com with a description 'My new project'.List all open issues in the repository 'my-org/my-repo' on Gitea.Create a pull request from branch 'feature-x' to 'main' in repository 'my-org/my-repo' with title 'Add feature X' and description 'This PR adds feature X.'name: gitea description: Interact with Gitea (self-hosted Git service) using the Gitea API. Use when working with Gitea repositories, issues, pull requests, or API operations. allowed-tools: Bash, Read, Write, Grep, Glob
Gitea Integration
This skill helps you interact with Gitea, a self-hosted Git service, using its API and CLI tools.
Prerequisites
Before using Gitea API commands, ensure:
- Gitea instance URL is known
- API token is available (can be created in Gitea Settings > Applications > Generate New Token)
curlortea(Gitea CLI) is installed
Common Operations
Repository Management
List Repositories
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/user/repos
Create Repository
curl -X POST -H "Authorization: token YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"name":"repo-name","description":"Repo description","private":false}' \
https://gitea.example.com/api/v1/user/repos
Get Repository Info
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/repos/OWNER/REPO
Issue Management
List Issues
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/repos/OWNER/REPO/issues
Create Issue
curl -X POST -H "Authorization: token YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"title":"Issue title","body":"Issue description"}' \
https://gitea.example.com/api/v1/repos/OWNER/REPO/issues
Update Issue
curl -X PATCH -H "Authorization: token YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"state":"closed"}' \
https://gitea.example.com/api/v1/repos/OWNER/REPO/issues/ISSUE_NUMBER
Pull Request Management
List Pull Requests
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/repos/OWNER/REPO/pulls
Create Pull Request
curl -X POST -H "Authorization: token YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"title":"PR title","head":"feature-branch","base":"main","body":"PR description"}' \
https://gitea.example.com/api/v1/repos/OWNER/REPO/pulls
Merge Pull Request
curl -X POST -H "Authorization: token YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"Do":"merge"}' \
https://gitea.example.com/api/v1/repos/OWNER/REPO/pulls/PR_NUMBER/merge
User and Organization Management
Get Current User Info
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/user
List Organization Repositories
curl -H "Authorization: token YOUR_TOKEN" \
https://gitea.example.com/api/v1/orgs/ORG_NAME/repos
Using Gitea CLI (tea)
If the tea CLI is available, you can use it for simpler commands:
# Login
tea login add --url https://gitea.example.com --token YOUR_TOKEN
# List repos
tea repos ls
# Create issue
tea issues create --title "Issue title" --body "Description"
# Create PR
tea pulls create --head feature-branch --base main --title "PR title"
# List PRs
tea pulls ls
Best Practices
- Security: Never hardcode API tokens. Use environment variables or ask the user for credentials.
- Error Handling: Always check API responses for errors before proceeding.
- Rate Limiting: Be mindful of API rate limits on the Gitea instance.
- Validation: Validate repository names, branch names, and other inputs before making API calls.
Workflow Example
When asked to create a new repository and set it up:
- Ask user for Gitea instance URL and verify they have an API token
- Create the repository using the API
- If requested, initialize with README or other files
- Set up repository settings (private/public, description, etc.)
- Provide the repository URL to the user
Environment Variables
Commonly used environment variables:
GITEA_URL: Base URL of the Gitea instanceGITEA_TOKEN: API token for authenticationGITEA_USER: Username for the Gitea instance
API Documentation
For complete API reference, refer to:
- Gitea API Swagger docs:
https://your-gitea-instance.com/api/swagger - Official docs: https://docs.gitea.com/api/1.20/
Next.js App Router Expert
Development
A skill that turns Claude into a Next.js App Router expert.
README Generator
Development
Creates professional and comprehensive README.md files for your projects.
API Documentation Writer
Development
Generates comprehensive API documentation in OpenAPI/Swagger format.