diff options
| -rw-r--r-- | src/mint-lib/mint_api_json.c | 40 | ||||
| -rw-r--r-- | src/mint-lib/mint_api_json.h | 11 | 
2 files changed, 45 insertions, 6 deletions
| diff --git a/src/mint-lib/mint_api_json.c b/src/mint-lib/mint_api_json.c index 81511c1c..e2a73bdd 100644 --- a/src/mint-lib/mint_api_json.c +++ b/src/mint-lib/mint_api_json.c @@ -202,12 +202,40 @@ parse_json (json_t *root,      case MAJ_CMD_EDDSA_SIGNATURE:        { -        /* FIXME: parse the JSON signature -           and the purpose, then check that the -           signature is valid and the size field -           is also correct; if all checks out, -           return the purpose */ -        GNUNET_break (0); // FIXME: implement! #3516 +        struct TALER_CoinSpendSignatureP sig; +        struct GNUNET_CRYPTO_EccSignaturePurpose *purpose; +        size_t size; +        struct MAJ_Specification sig_spec[] = { +          MAJ_spec_fixed_auto ("eddsa_sig", &sig), +          MAJ_spec_varsize ("eddsa_val", (void**) &purpose, &size), +          MAJ_spec_end +        }; + +        if (GNUNET_OK != +            MAJ_parse_json (pos, +                            sig_spec)) +        { +          GNUNET_break_op (0); +          MAJ_parse_free (sig_spec); +          return i; +        } +        if (size != ntohl (purpose->size)) +        { +          GNUNET_break_op (0); +          MAJ_parse_free (sig_spec); +          return i; +        } +        if (GNUNET_OK != +            GNUNET_CRYPTO_eddsa_verify (ntohl (purpose->purpose), +                                        purpose, +                                        &sig.eddsa_signature, +                                        spec[i].details.eddsa_signature.pub_key)) +        { +          GNUNET_break_op (0); +          MAJ_parse_free (sig_spec); +          return i; +        } +        *spec[i].details.eddsa_signature.purpose_p = purpose;        }        break; diff --git a/src/mint-lib/mint_api_json.h b/src/mint-lib/mint_api_json.h index 91679831..ec3b63cb 100644 --- a/src/mint-lib/mint_api_json.h +++ b/src/mint-lib/mint_api_json.h @@ -219,6 +219,17 @@ MAJ_parse_free (struct MAJ_Specification *spec);  /** + * Variable size object (in network byte order, encoded using Crockford + * Base32hex encoding). + * + * @param name name of the JSON field + * @param obj_ptr pointer where to write the data (a `void **`) + * @param size where to store the number of bytes allocated for @a obj (of type `size_t *` + */ +#define MAJ_spec_varsize(name,obj,size) { .cmd = MAJ_CMD_BINARY_VARIABLE, .field = name, .details.variable_data.dest_p = obj, .details.variable_data.dest_size_p = size } + + +/**   * Absolute time.   *   * @param name name of the JSON field | 
