/**
* Our block options (-p, -r, -a).
*/
-static struct GNUNET_FS_BlockOptions bo = { { 0LL }, 1, 365, 1 };
+static struct GNUNET_FS_BlockOptions bo = { {0LL}, 1, 365, 1 };
/**
* -q option given.
*/
-static int no_remote_printing;
+static int no_remote_printing;
/**
* -r option.
static int ret;
-static void*
-progress_cb (void *cls,
- const struct GNUNET_FS_ProgressInfo *info)
+static void *
+progress_cb (void *cls, const struct GNUNET_FS_ProgressInfo *info)
{
return NULL;
}
static void
-ns_printer (void *cls,
- const char *name,
- const GNUNET_HashCode *id)
+ns_printer (void *cls, const char *name, const GNUNET_HashCode * id)
{
struct GNUNET_CRYPTO_HashAsciiEncoded enc;
GNUNET_CRYPTO_hash_to_enc (id, &enc);
- fprintf (stdout,
- "%s (%s)\n",
- name,
- (const char*) &enc);
+ FPRINTF (stdout, "%s (%s)\n", name, (const char *) &enc);
}
static int
-pseudo_printer (void *cls,
- const GNUNET_HashCode *
- pseudonym,
- const struct
- GNUNET_CONTAINER_MetaData * md,
- int rating)
+pseudo_printer (void *cls, const GNUNET_HashCode * pseudonym,
+ const char *name, const char *unique_name,
+ const struct GNUNET_CONTAINER_MetaData *md, int rating)
{
- char *id;
-
- id = GNUNET_PSEUDONYM_id_to_name (cfg,
- pseudonym);
- if (id == NULL)
- {
- GNUNET_break (0);
- return GNUNET_OK;
- }
- fprintf (stdout,
- "%s (%d):\n",
- id,
- rating);
- GNUNET_CONTAINER_meta_data_iterate (md,
- &EXTRACTOR_meta_data_print,
- stdout);
- fprintf (stdout, "\n");
+ char *id, *unique_id;
+ int getinfo_result;
+
+ /* While we get a name from the caller, it might be NULL.
+ * GNUNET_PSEUDONYM_get_info () never returns NULL.
+ */
+ getinfo_result = GNUNET_PSEUDONYM_get_info (cfg, pseudonym,
+ NULL, NULL, &id, NULL);
+ if (getinfo_result != GNUNET_OK)
+ {
+ GNUNET_break (0);
+ return GNUNET_OK;
+ }
+ unique_id = GNUNET_PSEUDONYM_name_uniquify (cfg, pseudonym, id, NULL);
GNUNET_free (id);
+ FPRINTF (stdout, "%s (%d):\n", unique_id, rating);
+ GNUNET_CONTAINER_meta_data_iterate (md, &EXTRACTOR_meta_data_print, stdout);
+ FPRINTF (stdout, "%s", "\n");
+ GNUNET_free (unique_id);
return GNUNET_OK;
}
static void
-post_advertising (void *cls,
- const struct GNUNET_FS_Uri *uri,
- const char *emsg)
+post_advertising (void *cls, const struct GNUNET_FS_Uri *uri, const char *emsg)
{
GNUNET_HashCode nsid;
char *set;
int delta;
if (emsg != NULL)
- {
- fprintf (stderr, "%s", emsg);
- ret = 1;
- }
+ {
+ FPRINTF (stderr, "%s", emsg);
+ ret = 1;
+ }
if (ns != NULL)
+ {
+ if (GNUNET_OK != GNUNET_FS_namespace_delete (ns, GNUNET_NO))
+ ret = 1;
+ }
+ if (NULL != rating_change)
+ {
+ set = rating_change;
+ while ((*set != '\0') && (*set != ':'))
+ set++;
+ if (*set != ':')
{
- if (GNUNET_OK !=
- GNUNET_FS_namespace_delete (ns,
- GNUNET_NO))
- ret = 1;
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR, _("Invalid argument `%s'\n"),
+ rating_change);
}
- if (NULL != rating_change)
+ else
{
- set = rating_change;
- while ((*set != '\0') && (*set != ':'))
- set++;
- if (*set != ':')
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- _("Invalid argument `%s'\n"),
- rating_change);
- }
+ *set = '\0';
+ delta = strtol (&set[1], NULL, /* no error handling yet */
+ 10);
+ if (GNUNET_OK == GNUNET_PSEUDONYM_name_to_id (cfg, rating_change, &nsid))
+ {
+ (void) GNUNET_PSEUDONYM_rank (cfg, &nsid, delta);
+ }
else
- {
- *set = '\0';
- delta = strtol (&set[1], NULL, /* no error handling yet */
- 10);
- if (GNUNET_OK ==
- GNUNET_PSEUDONYM_name_to_id (cfg,
- rating_change,
- &nsid))
- {
- (void) GNUNET_PSEUDONYM_rank (cfg,
- &nsid,
- delta);
- }
- else
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- _("Namespace `%s' unknown.\n"),
- rating_change);
- }
- }
- GNUNET_free (rating_change);
- rating_change = NULL;
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ ("Namespace `%s' unknown. Make sure you specify its numeric suffix, if any.\n"),
+ rating_change);
+ }
}
+ GNUNET_free (rating_change);
+ rating_change = NULL;
+ }
if (0 != print_local_only)
- {
- GNUNET_FS_namespace_list (h,
- &ns_printer,
- NULL);
- }
+ {
+ GNUNET_FS_namespace_list (h, &ns_printer, NULL);
+ }
else if (0 == no_remote_printing)
- {
- GNUNET_PSEUDONYM_list_all (cfg,
- &pseudo_printer,
- NULL);
- }
+ {
+ GNUNET_PSEUDONYM_list_all (cfg, &pseudo_printer, NULL);
+ }
GNUNET_FS_stop (h);
}
* @param c configuration
*/
static void
-run (void *cls,
- char *const *args,
- const char *cfgfile,
+run (void *cls, char *const *args, const char *cfgfile,
const struct GNUNET_CONFIGURATION_Handle *c)
{
char *emsg;
cfg = c;
- h = GNUNET_FS_start (cfg,
- "gnunet-pseudonym",
- &progress_cb,
- NULL,
- GNUNET_FS_FLAGS_NONE,
- GNUNET_FS_OPTIONS_END);
+ h = GNUNET_FS_start (cfg, "gnunet-pseudonym", &progress_cb, NULL,
+ GNUNET_FS_FLAGS_NONE, GNUNET_FS_OPTIONS_END);
if (NULL != delete_ns)
+ {
+ ns = GNUNET_FS_namespace_create (h, delete_ns);
+ if (ns == NULL)
{
- ns = GNUNET_FS_namespace_create (h, delete_ns);
- if (ns == NULL)
- {
- ret = 1;
- }
- else
- {
- if (GNUNET_OK !=
- GNUNET_FS_namespace_delete (ns,
- GNUNET_YES))
- ret = 1;
- ns = NULL;
- }
+ ret = 1;
+ }
+ else
+ {
+ if (GNUNET_OK != GNUNET_FS_namespace_delete (ns, GNUNET_YES))
+ ret = 1;
+ ns = NULL;
}
+ }
if (NULL != create_ns)
+ {
+ ns = GNUNET_FS_namespace_create (h, create_ns);
+ if (ns == NULL)
{
- ns = GNUNET_FS_namespace_create (h, create_ns);
- if (ns == NULL)
- {
- ret = 1;
- }
+ ret = 1;
+ }
+ else
+ {
+ if (NULL != root_identifier)
+ {
+ if (ksk_uri == NULL)
+ {
+ emsg = NULL;
+ ksk_uri = GNUNET_FS_uri_parse ("gnunet://fs/ksk/namespace", &emsg);
+ GNUNET_assert (NULL == emsg);
+ }
+ GNUNET_FS_namespace_advertise (h, ksk_uri, ns, adv_metadata, &bo,
+ root_identifier, &post_advertising,
+ NULL);
+ return;
+ }
else
- {
- if (NULL != root_identifier)
- {
- if (ksk_uri == NULL)
- {
- emsg = NULL;
- ksk_uri = GNUNET_FS_uri_parse ("gnunet://fs/ksk/namespace", &emsg);
- GNUNET_assert (NULL == emsg);
- }
- GNUNET_FS_namespace_advertise (h,
- ksk_uri,
- ns,
- adv_metadata,
- &bo,
- root_identifier,
- &post_advertising,
- NULL);
- return;
- }
- else
- {
- if (ksk_uri != NULL)
- fprintf (stderr, _("Option `%s' ignored\n"), "-k");
- }
- }
+ {
+ if (ksk_uri != NULL)
+ FPRINTF (stderr, _("Option `%s' ignored\n"), "-k");
+ }
}
+ }
else
- {
- if (root_identifier != NULL)
- fprintf (stderr, _("Option `%s' ignored\n"), "-r");
- if (ksk_uri != NULL)
- fprintf (stderr, _("Option `%s' ignored\n"), "-k");
- }
-
+ {
+ if (root_identifier != NULL)
+ FPRINTF (stderr, _("Option `%s' ignored\n"), "-r");
+ if (ksk_uri != NULL)
+ FPRINTF (stderr, _("Option `%s' ignored\n"), "-k");
+ }
+
post_advertising (NULL, NULL, NULL);
}
gettext_noop ("set the desired LEVEL of sender-anonymity"),
1, &GNUNET_GETOPT_set_uint, &bo.anonymity_level},
{'C', "create", "NAME",
- gettext_noop
- ("create or advertise namespace NAME"),
+ gettext_noop ("create or advertise namespace NAME"),
1, &GNUNET_GETOPT_set_string, &create_ns},
{'D', "delete", "NAME",
- gettext_noop
- ("delete namespace NAME "),
+ gettext_noop ("delete namespace NAME "),
1, &GNUNET_GETOPT_set_string, &delete_ns},
{'k', "keyword", "VALUE",
- gettext_noop
- ("add an additional keyword for the advertisment"
- " (this option can be specified multiple times)"),
+ gettext_noop ("add an additional keyword for the advertisment"
+ " (this option can be specified multiple times)"),
1, &GNUNET_FS_getopt_set_keywords, &ksk_uri},
{'m', "meta", "TYPE:VALUE",
gettext_noop ("set the meta-data for the given TYPE to the given VALUE"),
gettext_noop ("set the desired replication LEVEL"),
1, &GNUNET_GETOPT_set_uint, &bo.replication_level},
{'R', "root", "ID",
- gettext_noop
- ("specify ID of the root of the namespace"),
+ gettext_noop ("specify ID of the root of the namespace"),
1, &GNUNET_GETOPT_set_string, &root_identifier},
{'s', "set-rating", "ID:VALUE",
- gettext_noop
- ("change rating of namespace ID by VALUE"),
+ gettext_noop ("change rating of namespace ID by VALUE"),
1, &GNUNET_GETOPT_set_string, &rating_change},
GNUNET_GETOPT_OPTION_END
};
- bo.expiration_time = GNUNET_FS_year_to_time (GNUNET_FS_get_current_year () + 2);
+ bo.expiration_time =
+ GNUNET_FS_year_to_time (GNUNET_FS_get_current_year () + 2);
return (GNUNET_OK ==
- GNUNET_PROGRAM_run (argc,
- argv,
- "gnunet-pseudonym [OPTIONS]",
- gettext_noop
- ("Manage GNUnet pseudonyms."),
+ GNUNET_PROGRAM_run (argc, argv, "gnunet-pseudonym [OPTIONS]",
+ gettext_noop ("Manage GNUnet pseudonyms."),
options, &run, NULL)) ? ret : 1;
}