cmdSecretSetValue: Make it obvious that --file, --base64 and --interactive are exlcusive

Convert the conditions to else if so that it's obvious that only one of
the cases will ever be used.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Peter Krempa 2021-02-01 13:10:59 +01:00
parent ac4b55c99d
commit 26fedf9218
1 changed files with 7 additions and 12 deletions

View File

@ -225,16 +225,10 @@ cmdSecretSetValue(vshControl *ctl, const vshCmd *cmd)
if (vshCommandOptStringReq(ctl, cmd, "file", &filename) < 0) if (vshCommandOptStringReq(ctl, cmd, "file", &filename) < 0)
return false; return false;
if (!base64 && !filename && !interactive) { if (base64) {
vshError(ctl, _("Input secret value is missing"));
return false;
}
/* warn users that the --base64 option passed from command line is wrong */ /* warn users that the --base64 option passed from command line is wrong */
if (base64)
vshError(ctl, _("Passing secret value as command-line argument is insecure!")); vshError(ctl, _("Passing secret value as command-line argument is insecure!"));
} else if (filename) {
if (filename) {
ssize_t read_ret; ssize_t read_ret;
if ((read_ret = virFileReadAll(filename, 1024, &file_buf)) < 0) { if ((read_ret = virFileReadAll(filename, 1024, &file_buf)) < 0) {
vshSaveLibvirtError(); vshSaveLibvirtError();
@ -243,9 +237,7 @@ cmdSecretSetValue(vshControl *ctl, const vshCmd *cmd)
file_len = read_ret; file_len = read_ret;
base64 = file_buf; base64 = file_buf;
} } else if (interactive) {
if (interactive) {
vshPrint(ctl, "%s", _("Enter new value for secret:")); vshPrint(ctl, "%s", _("Enter new value for secret:"));
fflush(stdout); fflush(stdout);
@ -255,6 +247,9 @@ cmdSecretSetValue(vshControl *ctl, const vshCmd *cmd)
} }
file_len = strlen(file_buf); file_len = strlen(file_buf);
plain = true; plain = true;
} else {
vshError(ctl, _("Input secret value is missing"));
return false;
} }
if (plain) { if (plain) {