Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
47 lines
1.3 KiB
47 lines
1.3 KiB
// Copyright 2021 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 pam |
|
|
|
import ( |
|
"code.gitea.io/gitea/models" |
|
"code.gitea.io/gitea/models/login" |
|
"code.gitea.io/gitea/modules/json" |
|
) |
|
|
|
// __________ _____ _____ |
|
// \______ \/ _ \ / \ |
|
// | ___/ /_\ \ / \ / \ |
|
// | | / | \/ Y \ |
|
// |____| \____|__ /\____|__ / |
|
// \/ \/ |
|
|
|
// Source holds configuration for the PAM login source. |
|
type Source struct { |
|
ServiceName string // pam service (e.g. system-auth) |
|
EmailDomain string |
|
SkipLocalTwoFA bool `json:",omitempty"` // Skip Local 2fa for users authenticated with this source |
|
|
|
// reference to the loginSource |
|
loginSource *login.Source |
|
} |
|
|
|
// FromDB fills up a PAMConfig from serialized format. |
|
func (source *Source) FromDB(bs []byte) error { |
|
return models.JSONUnmarshalHandleDoubleEncode(bs, &source) |
|
} |
|
|
|
// ToDB exports a PAMConfig to a serialized format. |
|
func (source *Source) ToDB() ([]byte, error) { |
|
return json.Marshal(source) |
|
} |
|
|
|
// SetLoginSource sets the related LoginSource |
|
func (source *Source) SetLoginSource(loginSource *login.Source) { |
|
source.loginSource = loginSource |
|
} |
|
|
|
func init() { |
|
login.RegisterTypeConfig(login.PAM, &Source{}) |
|
}
|
|
|