3 This file is part of GNUnet.
4 (C) 2012, 2013 Christian Grothoff (and other contributing authors)
6 GNUnet is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published
8 by the Free Software Foundation; either version 3, or (at your
9 option) any later version.
11 GNUnet is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNUnet; see the file COPYING. If not, write to the
18 Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA.
22 * @file gnunet-namecache.c
23 * @brief command line tool to inspect the name cache
24 * @author Christian Grothoff
30 #include "gnunet_util_lib.h"
31 #include "gnunet_dnsparser_lib.h"
32 #include "gnunet_identity_service.h"
33 #include "gnunet_gnsrecord_lib.h"
34 #include "gnunet_namecache_service.h"
38 * Handle to the namecache.
40 static struct GNUNET_NAMECACHE_Handle *ns;
43 * Queue entry for the 'query' operation.
45 static struct GNUNET_NAMECACHE_QueueEntry *qe;
48 * Name (label) of the records to list.
53 * Public key of the zone to look in.
55 static struct GNUNET_CRYPTO_EcdsaPublicKey pubkey;
58 * Public key of the zone to look in, in ASCII.
69 * Task run on shutdown. Cleans up everything.
72 * @param tc scheduler context
75 do_shutdown (void *cls,
76 const struct GNUNET_SCHEDULER_TaskContext *tc)
80 GNUNET_NAMECACHE_cancel (qe);
85 GNUNET_NAMECACHE_disconnect (ns);
92 * Process a record that was stored in the namecache in a block.
94 * @param cls closure, NULL
95 * @param rd_len number of entries in @a rd array
96 * @param rd array of records with data to store
99 display_records_from_block (void *cls,
101 const struct GNUNET_GNSRECORD_Data *rd)
103 const char *typestring;
110 _("No records found for `%s'"),
117 for (i=0;i<rd_len;i++)
119 typestring = GNUNET_GNSRECORD_number_to_typename (rd[i].record_type);
120 s = GNUNET_GNSRECORD_value_to_string (rd[i].record_type,
125 FPRINTF (stdout, _("\tCorrupt or unsupported record of type %u\n"),
126 (unsigned int) rd[i].record_type);
135 FPRINTF (stdout, "%s", "\n");
140 * Display block obtained from listing (by name).
143 * @param block NULL if not found
146 handle_block (void *cls,
147 const struct GNUNET_GNSRECORD_Block *block)
153 "No matching block found\n");
155 else if (GNUNET_OK !=
156 GNUNET_GNSRECORD_block_decrypt (block,
159 &display_records_from_block,
163 "Failed to decrypt block!\n");
165 GNUNET_SCHEDULER_shutdown ();
170 * Main function that will be run.
173 * @param args remaining command-line arguments
174 * @param cfgfile name of the configuration file used (for saving, can be NULL!)
175 * @param cfg configuration
178 run (void *cls, char *const *args, const char *cfgfile,
179 const struct GNUNET_CONFIGURATION_Handle *cfg)
181 struct GNUNET_HashCode dhash;
186 _("You must specify which zone should be accessed\n"));
191 GNUNET_CRYPTO_ecdsa_public_key_from_string (pkey,
196 _("Invalid public key for reverse lookup `%s'\n"),
198 GNUNET_SCHEDULER_shutdown ();
201 GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_FOREVER_REL,
204 GNUNET_GNSRECORD_query_from_public_key (&pubkey,
207 qe = GNUNET_NAMECACHE_lookup_block (ns,
215 * The main function for gnunet-namecache.
217 * @param argc number of arguments from the command line
218 * @param argv command line arguments
219 * @return 0 ok, 1 on error
222 main (int argc, char *const *argv)
224 static const struct GNUNET_GETOPT_CommandLineOption options[] = {
225 {'n', "name", "NAME",
226 gettext_noop ("name of the record to add/delete/display"), 1,
227 &GNUNET_GETOPT_set_string, &name},
228 {'z', "zone", "PKEY",
229 gettext_noop ("spezifies the public key of the zone to look in"), 1,
230 &GNUNET_GETOPT_set_string, &pkey},
231 GNUNET_GETOPT_OPTION_END
234 if (GNUNET_OK != GNUNET_STRINGS_get_utf8_args (argc, argv, &argc, &argv))
237 GNUNET_log_setup ("gnunet-namecache", "WARNING", NULL);
239 GNUNET_PROGRAM_run (argc, argv, "gnunet-namecache",
240 _("GNUnet zone manipulation tool"),
244 GNUNET_free ((void*) argv);
247 GNUNET_free ((void*) argv);
251 /* end of gnunet-namecache.c */