0
0
mirror of https://github.com/go-gitea/gitea.git synced 2024-11-30 07:16:19 +01:00
Git with a cup of tea! Painless self-hosted all-in-one software development service, including Git hosting, code review, team collaboration, package registry and CI/CD https://gitea.com/
Go to file
Martin Michaelis 55eb1745bd
OAuth2 auto-register (#5123)
* Refactored handleOAuth2SignIn in routers/user/auth.go

The function handleOAuth2SignIn was called twice but some code path could only
be reached by one of the invocations. Moved the unnecessary code path out of
handleOAuth2SignIn.


* Refactored user creation

There was common code to create a user and display the correct error message.
And after the creation the only user should be an admin and if enabled a
confirmation email should be sent. This common code is now abstracted into
two functions and a helper function to call both.

* Added auto-register for OAuth2 users

If enabled new OAuth2 users will be registered with their OAuth2 details.
The UserID, Name and Email fields from the gothUser are used.
Therefore the OpenID Connect provider needs additional scopes to return
the coresponding claims.

* Added error for missing fields in OAuth2 response

* Linking and auto linking on oauth2 registration

* Set default username source to nickname

* Add automatic oauth2 scopes for github and google

* Add hint to change the openid connect scopes if fields are missing

* Extend info about auto linking security risk

Co-authored-by: Viktor Kuzmin <kvaster@gmail.com>
Signed-off-by: Martin Michaelis <code@mgjm.de>
2021-04-14 14:02:12 +02:00
.github Issue template addition: Are you using Gitea behind CloudFlare? (#14098) 2021-02-18 12:28:07 +01:00
assets Clean up SVG (#13680) 2020-12-17 16:33:53 -05:00
build Add frontend testing, require node 12 (#15315) 2021-04-08 12:41:57 +02:00
cmd dump: Add option to skip LFS/attachment files (#15407) 2021-04-12 17:33:32 +08:00
contrib Add environment-to-ini to docker image (#14762) 2021-02-23 20:21:44 +01:00
custom/conf OAuth2 auto-register (#5123) 2021-04-14 14:02:12 +02:00
docker Add reverse proxy configuration support for remote IP address (#14959) 2021-03-16 00:27:28 +02:00
docs OAuth2 auto-register (#5123) 2021-04-14 14:02:12 +02:00
integrations Fix delete nonexist oauth application 500 and prevent deadlock (#15384) 2021-04-10 16:49:10 -04:00
models OAuth2 auto-register (#5123) 2021-04-14 14:02:12 +02:00
modules OAuth2 auto-register (#5123) 2021-04-14 14:02:12 +02:00
options [skip ci] Updated translations via Crowdin 2021-04-14 00:12:38 +00:00
public Update JS dependencies (#15033) 2021-03-22 05:04:19 +01:00
routers OAuth2 auto-register (#5123) 2021-04-14 14:02:12 +02:00
services Always set the merge base used to merge the commit (#15352) 2021-04-10 09:27:29 +01:00
snap Consolidate Logos and update README header (#14136) 2021-01-01 14:04:35 -05:00
templates Fix repository search (#15428) 2021-04-12 22:09:46 -04:00
tools Added 2 fuzzers (#13818) 2020-12-10 20:43:11 +01:00
vendor Upgrade to bluemonday 1.0.7 (#15379) 2021-04-09 19:13:06 -04:00
web_src Fix repository search (#15428) 2021-04-12 22:09:46 -04:00
.air.conf
.changelog.yml
.drone.yml Stop packaging node_modules in release tarballs (#15273) 2021-04-09 01:08:14 -04:00
.editorconfig Enforce tab indentation in templates (#15289) 2021-04-10 23:46:37 -04:00
.eslintrc Add frontend testing, require node 12 (#15315) 2021-04-08 12:41:57 +02:00
.gitattributes Update JS dependencies and misc tweaks (#13741) 2020-11-29 16:39:36 -05:00
.gitignore Stop packaging node_modules in release tarballs (#15273) 2021-04-09 01:08:14 -04:00
.golangci.yml Fix typo in .golangci.yml (#14933) 2021-03-09 03:38:18 -05:00
.ignore
.lgtm
.npmrc Stop packaging node_modules in release tarballs (#15273) 2021-04-09 01:08:14 -04:00
.revive.toml
.stylelintrc
BSDmakefile
build.go
CHANGELOG.md Changelog v1.14.0 (#15360) (#15400) 2021-04-11 13:23:55 +08:00
CONTRIBUTING.md Update owners for 2021 (#14206) 2021-01-01 01:41:03 +02:00
DCO
Dockerfile go1.16 (#14783) 2021-02-28 18:08:33 -05:00
Dockerfile.rootless go1.16 (#14783) 2021-02-28 18:08:33 -05:00
go.mod Upgrade to bluemonday 1.0.7 (#15379) 2021-04-09 19:13:06 -04:00
go.sum Upgrade to bluemonday 1.0.7 (#15379) 2021-04-09 19:13:06 -04:00
jest.config.js Add frontend testing, require node 12 (#15315) 2021-04-08 12:41:57 +02:00
LICENSE
main.go Dump github/gitlab/gitea repository data to a local directory and restore to gitea (#12244) 2020-12-27 11:34:19 +08:00
MAINTAINERS Update MAINTAINERS (#15382) 2021-04-09 19:11:31 -04:00
Makefile Enforce tab indentation in templates (#15289) 2021-04-10 23:46:37 -04:00
package-lock.json Enforce tab indentation in templates (#15289) 2021-04-10 23:46:37 -04:00
package.json Enforce tab indentation in templates (#15289) 2021-04-10 23:46:37 -04:00
README_ZH.md Kd/add bountysource (#14323) 2021-01-13 10:53:17 -05:00
README.md Stop packaging node_modules in release tarballs (#15273) 2021-04-09 01:08:14 -04:00
SECURITY.md
webpack.config.js Disable cssnano's colormin plugin (#15347) 2021-04-08 19:28:41 +01:00

Gitea

Gitea - Git with a cup of tea

View the chinese version of this document

Purpose

The goal of this project is to make the easiest, fastest, and most painless way of setting up a self-hosted Git service. Using Go, this can be done with an independent binary distribution across all platforms which Go supports, including Linux, macOS, and Windows on x86, amd64, ARM and PowerPC architectures. Want to try it before doing anything else? Do it with the online demo! This project has been forked from Gogs since 2016.11 but changed a lot.

Building

From the root of the source tree, run:

TAGS="bindata" make build

or if sqlite support is required:

TAGS="bindata sqlite sqlite_unlock_notify" make build

The build target is split into two sub-targets:

  • make backend which requires Go 1.13 or greater.
  • make frontend which requires Node.js 12.17 or greater and Internet connectivity to download npm dependencies.

When building from the official source tarballs which include pre-built frontend files, the frontend target will not be triggered, making it possible to build without Node.js and Internet connectivity.

Parallelism (make -j <num>) is not supported.

More info: https://docs.gitea.io/en-us/install-from-source/

Using

./gitea web

NOTE: If you're interested in using our APIs, we have experimental support with documentation.

Contributing

Expected workflow is: Fork -> Patch -> Push -> Pull Request

NOTES:

  1. YOU MUST READ THE CONTRIBUTORS GUIDE BEFORE STARTING TO WORK ON A PULL REQUEST.
  2. If you have found a vulnerability in the project, please write privately to security@gitea.io. Thanks!

Further information

For more information and instructions about how to install Gitea, please look at our documentation. If you have questions that are not covered by the documentation, you can get in contact with us on our Discord server or create a post in the discourse forum.

We maintain a list of Gitea-related projects at gitea/awesome-gitea.
The hugo-based documentation theme is hosted at gitea/theme.
The official Gitea CLI is developed at gitea/tea.

Authors

Backers

Thank you to all our backers! 🙏 [Become a backer]

Sponsors

Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor]

FAQ

How do you pronounce Gitea?

Gitea is pronounced /ɡɪti:/ as in "gi-tea" with a hard g.

Why is this not hosted on a Gitea instance?

We're working on it.

License

This project is licensed under the MIT License. See the LICENSE file for the full license text.

Screenshots

Looking for an overview of the interface? Check it out!

Dashboard User Profile Global Issues
Branches Web Editor Activity
New Migration Migrating Pull Request View
Pull Request Dark Diff Review Dark Diff Dark