Are you sure you want to delete this task? Once this task is deleted, it cannot be recovered.
lewis e28644e8d9 | 1 year ago | |
---|---|---|
.. | ||
gothic | 1 year ago | |
providers | 1 year ago | |
.gitignore | 5 years ago | |
.travis.yml | 4 years ago | |
LICENSE.txt | 7 years ago | |
README.md | 4 years ago | |
doc.go | 7 years ago | |
go.mod | 4 years ago | |
go.sum | 4 years ago | |
provider.go | 5 years ago | |
session.go | 7 years ago | |
user.go | 4 years ago |
Package goth provides a simple, clean, and idiomatic way to write authentication
packages for Go web applications.
Unlike other similar packages, Goth, lets you write OAuth, OAuth2, or any other
protocol providers, as long as they implement the Provider
and Session
interfaces.
This package was inspired by https://github.com/intridea/omniauth.
$ go get github.com/markbates/goth
See the examples folder for a working application that lets users authenticate
through Twitter, Facebook, Google Plus etc.
To run the example either clone the source from GitHub
$ git clone git@github.com:markbates/goth.git
or use
$ go get github.com/markbates/goth
$ cd goth/examples
$ go get -v
$ go build
$ ./examples
Now open up your browser and go to http://localhost:3000 to see the example.
To actually use the different providers, please make sure you set environment variables. Example given in the examples/main.go file
By default, gothic uses a CookieStore
from the gorilla/sessions
package to store session data.
As configured, this default store (gothic.Store
) will generate cookies with Options
:
&Options{
Path: "/",
Domain: "",
MaxAge: 86400 * 30,
HttpOnly: true,
Secure: false,
}
To tailor these fields for your application, you can override the gothic.Store
variable at startup.
The following snippet shows one way to do this:
key := "" // Replace with your SESSION_SECRET or similar
maxAge := 86400 * 30 // 30 days
isProd := false // Set to true when serving over https
store := sessions.NewCookieStore([]byte(key))
store.MaxAge(maxAge)
store.Options.Path = "/"
store.Options.HttpOnly = true // HttpOnly should always be enabled
store.Options.Secure = isProd
gothic.Store = store
Issues always stand a significantly better chance of getting fixed if they are accompanied by a
pull request.
Would I love to see more providers? Certainly! Would you love to contribute one? Hopefully, yes!
本项目是群体化方法与技术的开源实现案例,在基于Gitea的基础上,进一步支持社交化的协同开发、协同学习、协同研究等群体创新实践服务,特别是针对新一代人工智能技术特点,重点支持项目管理、git代码管理、大数据集存储管理与智能计算平台接入。
Go SVG JavaScript Vue HTML other
Dear OpenI User
Thank you for your continuous support to the Openl Qizhi Community AI Collaboration Platform. In order to protect your usage rights and ensure network security, we updated the Openl Qizhi Community AI Collaboration Platform Usage Agreement in January 2024. The updated agreement specifies that users are prohibited from using intranet penetration tools. After you click "Agree and continue", you can continue to use our services. Thank you for your cooperation and understanding.
For more agreement content, please refer to the《Openl Qizhi Community AI Collaboration Platform Usage Agreement》