|
|
|
@ -117,16 +117,6 @@ func (key *PublicKey) GetAuthorizedString() string {
|
|
|
|
|
return fmt.Sprintf(_TPL_PUBLICK_KEY, appPath, key.ID, setting.CustomConf, key.Content)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var minimumKeySizes = map[string]int{
|
|
|
|
|
"(ED25519)": 256,
|
|
|
|
|
"(ECDSA)": 256,
|
|
|
|
|
"(NTRU)": 1087,
|
|
|
|
|
"(MCE)": 1702,
|
|
|
|
|
"(McE)": 1702,
|
|
|
|
|
"(RSA)": 1024,
|
|
|
|
|
"(DSA)": 1024,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func extractTypeFromBase64Key(key string) (string, error) {
|
|
|
|
|
b, err := base64.StdEncoding.DecodeString(key)
|
|
|
|
|
if err != nil || len(b) < 4 {
|
|
|
|
@ -251,8 +241,8 @@ func CheckPublicKeyString(content string) (_ string, err error) {
|
|
|
|
|
if keySize == 0 {
|
|
|
|
|
return "", errors.New("cannot get key size of the given key")
|
|
|
|
|
}
|
|
|
|
|
keyType := strings.TrimSpace(sshKeygenOutput[len(sshKeygenOutput)-1])
|
|
|
|
|
if minimumKeySize := minimumKeySizes[keyType]; minimumKeySize == 0 {
|
|
|
|
|
keyType := strings.Trim(sshKeygenOutput[len(sshKeygenOutput)-1], " ()")
|
|
|
|
|
if minimumKeySize := setting.Service.MinimumKeySizes[keyType]; minimumKeySize == 0 {
|
|
|
|
|
return "", errors.New("sorry, unrecognized public key type")
|
|
|
|
|
} else if keySize < minimumKeySize {
|
|
|
|
|
return "", fmt.Errorf("the minimum accepted size of a public key %s is %d", keyType, minimumKeySize)
|
|
|
|
|