11 Star 11 Fork 0

Gitee 极速下载/goa

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/goadesign/goa
克隆/下载
scheme.go 4.32 KB
一键复制 编辑 原始数据 按行查看 历史
/*Package security contains the types used by the code generators to
secure goa endpoint. It supports the following security schemes:
* Basic security using usernames and passwords.
* API key security using keys.
* JWT security using JWT tokens.
* OAuth2 security using OAuth2 tokens.
*/
package security
import (
"context"
"fmt"
"strings"
)
type (
// BasicScheme represents the BasicAuth security scheme.
// It consists of a simple username and password.
BasicScheme struct {
// Name is the scheme name defined in the design.
Name string
// Scopes holds a list of scopes for the scheme.
Scopes []string
// RequiredScopes holds a list of scopes which are required
// by the scheme. It is a subset of Scopes field.
RequiredScopes []string
}
// APIKeyScheme represents the API key security scheme.
// It consists of a key which is used in authentication.
APIKeyScheme struct {
// Name is the scheme name defined in the design.
Name string
// Scopes holds a list of scopes for the scheme.
Scopes []string
// RequiredScopes holds a list of scopes which are required
// by the scheme. It is a subset of Scopes field.
RequiredScopes []string
}
// JWTScheme represents an API key based scheme with support
// for scopes.
JWTScheme struct {
// Name is the scheme name defined in the design.
Name string
// Scopes holds a list of scopes for the scheme.
Scopes []string
// RequiredScopes holds a list of scopes which are required
// by the scheme. It is a subset of Scopes field.
RequiredScopes []string
}
// OAuth2Scheme represents the oauth2 security scheme.
OAuth2Scheme struct {
// Name is the scheme name defined in the design.
Name string
// Scopes holds a list of scopes for the scheme.
Scopes []string
// RequiredScopes holds a list of scopes which are required
// by the scheme. It is a subset of Scopes field.
RequiredScopes []string
// Flows determine the oauth2 flows.
Flows []*OAuthFlow
}
// OAuthFlow represents the OAuth2 flow defined by the scheme.
OAuthFlow struct {
// Type is the type of grant.
Type string
// AuthorizationURL to be used for implicit or authorizationCode flows.
AuthorizationURL string
// TokenURL to be used for password, clientCredentials or authorizationCode flows.
TokenURL string
// RefreshURL to be used for obtaining refresh token.
RefreshURL string
}
// AuthBasicFunc is the function type that implements the basic auth
// scheme of using username and password.
AuthBasicFunc func(ctx context.Context, user, pass string, s *BasicScheme) (context.Context, error)
// AuthAPIKeyFunc is the function type that implements the API key
// scheme of using an API key.
AuthAPIKeyFunc func(ctx context.Context, key string, s *APIKeyScheme) (context.Context, error)
// AuthOAuth2Func is the function type that implements the OAuth2
// scheme of using an OAuth2 token.
AuthOAuth2Func func(ctx context.Context, token string, s *OAuth2Scheme) (context.Context, error)
// AuthJWTFunc is the function type that implements the JWT
// scheme of using a JWT token.
AuthJWTFunc func(ctx context.Context, token string, s *JWTScheme) (context.Context, error)
)
// Validate returns a non-nil error if scopes does not contain all of
// Basic scheme's required scopes.
func (s *BasicScheme) Validate(scopes []string) error {
return validateScopes(s.RequiredScopes, scopes)
}
// Validate returns a non-nil error if scopes does not contain all of
// APIKey scheme's required scopes.
func (s *APIKeyScheme) Validate(scopes []string) error {
return validateScopes(s.RequiredScopes, scopes)
}
// Validate returns a non-nil error if scopes does not contain all of
// OAuth2 scheme's required scopes.
func (s *OAuth2Scheme) Validate(scopes []string) error {
return validateScopes(s.RequiredScopes, scopes)
}
// Validate returns a non-nil error if scopes does not contain all of
// JWT scheme's required scopes.
func (s *JWTScheme) Validate(scopes []string) error {
return validateScopes(s.RequiredScopes, scopes)
}
func validateScopes(expected, actual []string) error {
var missing []string
for _, r := range expected {
found := false
for _, s := range actual {
if s == r {
found = true
break
}
}
if !found {
missing = append(missing, r)
}
}
if len(missing) == 0 {
return nil
}
return fmt.Errorf("missing scopes: %s", strings.Join(missing, ", "))
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/mirrors/goa.git
git@gitee.com:mirrors/goa.git
mirrors
goa
goa
v2.2.4

搜索帮助