mirror of https://github.com/go-gitea/gitea.git
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.
71 lines
1.9 KiB
71 lines
1.9 KiB
// Copyright 2021 The Gitea Authors. All rights reserved. |
|
// SPDX-License-Identifier: MIT |
|
|
|
package pam |
|
|
|
import ( |
|
"context" |
|
"fmt" |
|
"strings" |
|
|
|
"code.gitea.io/gitea/models/auth" |
|
user_model "code.gitea.io/gitea/models/user" |
|
"code.gitea.io/gitea/modules/auth/pam" |
|
"code.gitea.io/gitea/modules/optional" |
|
"code.gitea.io/gitea/modules/setting" |
|
|
|
"github.com/google/uuid" |
|
) |
|
|
|
// Authenticate queries if login/password is valid against the PAM, |
|
// and create a local user if success when enabled. |
|
func (source *Source) Authenticate(ctx context.Context, user *user_model.User, userName, password string) (*user_model.User, error) { |
|
pamLogin, err := pam.Auth(source.ServiceName, userName, password) |
|
if err != nil { |
|
if strings.Contains(err.Error(), "Authentication failure") { |
|
return nil, user_model.ErrUserNotExist{Name: userName} |
|
} |
|
return nil, err |
|
} |
|
|
|
if user != nil { |
|
return user, nil |
|
} |
|
|
|
// Allow PAM sources with `@` in their name, like from Active Directory |
|
username := pamLogin |
|
email := pamLogin |
|
before, _, ok := strings.Cut(pamLogin, "@") |
|
if ok { |
|
username = before |
|
} |
|
if user_model.ValidateEmail(email) != nil { |
|
if source.EmailDomain != "" { |
|
email = fmt.Sprintf("%s@%s", username, source.EmailDomain) |
|
} else { |
|
email = fmt.Sprintf("%s@%s", username, setting.Service.NoReplyAddress) |
|
} |
|
if user_model.ValidateEmail(email) != nil { |
|
email = uuid.New().String() + "@localhost" |
|
} |
|
} |
|
|
|
user = &user_model.User{ |
|
LowerName: strings.ToLower(username), |
|
Name: username, |
|
Email: email, |
|
Passwd: password, |
|
LoginType: auth.PAM, |
|
LoginSource: source.AuthSource.ID, |
|
LoginName: userName, // This is what the user typed in |
|
} |
|
overwriteDefault := &user_model.CreateUserOverwriteOptions{ |
|
IsActive: optional.Some(true), |
|
} |
|
|
|
if err := user_model.CreateUser(ctx, user, &user_model.Meta{}, overwriteDefault); err != nil { |
|
return user, err |
|
} |
|
|
|
return user, nil |
|
}
|
|
|