actions: renaming
This commit is contained in:
parent
02c2ba8f0f
commit
fbe829f71e
|
@ -257,6 +257,42 @@ int action_rename (bool yes,
|
||||||
const std::string&filter, const std::string&name,
|
const std::string&filter, const std::string&name,
|
||||||
keyring&KR)
|
keyring&KR)
|
||||||
{
|
{
|
||||||
|
if (name.length() ) {
|
||||||
|
err ("error: missing new name specification");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
int kc = 0;
|
||||||
|
for (keyring::pubkey_storage::iterator
|
||||||
|
i = KR.pubs.begin(), e = KR.pubs.end();
|
||||||
|
i != e; ++i) {
|
||||||
|
if (keyspec_matches (filter, i->second.name, i->first) )
|
||||||
|
++kc;
|
||||||
|
}
|
||||||
|
if (!kc) {
|
||||||
|
err ("error: no such key");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (kc > 1 && !yes) {
|
||||||
|
bool okay = false;
|
||||||
|
ask_for_yes (okay, "This will rename " << kc
|
||||||
|
<< " pubkeys from your keyring to `"
|
||||||
|
<< name << "'. Continue?");
|
||||||
|
if (!okay) return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//do the renaming
|
||||||
|
for (keyring::pubkey_storage::iterator
|
||||||
|
i = KR.pubs.begin(), e = KR.pubs.end();
|
||||||
|
i != e; ++i) {
|
||||||
|
if (keyspec_matches (filter, i->second.name, i->first) )
|
||||||
|
i->second.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!KR.save() ) {
|
||||||
|
err ("error: couldn't save keyring");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -306,7 +342,7 @@ int action_delete_sec (bool yes, const std::string&filter, keyring&KR)
|
||||||
++kc;
|
++kc;
|
||||||
}
|
}
|
||||||
if (!kc) {
|
if (!kc) {
|
||||||
err ("no such key");
|
err ("error: no such key");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (!yes) {
|
if (!yes) {
|
||||||
|
@ -342,5 +378,41 @@ int action_rename_sec (bool yes,
|
||||||
const std::string&filter, const std::string&name,
|
const std::string&filter, const std::string&name,
|
||||||
keyring&KR)
|
keyring&KR)
|
||||||
{
|
{
|
||||||
|
if (!name.length() ) {
|
||||||
|
err ("error: missing new name specification");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int kc = 0;
|
||||||
|
for (keyring::keypair_storage::iterator
|
||||||
|
i = KR.pairs.begin(), e = KR.pairs.end();
|
||||||
|
i != e; ++i) {
|
||||||
|
if (keyspec_matches (filter, i->second.pub.name, i->first) )
|
||||||
|
++kc;
|
||||||
|
}
|
||||||
|
if (!kc) {
|
||||||
|
err ("error: no such key");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (!yes) {
|
||||||
|
bool okay = false;
|
||||||
|
ask_for_yes (okay, "This will rename " << kc
|
||||||
|
<< " secrets from your keyring to `"
|
||||||
|
<< name << "'. Continue?");
|
||||||
|
if (!okay) return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//do the renaming
|
||||||
|
for (keyring::keypair_storage::iterator
|
||||||
|
i = KR.pairs.begin(), e = KR.pairs.end();
|
||||||
|
i != e; ++i) {
|
||||||
|
if (keyspec_matches (filter, i->second.pub.name, i->first) )
|
||||||
|
i->second.pub.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!KR.save() ) {
|
||||||
|
err ("error: couldn't save keyring");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue