GNUnet 0.22.0
plugin_reclaim_credential_pabc.c File Reference

reclaim-credential-plugin-pabc attribute plugin to provide the API for pabc credentials. More...

#include "gnunet_common.h"
#include "platform.h"
#include "gnunet_util_lib.h"
#include "gnunet_reclaim_plugin.h"
#include <inttypes.h>
#include <jansson.h>
#include <pabc/pabc.h>
#include "pabc_helper.h"
Include dependency graph for plugin_reclaim_credential_pabc.c:

Go to the source code of this file.

Functions

static char * pabc_value_to_string (void *cls, uint32_t type, const void *data, size_t data_size)
 Convert the 'value' of an credential to a string. More...
 
static int pabc_string_to_value (void *cls, uint32_t type, const char *s, void **data, size_t *data_size)
 Convert human-readable version of a 'value' of an credential to the binary representation. More...
 
static uint32_t pabc_typename_to_number (void *cls, const char *pabc_typename)
 Convert a type name to the corresponding number. More...
 
static const char * pabc_number_to_typename (void *cls, uint32_t type)
 Convert a type number (i.e. More...
 
static void inspect_attrs (char const *const key, char const *const value, void *ctx)
 
static struct GNUNET_RECLAIM_AttributeListpabc_parse_attributes (void *cls, const char *data, size_t data_size)
 Parse a pabc and return the respective claim value as Attribute. More...
 
static struct GNUNET_RECLAIM_AttributeListpabc_parse_attributes_c (void *cls, const struct GNUNET_RECLAIM_Credential *cred)
 Parse a pabc and return the respective claim value as Attribute. More...
 
static struct GNUNET_RECLAIM_AttributeListpabc_parse_attributes_p (void *cls, const struct GNUNET_RECLAIM_Presentation *cred)
 Parse a pabc and return the respective claim value as Attribute. More...
 
static char * pabc_get_issuer (void *cls, const char *data, size_t data_size)
 Parse a pabc and return the issuer. More...
 
static char * pabc_get_issuer_c (void *cls, const struct GNUNET_RECLAIM_Credential *cred)
 Parse a pabc and return the issuer. More...
 
static char * pabc_get_issuer_p (void *cls, const struct GNUNET_RECLAIM_Presentation *cred)
 Parse a pabc and return the issuer. More...
 
static enum GNUNET_GenericReturnValue pabc_get_expiration (void *cls, const char *data, size_t data_size, struct GNUNET_TIME_Absolute *exp)
 Parse a pabc and return the expiration. More...
 
static enum GNUNET_GenericReturnValue pabc_get_expiration_c (void *cls, const struct GNUNET_RECLAIM_Credential *cred, struct GNUNET_TIME_Absolute *exp)
 Parse a pabc and return the expiration. More...
 
static enum GNUNET_GenericReturnValue pabc_get_expiration_p (void *cls, const struct GNUNET_RECLAIM_Presentation *cred, struct GNUNET_TIME_Absolute *exp)
 Parse a pabc and return the expiration. More...
 
static enum GNUNET_GenericReturnValue pabc_create_presentation (void *cls, const struct GNUNET_RECLAIM_Credential *credential, const struct GNUNET_RECLAIM_AttributeList *attrs, struct GNUNET_RECLAIM_Presentation **presentation)
 
void * libgnunet_plugin_reclaim_credential_pabc_init (void *cls)
 Entry point for the plugin. More...
 
void * libgnunet_plugin_reclaim_credential_pabc_done (void *cls)
 Exit point from the plugin. More...
 

Variables

struct {
   const char *   name
 
   uint32_t   number
 
pabc_cred_name_map []
 Mapping of credential type numbers to human-readable credential type names. More...
 

Detailed Description

reclaim-credential-plugin-pabc attribute plugin to provide the API for pabc credentials.

Author
Martin Schanzenbach

Definition in file plugin_reclaim_credential_pabc.c.

Function Documentation

◆ pabc_value_to_string()

static char * pabc_value_to_string ( void *  cls,
uint32_t  type,
const void *  data,
size_t  data_size 
)
static

Convert the 'value' of an credential to a string.

Parameters
clsclosure, unused
typetype of the credential
datavalue in binary encoding
data_sizenumber of bytes in data
Returns
NULL on error, otherwise human-readable representation of the value

Definition at line 47 of file plugin_reclaim_credential_pabc.c.

51{
52 switch (type)
53 {
56
57 default:
58 return NULL;
59 }
60}
static char * data
The data to insert into the dht.
static uint32_t type
Type string converted to DNS type value.
static size_t data_size
Number of bytes in data.
#define GNUNET_strndup(a, length)
Wrapper around GNUNET_xstrndup_.
@ GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC
libpabc credential

References data, data_size, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, GNUNET_strndup, and type.

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the caller graph for this function:

◆ pabc_string_to_value()

static int pabc_string_to_value ( void *  cls,
uint32_t  type,
const char *  s,
void **  data,
size_t *  data_size 
)
static

Convert human-readable version of a 'value' of an credential to the binary representation.

Parameters
clsclosure, unused
typetype of the credential
shuman-readable string
dataset to value in binary encoding (will be allocated)
data_sizeset to number of bytes in data
Returns
GNUNET_OK on success

Definition at line 75 of file plugin_reclaim_credential_pabc.c.

80{
81 if (NULL == s)
82 return GNUNET_SYSERR;
83 switch (type)
84 {
86 *data = GNUNET_strdup (s);
87 *data_size = strlen (s) + 1;
88 return GNUNET_OK;
89
90 default:
91 return GNUNET_SYSERR;
92 }
93}
@ GNUNET_OK
@ GNUNET_SYSERR
#define GNUNET_strdup(a)
Wrapper around GNUNET_xstrdup_.

References data, data_size, GNUNET_OK, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, GNUNET_strdup, GNUNET_SYSERR, and type.

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the caller graph for this function:

◆ pabc_typename_to_number()

static uint32_t pabc_typename_to_number ( void *  cls,
const char *  pabc_typename 
)
static

Convert a type name to the corresponding number.

Parameters
clsclosure, unused
pabc_typenamename to convert
Returns
corresponding number, UINT32_MAX on error

Definition at line 115 of file plugin_reclaim_credential_pabc.c.

116{
117 unsigned int i;
118
119 i = 0;
120 while ((NULL != pabc_cred_name_map[i].name) &&
121 (0 != strcasecmp (pabc_typename, pabc_cred_name_map[i].name)))
122 i++;
123 return pabc_cred_name_map[i].number;
124}
const char * name
static struct @43 pabc_cred_name_map[]
Mapping of credential type numbers to human-readable credential type names.

References name, and pabc_cred_name_map.

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the caller graph for this function:

◆ pabc_number_to_typename()

static const char * pabc_number_to_typename ( void *  cls,
uint32_t  type 
)
static

Convert a type number (i.e.

1) to the corresponding type string

Parameters
clsclosure, unused
typenumber of a type to convert
Returns
corresponding typestring, NULL on error

Definition at line 135 of file plugin_reclaim_credential_pabc.c.

136{
137 unsigned int i;
138
139 i = 0;
140 while ((NULL != pabc_cred_name_map[i].name) && (type !=
142 number))
143 i++;
144 return pabc_cred_name_map[i].name;
145}

References name, number, pabc_cred_name_map, and type.

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the caller graph for this function:

◆ inspect_attrs()

static void inspect_attrs ( char const *const  key,
char const *const  value,
void *  ctx 
)
static

Definition at line 149 of file plugin_reclaim_credential_pabc.c.

152{
153 struct GNUNET_RECLAIM_AttributeList *attrs = ctx;
154
155 if (NULL == value)
156 return;
158 "Found attribute in PABC credential: `%s': `%s'\n",
159 key, value);
160 if (0 == strcmp (key, "expiration"))
161 return;
162 if (0 == strcmp (key, "issuer"))
163 return;
164 if (0 == strcmp (key, "subject"))
165 return;
167 key,
168 NULL,
170 value,
171 strlen (value));
172}
struct GNUNET_HashCode key
The key used in the DHT.
static struct GNUNET_FS_Handle * ctx
static char * value
Value of the record to add/remove.
#define GNUNET_log(kind,...)
@ GNUNET_ERROR_TYPE_DEBUG
void GNUNET_RECLAIM_attribute_list_add(struct GNUNET_RECLAIM_AttributeList *attrs, const char *attr_name, const struct GNUNET_RECLAIM_Identifier *credential, uint32_t type, const void *data, size_t data_size)
Add a new attribute to a claim list.
@ GNUNET_RECLAIM_ATTRIBUTE_TYPE_STRING
String attribute.
A list of GNUNET_RECLAIM_Attribute structures.

