2021-12-10 09:14:24 +01:00
|
|
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
2022-11-27 19:20:29 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-12-10 09:14:24 +01:00
|
|
|
|
|
|
|
package asymkey
|
|
|
|
|
|
|
|
import (
|
|
|
|
asymkey_model "code.gitea.io/gitea/models/asymkey"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
|
|
user_model "code.gitea.io/gitea/models/user"
|
|
|
|
)
|
|
|
|
|
|
|
|
// DeletePublicKey deletes SSH key information both in database and authorized_keys file.
|
|
|
|
func DeletePublicKey(doer *user_model.User, id int64) (err error) {
|
|
|
|
key, err := asymkey_model.GetPublicKeyByID(id)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if user has access to delete this key.
|
|
|
|
if !doer.IsAdmin && doer.ID != key.OwnerID {
|
|
|
|
return asymkey_model.ErrKeyAccessDenied{
|
|
|
|
UserID: doer.ID,
|
|
|
|
KeyID: key.ID,
|
|
|
|
Note: "public",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-12 21:18:50 +01:00
|
|
|
ctx, committer, err := db.TxContext(db.DefaultContext)
|
2021-12-10 09:14:24 +01:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer committer.Close()
|
|
|
|
|
|
|
|
if err = asymkey_model.DeletePublicKeys(ctx, id); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = committer.Commit(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
committer.Close()
|
|
|
|
|
|
|
|
if key.Type == asymkey_model.KeyTypePrincipal {
|
2022-05-20 16:08:52 +02:00
|
|
|
return asymkey_model.RewriteAllPrincipalKeys(db.DefaultContext)
|
2021-12-10 09:14:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return asymkey_model.RewriteAllPublicKeys()
|
|
|
|
}
|