mirror of
https://gitea.com/gitea/tea
synced 2026-05-03 13:40:48 +02:00
9d6ae4bf02
## Summary - Adds `tea ssh-keys` command group (aliases: `ssh-key`, `keys`) under the SETUP category - Mirrors the interface of `gh ssh-key add/list/delete` - Three subcommands: `add <keyfile>`, `list`, `delete <id>` ## Commands \`\`\`sh tea ssh-keys add ~/.ssh/id_ed25519.pub # title defaults to filename stem tea ssh-keys add ~/.ssh/id_rsa.pub --title "work laptop" tea ssh-keys add ~/.ssh/deploy.pub --read-only # authentication-only key tea ssh-keys list tea ssh-keys list --output json tea ssh-keys delete 42 # prompts for confirmation tea ssh-keys delete 42 --force # skip prompt \`\`\` ## Test plan - [x] `make lint` — 0 issues - [x] `make fmt-check` — passes - [x] `go test ./cmd/sshkeys/... -run TestKeyTitle` — unit tests pass (no server needed) - [ ] Integration tests with live Gitea instance: \`\`\`sh GITEA_TEA_TEST_URL=https://your-gitea \ GITEA_TEA_TEST_TOKEN=<token> \ go test ./cmd/sshkeys/... -v -run TestSSHKey \`\`\` Exercises full add → SDK-verify → delete → 404-verify lifecycle. --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: Brandon Fryslie <530235+brandon-fryslie@users.noreply.github.com> Reviewed-on: https://gitea.com/gitea/tea/pulls/940 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: Brandon Fryslie <186614+brandroid@noreply.gitea.com> Co-committed-by: Brandon Fryslie <186614+brandroid@noreply.gitea.com>
77 lines
1.8 KiB
Go
77 lines
1.8 KiB
Go
// Copyright 2026 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package sshkeys
|
|
|
|
import (
|
|
stdctx "context"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"code.gitea.io/tea/cmd/flags"
|
|
"code.gitea.io/tea/modules/context"
|
|
|
|
"github.com/urfave/cli/v3"
|
|
)
|
|
|
|
// CmdSSHKeyDelete represents a sub command of ssh-keys to delete an SSH key by ID
|
|
var CmdSSHKeyDelete = cli.Command{
|
|
Name: "delete",
|
|
Aliases: []string{"rm"},
|
|
Usage: "Delete an SSH key",
|
|
Description: "Delete an SSH key from the current user's profile by its numeric ID",
|
|
ArgsUsage: "<key-id>",
|
|
Action: RunSSHKeyDelete,
|
|
Flags: append([]cli.Flag{
|
|
&cli.BoolFlag{
|
|
Name: "confirm",
|
|
Aliases: []string{"y"},
|
|
Usage: "Confirm deletion (required)",
|
|
},
|
|
}, flags.LoginOutputFlags...),
|
|
}
|
|
|
|
// RunSSHKeyDelete removes an SSH key by its numeric ID
|
|
func RunSSHKeyDelete(_ stdctx.Context, cmd *cli.Command) error {
|
|
ctx, err := context.InitCommand(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if ctx.Args().Len() < 1 {
|
|
return fmt.Errorf("key ID is required")
|
|
}
|
|
|
|
keyID, err := strconv.ParseInt(ctx.Args().First(), 10, 64)
|
|
if err != nil {
|
|
return fmt.Errorf("invalid key ID '%s': must be a number", ctx.Args().First())
|
|
}
|
|
|
|
client := ctx.Login.Client()
|
|
|
|
key, resp, err := client.GetPublicKey(keyID)
|
|
if err != nil {
|
|
if resp != nil && resp.StatusCode == 404 {
|
|
return fmt.Errorf("SSH key with ID %d not found", keyID)
|
|
}
|
|
return err
|
|
}
|
|
|
|
if !ctx.Bool("confirm") {
|
|
fmt.Printf("Are you sure you want to delete SSH key '%s' (id: %d)? [y/N] ", key.Title, keyID)
|
|
var response string
|
|
fmt.Scanln(&response)
|
|
if response != "y" && response != "Y" && response != "yes" {
|
|
fmt.Println("Deletion canceled.")
|
|
return nil
|
|
}
|
|
}
|
|
|
|
if _, err = client.DeletePublicKey(keyID); err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Printf("SSH key '%s' deleted successfully\n", key.Title)
|
|
return nil
|
|
}
|