References ctx, GNUNET_ERROR_TYPE_DEBUG, GNUNET_log, GNUNET_RECLAIM_attribute_list_add(), GNUNET_RECLAIM_ATTRIBUTE_TYPE_STRING, key, and value.

Referenced by pabc_parse_attributes().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_parse_attributes()

static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes ( void *  cls,
const char *  data,
size_t  data_size 
)
static

Parse a pabc and return the respective claim value as Attribute.

Parameters
clsthe plugin
credthe pabc credential
Returns
a GNUNET_RECLAIM_Attribute, containing the new value

Definition at line 183 of file plugin_reclaim_credential_pabc.c.

186{
187 struct GNUNET_RECLAIM_AttributeList *attrs;
188
190 "Collecting PABC attributes...\n");
192 GNUNET_assert (PABC_OK ==
193 pabc_cred_inspect_credential (data,
194 &inspect_attrs, attrs));
195 return attrs;
196}
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
#define GNUNET_new(type)
Allocate a struct or union of the given type.
static void inspect_attrs(char const *const key, char const *const value, void *ctx)

References data, GNUNET_assert, GNUNET_ERROR_TYPE_DEBUG, GNUNET_log, GNUNET_new, and inspect_attrs().

Referenced by pabc_parse_attributes_c(), and pabc_parse_attributes_p().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_parse_attributes_c()

