aboutsummaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authorJerry Jacobs <xor-gate@users.noreply.github.com>2018-10-31 01:08:30 +0100
committertechknowlogick <hello@techknowlogick.com>2018-10-30 20:08:30 -0400
commit22ad514297b1958f93913aacbb88b81a94113a1e (patch)
treeee448a94eeef244da26a834be10e77d13b655fa5 /models
parentb686bd0c9467885308a8e45214e75ee270c084e2 (diff)
downloadgitea-22ad514297b1958f93913aacbb88b81a94113a1e.tar.gz
gitea-22ad514297b1958f93913aacbb88b81a94113a1e.zip
Fix issue where ecdsa and other key types are not synced from LDAP (#5092) (#5094)
* Fix issue where ecdsa and other key types are not synced from LDAP authentication provider fixes #5092 * integrations/auth_ldap_test.go: Add Hermes Conrad new ecdsa-sha2-nistp256 publickey fingerprint * integrations/auth_ldap_test.go: Use ssh-keygen -lf <filename> -E sha256
Diffstat (limited to 'models')
-rw-r--r--models/user.go4
1 files changed, 3 insertions, 1 deletions
diff --git a/models/user.go b/models/user.go
index 32e7dda2cb..9469d6e793 100644
--- a/models/user.go
+++ b/models/user.go
@@ -29,6 +29,7 @@ import (
"github.com/go-xorm/xorm"
"github.com/nfnt/resize"
"golang.org/x/crypto/pbkdf2"
+ "golang.org/x/crypto/ssh"
"code.gitea.io/git"
api "code.gitea.io/sdk/gitea"
@@ -1454,7 +1455,8 @@ func deleteKeysMarkedForDeletion(keys []string) (bool, error) {
func addLdapSSHPublicKeys(s *LoginSource, usr *User, SSHPublicKeys []string) bool {
var sshKeysNeedUpdate bool
for _, sshKey := range SSHPublicKeys {
- if strings.HasPrefix(strings.ToLower(sshKey), "ssh") {
+ _, _, _, _, err := ssh.ParseAuthorizedKey([]byte(sshKey))
+ if err == nil {
sshKeyName := fmt.Sprintf("%s-%s", s.Name, sshKey[0:40])
if _, err := AddPublicKey(usr.ID, sshKeyName, sshKey, s.ID); err != nil {
log.Error(4, "addLdapSSHPublicKeys[%s]: Error adding LDAP Public SSH Key for user %s: %v", s.Name, usr.Name, err)