From ad897d62a28054dbc4b9d720417336129835f301 Mon Sep 17 00:00:00 2001 From: James Moger Date: Thu, 27 Mar 2014 13:13:29 -0400 Subject: [PATCH] Add command to change the comment of a registered ssh public key --- .../com/gitblit/transport/ssh/SshKey.java | 3 ++ .../transport/ssh/gitblit/KeysDispatcher.java | 50 +++++++++++++++++-- 2 files changed, 49 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/gitblit/transport/ssh/SshKey.java b/src/main/java/com/gitblit/transport/ssh/SshKey.java index 498b6bd4..cb5ee097 100644 --- a/src/main/java/com/gitblit/transport/ssh/SshKey.java +++ b/src/main/java/com/gitblit/transport/ssh/SshKey.java @@ -73,6 +73,9 @@ public class SshKey implements Serializable { public void setComment(String comment) { this.comment = comment; + if (rawData != null) { + rawData = null; + } } public String getRawData() { diff --git a/src/main/java/com/gitblit/transport/ssh/gitblit/KeysDispatcher.java b/src/main/java/com/gitblit/transport/ssh/gitblit/KeysDispatcher.java index b42be17f..5f508e60 100644 --- a/src/main/java/com/gitblit/transport/ssh/gitblit/KeysDispatcher.java +++ b/src/main/java/com/gitblit/transport/ssh/gitblit/KeysDispatcher.java @@ -33,6 +33,7 @@ import com.gitblit.transport.ssh.commands.SshCommand; import com.gitblit.transport.ssh.commands.UsageExample; import com.gitblit.utils.FlipTable; import com.gitblit.utils.FlipTable.Borders; +import com.google.common.base.Joiner; /** * The dispatcher and it's commands for SSH public key management. @@ -49,6 +50,7 @@ public class KeysDispatcher extends DispatchCommand { register(user, RemoveKey.class); register(user, ListKeys.class); register(user, WhichKey.class); + register(user, CommentKey.class); } @CommandMetaData(name = "add", description = "Add an SSH public key to your account") @@ -195,16 +197,56 @@ public class KeysDispatcher extends DispatchCommand { if (showRaw) { stdout.println(key.getRawData()); } else { - asTable(key); + final String username = getContext().getClient().getUsername(); + List keys = getContext().getGitblit().getPublicKeyManager().getKeys(username); + int index = 0; + for (int i = 0; i < keys.size(); i++) { + if (key.equals(keys.get(i))) { + index = i + 1; + break; + } + } + asTable(index, key); } } - protected void asTable(SshKey key) { - String[] headers = { "Fingerprint", "Comment", "Type" }; + protected void asTable(int index, SshKey key) { + String[] headers = { "#", "Fingerprint", "Comment", "Type" }; Object[][] data = new Object[1][]; - data[0] = new Object[] { key.getFingerprint(), key.getComment(), key.getAlgorithm() }; + data[0] = new Object[] { index, key.getFingerprint(), key.getComment(), key.getAlgorithm() }; stdout.println(FlipTable.of(headers, data, Borders.BODY_HCOLS)); } } + + @CommandMetaData(name = "comment", description = "Set the comment for an SSH public key") + @UsageExample(syntax = "${cmd} 3 Home workstation", description = "Set the comment for key #3") + public static class CommentKey extends SshCommand { + + @Argument(index = 0, metaVar = "INDEX", usage = "the key index", required = true) + private int index; + + @Argument(index = 1, metaVar = "COMMENT", usage = "the new comment", required = true) + private List values = new ArrayList(); + + @Override + public void run() throws UnloggedFailure { + final String username = getContext().getClient().getUsername(); + IPublicKeyManager keyManager = getContext().getGitblit().getPublicKeyManager(); + List keys = keyManager.getKeys(username); + if (index > keys.size()) { + throw new UnloggedFailure(1, "Invalid key index!"); + } + + String comment = Joiner.on(" ").join(values); + SshKey key = keys.get(index - 1); + key.setComment(comment); + if (keyManager.addKey(username, key)) { + stdout.println(String.format("Updated the comment for key #%d.", index)); + } else { + throw new UnloggedFailure(1, String.format("Failed to update the comment for key #%d!", index)); + } + } + + } } -- 2.39.5