static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes_c ( void *  cls,
const struct GNUNET_RECLAIM_Credential cred 
)
static

Parse a pabc and return the respective claim value as Attribute.

Parameters
clsthe plugin
credthe pabc credential
Returns
a GNUNET_RECLAIM_Attribute, containing the new value

Definition at line 207 of file plugin_reclaim_credential_pabc.c.

209{
211 return NULL;
212 return pabc_parse_attributes (cls, cred->data, cred->data_size);
213}
static gnutls_certificate_credentials_t cred
The credential.
static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes(void *cls, const char *data, size_t data_size)
Parse a pabc and return the respective claim value as Attribute.

References cred, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_parse_attributes().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_parse_attributes_p()

static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes_p ( void *  cls,
const struct GNUNET_RECLAIM_Presentation cred 
)
static

Parse a pabc and return the respective claim value as Attribute.

Parameters
clsthe plugin
credthe pabc credential
Returns
a GNUNET_RECLAIM_Attribute, containing the new value

Definition at line 224 of file plugin_reclaim_credential_pabc.c.

226{
228 return NULL;
229 return pabc_parse_attributes (cls, cred->data, cred->data_size);
230}

References cred, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_parse_attributes().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_get_issuer()

static char * pabc_get_issuer ( void *  cls,
const char *  data,
size_t  data_size 
)
static

Parse a pabc and return the issuer.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 241 of file plugin_reclaim_credential_pabc.c.

244{
245 char *res;
246 if (PABC_OK != pabc_cred_get_attr_by_name_from_cred (data,
247 "issuer",
248 &res))
249 return NULL;
250 return res;
251}
static char * res
Currently read line or NULL on EOF.

References data, and res.

Referenced by pabc_get_issuer_c(), and pabc_get_issuer_p().

Here is the caller graph for this function:

◆ pabc_get_issuer_c()

static char * pabc_get_issuer_c ( void *  cls,
const struct GNUNET_RECLAIM_Credential cred 
)
static

Parse a pabc and return the issuer.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 262 of file plugin_reclaim_credential_pabc.c.

264{
266 return NULL;
267 return pabc_get_issuer (cls, cred->data, cred->data_size);
268}
static char * pabc_get_issuer(void *cls, const char *data, size_t data_size)
Parse a pabc and return the issuer.

References cred, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_get_issuer().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init(), and pabc_create_presentation().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_get_issuer_p()

static char * pabc_get_issuer_p ( void *  cls,
const struct GNUNET_RECLAIM_Presentation cred 
)
static

Parse a pabc and return the issuer.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 279 of file plugin_reclaim_credential_pabc.c.

281{
283 return NULL;
284 return pabc_get_issuer (cls, cred->data, cred->data_size);
285}

References cred, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_get_issuer().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_get_expiration()

static enum GNUNET_GenericReturnValue pabc_get_expiration ( void *  cls,
const char *  data,
size_t  data_size,
struct GNUNET_TIME_Absolute exp 
)
static

