aboutsummaryrefslogtreecommitdiffstats
path: root/find-contact-by-pgpkey.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2021-04-03 02:28:44 +0200
committerMattias Andrée <maandree@kth.se>2021-04-03 02:28:44 +0200
commit49e4bd18d29d5ef9c85d106026b09d86de6ff19c (patch)
treeacaad00d8d6df3a9dd6f0780fb837933b6ccddfd /find-contact-by-pgpkey.c
downloadcontacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.gz
contacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.bz2
contacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.xz
First commmit
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'find-contact-by-pgpkey.c')
-rw-r--r--find-contact-by-pgpkey.c62
1 files changed, 62 insertions, 0 deletions
diff --git a/find-contact-by-pgpkey.c b/find-contact-by-pgpkey.c
new file mode 100644
index 0000000..85d2202
--- /dev/null
+++ b/find-contact-by-pgpkey.c
@@ -0,0 +1,62 @@
+/* See LICENSE file for copyright and license details. */
+#include "common.h"
+
+USAGE("[-c context] (-L | fingerprint)");
+
+
+int
+main(int argc, char *argv[])
+{
+ int list = 0;
+ struct passwd *user;
+ struct libcontacts_contact **contacts;
+ struct libcontacts_pgpkey **pgpkeys, *pgpkey;
+ char *context = NULL;
+ size_t i;
+
+ ARGBEGIN {
+ case 'c':
+ if (context)
+ usage();
+ context = ARG();
+ break;
+ case 'L':
+ list = 1;
+ break;
+ default:
+ usage();
+ } ARGEND;
+
+ if (argc != 1 - list)
+ usage();
+
+ errno = 0;
+ user = getpwuid(getuid());
+ if (!user)
+ eprintf("getpwuid: %s\n", errno ? strerror(errno) : "user does not exist");
+
+ if (libcontacts_load_contacts(&contacts, user))
+ eprintf("libcontacts_load_contacts:");
+ for (i = 0; contacts[i]; i++) {
+ if ((pgpkeys = contacts[i]->pgpkeys)) {
+ for (; (pgpkey = *pgpkeys); pgpkeys++) {
+ if (!pgpkey->id)
+ continue;
+ if (context && (!pgpkey->context || strcmp(pgpkey->context, context)))
+ continue;
+ if (list)
+ printf("%s (%s)\n", contacts[i]->id, pgpkey->id);
+ else if (!strcmp(pgpkey->id, argv[0]))
+ printf("%s\n", contacts[i]->id);
+ }
+ }
+ libcontacts_contact_destroy(contacts[i]);
+ free(contacts[i]);
+ }
+ free(contacts);
+
+ if (fflush(stdout) || ferror(stdout) || fclose(stdout))
+ eprintf("printf:");
+
+ return 0;
+}