2017-03-17 22:16:08 +08:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
2022-11-28 02:20:29 +08:00
|
|
|
// SPDX-License-Identifier: MIT
|
2017-03-17 22:16:08 +08:00
|
|
|
|
|
|
|
package openid
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
2019-08-24 00:40:30 +08:00
|
|
|
|
|
|
|
"github.com/yohcop/openid-go"
|
2017-03-17 22:16:08 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// For the demo, we use in-memory infinite storage nonce and discovery
|
|
|
|
// cache. In your app, do not use this as it will eat up memory and
|
|
|
|
// never
|
|
|
|
// free it. Use your own implementation, on a better database system.
|
|
|
|
// If you have multiple servers for example, you may need to share at
|
|
|
|
// least
|
|
|
|
// the nonceStore between them.
|
2022-01-21 01:46:10 +08:00
|
|
|
var (
|
|
|
|
nonceStore = openid.NewSimpleNonceStore()
|
|
|
|
discoveryCache = newTimedDiscoveryCache(24 * time.Hour)
|
|
|
|
)
|
2017-03-17 22:16:08 +08:00
|
|
|
|
|
|
|
// Verify handles response from OpenID provider
|
|
|
|
func Verify(fullURL string) (id string, err error) {
|
|
|
|
return openid.Verify(fullURL, discoveryCache, nonceStore)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Normalize normalizes an OpenID URI
|
|
|
|
func Normalize(url string) (id string, err error) {
|
|
|
|
return openid.Normalize(url)
|
|
|
|
}
|
|
|
|
|
|
|
|
// RedirectURL redirects browser
|
|
|
|
func RedirectURL(id, callbackURL, realm string) (string, error) {
|
|
|
|
return openid.RedirectURL(id, callbackURL, realm)
|
|
|
|
}
|