Parse a pabc and return the expiration.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 296 of file plugin_reclaim_credential_pabc.c.

300{
301 char *exp_str;
302 uint64_t exp_i;
303
304 if (PABC_OK != pabc_cred_get_attr_by_name_from_cred (data,
305 "expiration",
306 &exp_str))
307 return GNUNET_SYSERR;
308
309 if (1 != sscanf (exp_str, "%llu", &exp_i))
310 {
312 "Invalid expiration `%s'\n", exp_str);
313 GNUNET_free (exp_str);
314 return GNUNET_SYSERR;
315 }
317 "Converted expiration string `%s' to %llu",
318 exp_str, exp_i);
319
320 GNUNET_free (exp_str);
321 exp->abs_value_us = exp_i * 1000 * 1000;
322 return GNUNET_OK;
323}
@ GNUNET_ERROR_TYPE_ERROR
#define GNUNET_free(ptr)
Wrapper around free.
uint64_t abs_value_us
The actual value.

References GNUNET_TIME_Absolute::abs_value_us, data, GNUNET_ERROR_TYPE_DEBUG, GNUNET_ERROR_TYPE_ERROR, GNUNET_free, GNUNET_log, GNUNET_OK, and GNUNET_SYSERR.

Referenced by pabc_get_expiration_c(), and pabc_get_expiration_p().

Here is the caller graph for this function:

◆ pabc_get_expiration_c()

static enum GNUNET_GenericReturnValue pabc_get_expiration_c ( void *  cls,
const struct GNUNET_RECLAIM_Credential cred,
struct GNUNET_TIME_Absolute exp 
)
static

Parse a pabc and return the expiration.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 334 of file plugin_reclaim_credential_pabc.c.

337{
339 return GNUNET_NO;
340 return pabc_get_expiration (cls, cred->data, cred->data_size, exp);
341}
@ GNUNET_NO
static enum GNUNET_GenericReturnValue pabc_get_expiration(void *cls, const char *data, size_t data_size, struct GNUNET_TIME_Absolute *exp)
Parse a pabc and return the expiration.

References cred, GNUNET_NO, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_get_expiration().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_get_expiration_p()

static enum GNUNET_GenericReturnValue pabc_get_expiration_p ( void *  cls,
const struct GNUNET_RECLAIM_Presentation cred,
struct GNUNET_TIME_Absolute exp 
)
static

Parse a pabc and return the expiration.

Parameters
clsthe plugin
credthe pabc credential
Returns
a string, containing the isser

Definition at line 352 of file plugin_reclaim_credential_pabc.c.

355{
357 return GNUNET_NO;
358 return pabc_get_expiration (cls, cred->data, cred->data_size, exp);
359}

References cred, GNUNET_NO, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, and pabc_get_expiration().

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ pabc_create_presentation()

static enum GNUNET_GenericReturnValue pabc_create_presentation ( void *  cls,
const struct GNUNET_RECLAIM_Credential credential,
const struct GNUNET_RECLAIM_AttributeList attrs,
struct GNUNET_RECLAIM_Presentation **  presentation 
)
static

Definition at line 363 of file plugin_reclaim_credential_pabc.c.

