forgejo/routers/repo
zeripath 17c5c654a5
Prevent double-login for Git HTTP and LFS and simplify login (#15303)
* Prevent double-login for Git HTTP and LFS and simplify login

There are a number of inconsistencies with our current methods for
logging in for git and lfs. The first is that there is a double login
process. This is particularly evident in 1.13 where there are no less
than 4 hash checks for basic authentication due to the previous
IsPasswordSet behaviour.

This duplicated code had individual inconsistencies that were not
helpful and caused confusion.

This PR does the following:

* Remove the specific login code from the git and lfs handlers except
for the lfs special bearer token
* Simplify the meaning of DisableBasicAuthentication to allow Token and
Oauth2 sign-in.
* The removal of the specific code from git and lfs means that these
both now have the same login semantics and can - if not
DisableBasicAuthentication - login from external services. Further it
allows Oauth2 token authentication as per our standard mechanisms.
* The change in the recovery handler prevents the service from
re-attempting to login - primarily because this could easily cause a
further panic and it is wasteful.

* add test

Signed-off-by: Andrew Thornton <art27@cantab.net>
Co-authored-by: Andrew Thornton <art27@cantab.net>
2021-05-15 17:32:09 +02:00
..
activity.go
attachment.go
blame.go
branch.go
commit.go
compare.go Add selecting tags on the compare page (#15723) 2021-05-07 23:10:05 +02:00
download.go Add mimetype mapping settings (#15133) 2021-05-10 16:38:08 -04:00
editor.go
editor_test.go
http.go Prevent double-login for Git HTTP and LFS and simplify login (#15303) 2021-05-15 17:32:09 +02:00
issue.go Ensure that ctx.Written is checked after issues(...) calls (#15797) 2021-05-09 10:33:49 +08:00
issue_dependency.go
issue_label.go Unified link creation. (#15619) 2021-04-30 19:25:13 +02:00
issue_label_test.go
issue_lock.go
issue_stopwatch.go
issue_test.go
issue_timetrack.go
issue_watch.go
lfs.go
main_test.go
middlewares.go
migrate.go Unified link creation. (#15619) 2021-04-30 19:25:13 +02:00
milestone.go
projects.go
projects_test.go
pull.go Unified link creation. (#15619) 2021-04-30 19:25:13 +02:00
pull_review.go
release.go fix some ui bug about draft release (#15137) 2021-05-06 05:12:50 +02:00
release_test.go
repo.go Unified link creation. (#15619) 2021-04-30 19:25:13 +02:00
search.go
setting.go Close the gitrepo when deleting the repository (#15876) 2021-05-14 21:19:38 +01:00
setting_protected_branch.go
settings_test.go
topic.go
view.go
webhook.go
wiki.go
wiki_test.go