mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	Use [chi](https://github.com/go-chi/chi) instead of the forked [macaron](https://gitea.com/macaron/macaron). Since macaron and chi have conflicts with session share, this big PR becomes a have-to thing. According my previous idea, we can replace macaron step by step but I'm wrong. :( Below is a list of big changes on this PR. - [x] Define `context.ResponseWriter` interface with an implementation `context.Response`. - [x] Use chi instead of macaron, and also a customize `Route` to wrap chi so that the router usage is similar as before. - [x] Create different routers for `web`, `api`, `internal` and `install` so that the codes will be more clear and no magic . - [x] Use https://github.com/unrolled/render instead of macaron's internal render - [x] Use https://github.com/NYTimes/gziphandler instead of https://gitea.com/macaron/gzip - [x] Use https://gitea.com/go-chi/session which is a modified version of https://gitea.com/macaron/session and removed `nodb` support since it will not be maintained. **BREAK** - [x] Use https://gitea.com/go-chi/captcha which is a modified version of https://gitea.com/macaron/captcha - [x] Use https://gitea.com/go-chi/cache which is a modified version of https://gitea.com/macaron/cache - [x] Use https://gitea.com/go-chi/binding which is a modified version of https://gitea.com/macaron/binding - [x] Use https://github.com/go-chi/cors instead of https://gitea.com/macaron/cors - [x] Dropped https://gitea.com/macaron/i18n and make a new one in `code.gitea.io/gitea/modules/translation` - [x] Move validation form structs from `code.gitea.io/gitea/modules/auth` to `code.gitea.io/gitea/modules/forms` to avoid dependency cycle. - [x] Removed macaron log service because it's not need any more. **BREAK** - [x] All form structs have to be get by `web.GetForm(ctx)` in the route function but not as a function parameter on routes definition. - [x] Move Git HTTP protocol implementation to use routers directly. - [x] Fix the problem that chi routes don't support trailing slash but macaron did. - [x] `/api/v1/swagger` now will be redirect to `/api/swagger` but not render directly so that `APIContext` will not create a html render. Notices: - Chi router don't support request with trailing slash - Integration test `TestUserHeatmap` maybe mysql version related. It's failed on my macOS(mysql 5.7.29 installed via brew) but succeed on CI. Co-authored-by: 6543 <6543@obermui.de>
		
			
				
	
	
		
			290 lines
		
	
	
	
		
			8.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			290 lines
		
	
	
	
		
			8.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| date: "2016-11-08T16:00:00+02:00"
 | |
| title: "Documentation"
 | |
| slug: "documentation"
 | |
| url: "/en-us/"
 | |
| weight: 10
 | |
| toc: false
 | |
| draft: false
 | |
| ---
 | |
| 
 | |
| # What is Gitea?
 | |
| 
 | |
| Gitea is a painless self-hosted Git service. It is similar to GitHub, Bitbucket, and GitLab.
 | |
| Gitea is a fork of [Gogs](http://gogs.io). See the [Gitea Announcement](https://blog.gitea.io/2016/12/welcome-to-gitea/)
 | |
| blog post to read about the justification for a fork.
 | |
| 
 | |
| ## Purpose
 | |
| 
 | |
| The goal of this project is to provide the easiest, fastest, and most painless way of setting
 | |
| up a self-hosted Git service. With Go, this can be done with an independent binary distribution
 | |
| across all platforms and architectures that Go supports. This support includes Linux, macOS, and
 | |
| Windows, on architectures like amd64, i386, ARM, PowerPC, and others.
 | |
| 
 | |
| ## Features
 | |
| 
 | |
| - User Dashboard
 | |
|     - Context switcher (organization or current user)
 | |
|     - Activity timeline
 | |
|         - Commits
 | |
|         - Issues
 | |
|         - Pull requests
 | |
|         - Repository creation
 | |
|     - Searchable repository list
 | |
|     - List of organizations
 | |
|     - A list of mirror repositories
 | |
| - Issues dashboard
 | |
|     - Context switcher (organization or current user)
 | |
|     - Filter by
 | |
|         - Open
 | |
|         - Closed
 | |
|         - Your repositories
 | |
|         - Assigned issues
 | |
|         - Your issues
 | |
|         - Repository
 | |
|     - Sort by
 | |
|         - Oldest
 | |
|         - Last updated
 | |
|         - Number of comments
 | |
| - Pull request dashboard
 | |
|     - Same as issue dashboard
 | |
| - Repository types
 | |
|     - Mirror
 | |
|     - Normal
 | |
|     - Migrated
 | |
| - Notifications (email and web)
 | |
|     - Read
 | |
|     - Unread
 | |
|     - Pin
 | |
| - Explore page
 | |
|     - Users
 | |
|     - Repos
 | |
|     - Organizations
 | |
|     - Search
 | |
| - Custom templates
 | |
| - Override public files (logo, css, etc)
 | |
| - CSRF and XSS protection
 | |
| - HTTPS support
 | |
| - Set allowed upload sizes and types
 | |
| - Logging
 | |
| - Configuration
 | |
|     - Databases
 | |
|         - MySQL
 | |
|         - PostgreSQL
 | |
|         - SQLite3
 | |
|         - MSSQL
 | |
|         - TiDB (experimental, not recommended)
 | |
|     - Configuration file
 | |
|         - [app.ini](https://github.com/go-gitea/gitea/blob/master/custom/conf/app.example.ini)
 | |
|     - Admin panel
 | |
|         - Statistics
 | |
|         - Actions
 | |
|             - Delete inactive accounts
 | |
|             - Delete cached repository archives
 | |
|             - Delete repositories records which are missing their files
 | |
|             - Run garbage collection on repositories
 | |
|             - Rewrite SSH keys
 | |
|             - Resync hooks
 | |
|             - Recreate repositories which are missing
 | |
|         - Server status
 | |
|             - Uptime
 | |
|             - Memory
 | |
|             - Current # of goroutines
 | |
|             - And more
 | |
|          - User management
 | |
|             - Search
 | |
|             - Sort
 | |
|             - Last login
 | |
|             - Authentication source
 | |
|             - Maximum repositories
 | |
|             - Disable account
 | |
|             - Admin permissions
 | |
|             - Permission to create git hooks
 | |
|             - Permission to create organizations
 | |
|             - Permission to import repositories
 | |
|         - Organization management
 | |
|             - People
 | |
|             - Teams
 | |
|             - Avatar
 | |
|             - Hooks
 | |
|         - Repository management
 | |
|             - See all repository information and manage repositories
 | |
|         - Authentication sources
 | |
|             - OAuth
 | |
|             - PAM
 | |
|             - LDAP
 | |
|             - SMTP
 | |
|         - Configuration viewer
 | |
|             - Everything in config file
 | |
|         - System notices
 | |
|             - When somthing unexpected happens
 | |
|         - Monitoring
 | |
|             - Current processes
 | |
|             - Cron jobs
 | |
|                 - Update mirrors
 | |
|                 - Repository health check
 | |
|                 - Check repository statistics
 | |
|                 - Clean up old archives
 | |
|     - Environment variables
 | |
|     - Command line options
 | |
| - Multi-language support ([21 languages](https://github.com/go-gitea/gitea/tree/master/options/locale))
 | |
| - [Mermaid](https://mermaidjs.github.io/) Diagram support
 | |
| - Mail service
 | |
|     - Notifications
 | |
|     - Registration confirmation
 | |
|     - Password reset
 | |
| - Reverse proxy support
 | |
|     - Includes subpaths
 | |
| - Users
 | |
|     - Profile
 | |
|         - Name
 | |
|         - Username
 | |
|         - Email
 | |
|         - Website
 | |
|         - Join date
 | |
|         - Followers and following
 | |
|         - Organizations
 | |
|         - Repositories
 | |
|         - Activity
 | |
|         - Starred repositories
 | |
|     - Settings
 | |
|         - Same as profile and more below
 | |
|         - Keep email private
 | |
|         - Avatar
 | |
|             - Gravatar
 | |
|             - Libravatar
 | |
|             - Custom
 | |
|         - Password
 | |
|         - Mutiple email addresses
 | |
|         - SSH Keys
 | |
|         - Connected applications
 | |
|         - Two factor authentication
 | |
|         - Linked OAuth2 sources
 | |
|         - Delete account
 | |
| - Repositories
 | |
|     - Clone with SSH/HTTP/HTTPS
 | |
|     - Git LFS
 | |
|     - Watch, Star, Fork
 | |
|     - View watchers, stars, and forks
 | |
|     - Code
 | |
|         - Branch browser
 | |
|         - Web based file upload and creation
 | |
|         - Clone urls
 | |
|         - Download
 | |
|             - ZIP
 | |
|             - TAR.GZ
 | |
|         - Web based editor
 | |
|             - Markdown editor
 | |
|             - Plain text editor
 | |
|                 - Syntax highlighting
 | |
|             - Diff preview
 | |
|             - Preview
 | |
|             - Choose where to commit to
 | |
|         - View file history
 | |
|         - Delete file
 | |
|         - View raw
 | |
|     - Issues
 | |
|         - Issue templates
 | |
|         - Milestones
 | |
|         - Labels
 | |
|         - Assign issues
 | |
|         - Track time
 | |
|         - Reactions
 | |
|         - Filter
 | |
|             - Open
 | |
|             - Closed
 | |
|             - Assigned person
 | |
|             - Created by you
 | |
|             - Mentioning you
 | |
|         - Sort
 | |
|             - Oldest
 | |
|             - Last updated
 | |
|             - Number of comments
 | |
|         - Search
 | |
|         - Comments
 | |
|         - Attachments
 | |
|     - Pull requests
 | |
|         - Same features as issues
 | |
|     - Commits
 | |
|         - Commit graph
 | |
|         - Commits by branch
 | |
|         - Search
 | |
|         - Search in all branches
 | |
|         - View diff
 | |
|         - View SHA
 | |
|         - View author
 | |
|         - Browse files in commit
 | |
|     - Releases
 | |
|         - Attachments
 | |
|         - Title
 | |
|         - Content
 | |
|         - Delete
 | |
|         - Mark as pre-release
 | |
|         - Choose branch
 | |
|     - Wiki
 | |
|         - Import
 | |
|         - Markdown editor
 | |
|     - Settings
 | |
|         - Options
 | |
|             - Name
 | |
|             - Description
 | |
|             - Private/Public
 | |
|             - Website
 | |
|             - Wiki
 | |
|                 - Enabled/disabled
 | |
|                 - Internal/external
 | |
|             - Issues
 | |
|                 - Enabled/disabled
 | |
|                 - Internal/external
 | |
|                 - External supports url rewriting for better integration
 | |
|             - Enable/disable pull requests
 | |
|             - Transfer repository
 | |
|             - Delete wiki
 | |
|             - Delete repository
 | |
|         - Collaboration
 | |
|             - Read/write/admin
 | |
|         - Branches
 | |
|             - Default branch
 | |
|             - Branch protection
 | |
|         - Webhooks
 | |
|         - Git hooks
 | |
|         - Deploy keys
 | |
| 
 | |
| ## System Requirements
 | |
| 
 | |
| - A Raspberry Pi 3 is powerful enough to run Gitea for small workloads.
 | |
| - 2 CPU cores and 1GB RAM is typically sufficient for small teams/projects.
 | |
| - Gitea should be run with a dedicated non-root system account on UNIX-type systems.
 | |
|    - Note: Gitea manages the `~/.ssh/authorized_keys` file. Running Gitea as a regular user could break that user's ability to log in.
 | |
| - [Git](https://git-scm.com/) version 1.7.2 or later is required. Version 1.9.0 or later is recommended. Also please note:
 | |
|    - Git [large file storage](https://git-lfs.github.com/) will be available if enabled when git >= 2.1.2.
 | |
|    - Git commit-graph rendering will be enabled automatically when git >= 2.18.
 | |
| 
 | |
| ## Browser Support
 | |
| 
 | |
| - Last 2 versions of Chrome, Firefox, Safari, Edge (EdgeHTML) and Edge (Chromium)
 | |
| - Firefox ESR
 | |
| 
 | |
| ## Components
 | |
| 
 | |
| * Web framework: [Chi](http://github.com/go-chi/chi)
 | |
| * ORM: [XORM](https://xorm.io)
 | |
| * UI components:
 | |
|   * [Semantic UI](http://semantic-ui.com/)
 | |
|   * [GitHub Octicons](https://octicons.github.com/)
 | |
|   * [Font Awesome](http://fontawesome.io/)
 | |
|   * [DropzoneJS](http://www.dropzonejs.com/)
 | |
|   * [Highlight](https://highlightjs.org/)
 | |
|   * [Clipboard](https://zenorocha.github.io/clipboard.js/)
 | |
|   * [CodeMirror](https://codemirror.net/)
 | |
|   * [jQuery MiniColors](https://github.com/claviska/jquery-minicolors)
 | |
| * Database drivers:
 | |
|   * [github.com/go-sql-driver/mysql](https://github.com/go-sql-driver/mysql)
 | |
|   * [github.com/lib/pq](https://github.com/lib/pq)
 | |
|   * [github.com/mattn/go-sqlite3](https://github.com/mattn/go-sqlite3)
 | |
|   * [github.com/pingcap/tidb](https://github.com/pingcap/tidb)
 | |
|   * [github.com/denisenkom/go-mssqldb](https://github.com/denisenkom/go-mssqldb)
 | |
| 
 | |
| ## Software and Service Support
 | |
| 
 | |
| - [Drone](https://github.com/drone/drone) (CI)
 |