367{
368 struct pabc_context *ctx = NULL;
369 struct pabc_user_context *usr_ctx = NULL;
370 struct pabc_public_parameters *pp = NULL;
371 struct pabc_credential *cred = NULL;
372 struct pabc_blinded_proof *proof = NULL;
374 char *issuer;
375 char *subject;
376 enum pabc_status status;
377
379 return GNUNET_NO;
380
381
382 PABC_ASSERT (pabc_new_ctx (&ctx));
383 issuer = pabc_get_issuer_c (cls, credential);
384 if (NULL == issuer)
385 {
387 "No issuer found in credential\n");
388 pabc_free_ctx (&ctx);
389 return GNUNET_SYSERR;
390 }
392 "Got issuer for credential: %s\n", issuer);
393 status = PABC_load_public_parameters (ctx, issuer, &pp);
394 if (status != PABC_OK)
395 {
397 "Failed to read public parameters.\n");
398 pabc_free_ctx (&ctx);
399 GNUNET_free (issuer);
400 return GNUNET_SYSERR;
401 }
402 if (PABC_OK != pabc_cred_get_attr_by_name_from_cred (credential->data,
403 "subject",
404 &subject))
405 {
407 "Failed to get subject.\n");
408 pabc_free_ctx (&ctx);
409 GNUNET_free (issuer);
410 return GNUNET_SYSERR;
411 }
412 status = PABC_read_usr_ctx (subject, issuer, ctx, pp, &usr_ctx);
413 GNUNET_free (issuer);
415 if (PABC_OK != status)
416 {
418 "Failed to read user context.\n");
419 pabc_free_public_parameters (ctx, &pp);
420 return GNUNET_SYSERR;
421 }
422
423 status = pabc_new_credential (ctx, pp, &cred);
424 if (status != PABC_OK)
425 {
427 "Failed to allocate credential.\n");
428 pabc_free_user_context (ctx, pp, &usr_ctx);
429 pabc_free_public_parameters (ctx, &pp);
430 return GNUNET_SYSERR;
431 }
432
433 status = pabc_decode_credential (ctx, pp, cred, credential->data);
434 if (status != PABC_OK)
435 {
437 "Failed to decode credential.\n");
438 pabc_free_credential (ctx, pp, &cred);
439 pabc_free_user_context (ctx, pp, &usr_ctx);
440 pabc_free_public_parameters (ctx, &pp);
441 return GNUNET_SYSERR;
442 }
443
444 status = pabc_new_proof (ctx, pp, &proof);
445 if (status != PABC_OK)
446 {
448 "Failed to allocate proof.\n");
449 pabc_free_credential (ctx, pp, &cred);
450 pabc_free_user_context (ctx, pp, &usr_ctx);
451 pabc_free_public_parameters (ctx, &pp);
452 return GNUNET_SYSERR;
453 }
454
455 // now we can parse the attributes to disclose and configure the proof
456 for (ale = attrs->list_head; NULL != ale; ale = ale->next)
457 {
458 status = pabc_set_disclosure_by_attribute_name (ctx, pp, proof,
459 ale->attribute->name,
460 PABC_DISCLOSED, cred);
461 if (status != PABC_OK)
462 {
464 "Failed to configure proof.\n");
465 pabc_free_credential (ctx, pp, &cred);
466 pabc_free_user_context (ctx, pp, &usr_ctx);
467 pabc_free_public_parameters (ctx, &pp);
468 return GNUNET_SYSERR;
469 }
470 }
471
472 // and finally -> sign the proof
473 status = pabc_gen_proof (ctx, usr_ctx, pp, proof, cred);
474 if (status != PABC_OK)
475 {
477 "Failed to sign proof.\n");
478 pabc_free_proof (ctx, pp, &proof);
479 pabc_free_credential (ctx, pp, &cred);
480 pabc_free_user_context (ctx, pp, &usr_ctx);
481 pabc_free_public_parameters (ctx, &pp);
482 return GNUNET_SYSERR;
483 }
484 // print the result
485 char *json = NULL;
486 char *ppid = NULL;
487 char *userid = NULL;
488 GNUNET_assert (PABC_OK == pabc_cred_get_userid_from_cred (credential->data,
489 &userid));
490 GNUNET_assert (PABC_OK == pabc_cred_get_ppid_from_cred (credential->data,
491 &ppid));
492 pabc_cred_encode_proof (ctx, pp, proof, userid, ppid, &json);
493 GNUNET_free (ppid);
494 GNUNET_free (userid);
495 if (PABC_OK != status)
496 {
498 "Failed to serialize proof.\n");
499 pabc_free_proof (ctx, pp, &proof);
500 pabc_free_credential (ctx, pp, &cred);
501 pabc_free_user_context (ctx, pp, &usr_ctx);
502 pabc_free_public_parameters (ctx, &pp);
503 return GNUNET_SYSERR;
504 }
505 char *json_enc;
507 strlen (json) + 1,
508 &json_enc);
510 "Presentation: %s\n", json_enc);
511 // clean up
512 *presentation = GNUNET_RECLAIM_presentation_new (
514 json_enc,
515 strlen (json_enc) + 1);
516 GNUNET_free (json_enc);
517 PABC_FREE_NULL (json);
518 pabc_free_proof (ctx, pp, &proof);
519 pabc_free_credential (ctx, pp, &cred);
520 pabc_free_user_context (ctx, pp, &usr_ctx);
521 pabc_free_public_parameters (ctx, &pp);
522 return GNUNET_OK;
523}
static char * subject
Subject pubkey string.
Definition: gnunet-abd.c:87
static int status
The program status; 0 for success.
Definition: gnunet-nse.c:39
static struct GNUNET_RECLAIM_Identifier credential
Credential ID.
static uint64_t proof
Definition: gnunet-scrypt.c:49
struct GNUNET_RECLAIM_Presentation * GNUNET_RECLAIM_presentation_new(uint32_t type, const void *data, size_t data_size)
size_t GNUNET_STRINGS_base64_encode(const void *in, size_t len, char **output)
Encode into Base64.
Definition: strings.c:1622
enum GNUNET_GenericReturnValue PABC_load_public_parameters(struct pabc_context *const ctx, char const *const pp_name, struct pabc_public_parameters **pp)
Definition: pabc_helper.c:135
enum GNUNET_GenericReturnValue PABC_read_usr_ctx(char const *const usr_name, char const *const pp_name, struct pabc_context const *const ctx, struct pabc_public_parameters const *const pp, struct pabc_user_context **usr_ctx)
Definition: pabc_helper.c:301
static char * pabc_get_issuer_c(void *cls, const struct GNUNET_RECLAIM_Credential *cred)
Parse a pabc and return the issuer.
struct GNUNET_RECLAIM_Attribute * attribute
The attribute claim.
struct GNUNET_RECLAIM_AttributeListEntry * next
DLL.
struct GNUNET_RECLAIM_AttributeListEntry * list_head
List head.
const char * name
The name of the attribute.

