mirror of
https://gitea.com/gitea/tea
synced 2024-11-23 00:12:05 +01:00
6a4ba6a689
This adds support for authentication using a SSH certificate and normal public keys when you've got an ssh-agent running that has this certificate or your public key loaded. First question when creating a new login is to ask about the ssh certificates or public keys, when the answer is yes, we don't need to ask about tokens/usernames anymore. Co-authored-by: Wim <wim@42.be> Reviewed-on: https://gitea.com/gitea/tea/pulls/442 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: 6543 <6543@obermui.de> Co-authored-by: Wim <42wim@noreply.gitea.io> Co-committed-by: Wim <42wim@noreply.gitea.io>
44 lines
890 B
Go
44 lines
890 B
Go
// Copyright 2020 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 utils
|
|
|
|
import (
|
|
"os"
|
|
|
|
"golang.org/x/crypto/ssh"
|
|
)
|
|
|
|
// Contains checks containment
|
|
func Contains(haystack []string, needle string) bool {
|
|
return IndexOf(haystack, needle) != -1
|
|
}
|
|
|
|
// IndexOf returns the index of first occurrence of needle in haystack
|
|
func IndexOf(haystack []string, needle string) int {
|
|
for i, s := range haystack {
|
|
if s == needle {
|
|
return i
|
|
}
|
|
}
|
|
return -1
|
|
}
|
|
|
|
// IsKeyEncrypted checks if the key is encrypted
|
|
func IsKeyEncrypted(sshKey string) (bool, error) {
|
|
priv, err := os.ReadFile(sshKey)
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
|
|
_, err = ssh.ParsePrivateKey(priv)
|
|
if err != nil {
|
|
if _, ok := err.(*ssh.PassphraseMissingError); ok {
|
|
return true, nil
|
|
}
|
|
}
|
|
|
|
return false, err
|
|
}
|