2017-03-17 17:16:08 +03:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package openid
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
2019-08-23 19:40:30 +03:00
|
|
|
|
|
|
|
"github.com/yohcop/openid-go"
|
2017-03-17 17:16:08 +03: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.
|
|
|
|
var nonceStore = openid.NewSimpleNonceStore()
|
2017-03-21 03:55:00 +03:00
|
|
|
var discoveryCache = newTimedDiscoveryCache(24 * time.Hour)
|
2017-03-17 17:16:08 +03: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)
|
|
|
|
}
|