References GNUNET_RECLAIM_AttributeListEntry::attribute, cred, credential, ctx, GNUNET_assert, GNUNET_ERROR_TYPE_DEBUG, GNUNET_ERROR_TYPE_ERROR, GNUNET_free, GNUNET_log, GNUNET_NO, GNUNET_OK, GNUNET_RECLAIM_CREDENTIAL_TYPE_PABC, GNUNET_RECLAIM_presentation_new(), GNUNET_STRINGS_base64_encode(), GNUNET_SYSERR, GNUNET_RECLAIM_AttributeList::list_head, GNUNET_RECLAIM_Attribute::name, GNUNET_RECLAIM_AttributeListEntry::next, pabc_get_issuer_c(), PABC_load_public_parameters(), PABC_read_usr_ctx(), proof, status, and subject.

Referenced by libgnunet_plugin_reclaim_credential_pabc_init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ libgnunet_plugin_reclaim_credential_pabc_init()

void * libgnunet_plugin_reclaim_credential_pabc_init ( void *  cls)

Entry point for the plugin.

Parameters
clsNULL
Returns
the exported block API

Definition at line 535 of file plugin_reclaim_credential_pabc.c.

536{
538
555 return api;
556}
static char * pabc_value_to_string(void *cls, uint32_t type, const void *data, size_t data_size)
Convert the 'value' of an credential to a string.
static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes_c(void *cls, const struct GNUNET_RECLAIM_Credential *cred)
Parse a pabc and return the respective claim value as Attribute.
static const char * pabc_number_to_typename(void *cls, uint32_t type)
Convert a type number (i.e.
static uint32_t pabc_typename_to_number(void *cls, const char *pabc_typename)
Convert a type name to the corresponding number.
static char * pabc_get_issuer_p(void *cls, const struct GNUNET_RECLAIM_Presentation *cred)
Parse a pabc and return the issuer.
static enum GNUNET_GenericReturnValue pabc_get_expiration_p(void *cls, const struct GNUNET_RECLAIM_Presentation *cred, struct GNUNET_TIME_Absolute *exp)
Parse a pabc and return the expiration.
static struct GNUNET_RECLAIM_AttributeList * pabc_parse_attributes_p(void *cls, const struct GNUNET_RECLAIM_Presentation *cred)
Parse a pabc and return the respective claim value as Attribute.
static int pabc_string_to_value(void *cls, uint32_t type, const char *s, void **data, size_t *data_size)
Convert human-readable version of a 'value' of an credential to the binary representation.
static enum GNUNET_GenericReturnValue pabc_create_presentation(void *cls, const struct GNUNET_RECLAIM_Credential *credential, const struct GNUNET_RECLAIM_AttributeList *attrs, struct GNUNET_RECLAIM_Presentation **presentation)
static enum GNUNET_GenericReturnValue pabc_get_expiration_c(void *cls, const struct GNUNET_RECLAIM_Credential *cred, struct GNUNET_TIME_Absolute *exp)
Parse a pabc and return the expiration.
Each plugin is required to return a pointer to a struct of this type as the return value from its ent...
GNUNET_RECLAIM_CredentialValueToStringFunction value_to_string
Conversion to string.
GNUNET_RECLAIM_CredentialTypenameToNumberFunction typename_to_number
Typename to number.
GNUNET_RECLAIM_PresentationGetIssuerFunction get_issuer_p
Attesation issuer.
GNUNET_RECLAIM_CredentialNumberToTypenameFunction number_to_typename
Number to typename.
GNUNET_RECLAIM_CredentialGetIssuerFunction get_issuer
Attesation issuer.
GNUNET_RECLAIM_PresentationGetExpirationFunction get_expiration_p
Expiration.
GNUNET_RECLAIM_PresentationValueToStringFunction value_to_string_p
Conversion to string.
GNUNET_RECLAIM_CredentialStringToValueFunction string_to_value
Conversion to binary.
GNUNET_RECLAIM_CredentialGetExpirationFunction get_expiration
Expiration.
GNUNET_RECLAIM_CredentialGetAttributesFunction get_attributes
Attesation attributes.
GNUNET_RECLAIM_PresentationStringToValueFunction string_to_value_p
Conversion to binary.
GNUNET_RECLAIM_PresentationTypenameToNumberFunction typename_to_number_p
Typename to number.
GNUNET_RECLAIM_PresentationNumberToTypenameFunction number_to_typename_p
Number to typename.
GNUNET_RECLAIM_CredentialToPresentation create_presentation
Get presentation.
GNUNET_RECLAIM_PresentationGetAttributesFunction get_attributes_p
Attesation attributes.

References GNUNET_RECLAIM_CredentialPluginFunctions::create_presentation, GNUNET_RECLAIM_CredentialPluginFunctions::get_attributes, GNUNET_RECLAIM_CredentialPluginFunctions::get_attributes_p, GNUNET_RECLAIM_CredentialPluginFunctions::get_expiration, GNUNET_RECLAIM_CredentialPluginFunctions::get_expiration_p, GNUNET_RECLAIM_CredentialPluginFunctions::get_issuer, GNUNET_RECLAIM_CredentialPluginFunctions::get_issuer_p, GNUNET_new, GNUNET_RECLAIM_CredentialPluginFunctions::number_to_typename, GNUNET_RECLAIM_CredentialPluginFunctions::number_to_typename_p, pabc_create_presentation(), pabc_get_expiration_c(), pabc_get_expiration_p(), pabc_get_issuer_c(), pabc_get_issuer_p(), pabc_number_to_typename(), pabc_parse_attributes_c(), pabc_parse_attributes_p(), pabc_string_to_value(), pabc_typename_to_number(), pabc_value_to_string(), GNUNET_RECLAIM_CredentialPluginFunctions::string_to_value, GNUNET_RECLAIM_CredentialPluginFunctions::string_to_value_p, GNUNET_RECLAIM_CredentialPluginFunctions::typename_to_number, GNUNET_RECLAIM_CredentialPluginFunctions::typename_to_number_p, GNUNET_RECLAIM_CredentialPluginFunctions::value_to_string, and GNUNET_RECLAIM_CredentialPluginFunctions::value_to_string_p.

Here is the call graph for this function:

◆ libgnunet_plugin_reclaim_credential_pabc_done()

void * libgnunet_plugin_reclaim_credential_pabc_done ( void *  cls)

Exit point from the plugin.

Parameters
clsthe return value from libgnunet_plugin_block_test_init()
Returns
NULL

Definition at line 568 of file plugin_reclaim_credential_pabc.c.

569{
571
572 GNUNET_free (api);
573 return NULL;
574}
void * cls
Closure for all of the callbacks.

References GNUNET_RECLAIM_CredentialPluginFunctions::cls, and GNUNET_free.

Variable Documentation

◆ name

const char* name

◆ number

uint32_t number

Definition at line 103 of file plugin_reclaim_credential_pabc.c.

Referenced by pabc_number_to_typename().

◆ 

struct { ... } pabc_cred_name_map[]
Initial value:
{ NULL, UINT32_MAX } }

Mapping of credential type numbers to human-readable credential type names.

Referenced by pabc_number_to_typename(), and pabc_typename_to_number().