diff options
| author | Christian Grothoff <christian@grothoff.org> | 2019-03-11 02:56:05 +0100 | 
|---|---|---|
| committer | Christian Grothoff <christian@grothoff.org> | 2019-03-11 02:56:05 +0100 | 
| commit | 82ce84fe67e14ff547bdca068c39511d8c0125fb (patch) | |
| tree | 4f58688ff93d4f1523ab8c27d755bcef1101e9ad /src/exchange/taler-exchange-httpd_keystate.c | |
| parent | c3b9ebc1effea652e3cdfc93fb6ed5b1cf83826a (diff) | |
| parent | 4405438d9c2db21be566a57a57b5eeeaf294bbc9 (diff) | |
pre-pull merging
Diffstat (limited to 'src/exchange/taler-exchange-httpd_keystate.c')
| -rw-r--r-- | src/exchange/taler-exchange-httpd_keystate.c | 19 | 
1 files changed, 15 insertions, 4 deletions
| diff --git a/src/exchange/taler-exchange-httpd_keystate.c b/src/exchange/taler-exchange-httpd_keystate.c index 36f464ba..30a0bbf1 100644 --- a/src/exchange/taler-exchange-httpd_keystate.c +++ b/src/exchange/taler-exchange-httpd_keystate.c @@ -783,16 +783,27 @@ revocations_iter (void *cls,  	      GNUNET_h2s (denom_hash));    dki = GNUNET_CONTAINER_multihashmap_get (key_state->denomkey_map,  					   denom_hash); -  if (NULL == dki) +  // FIXME: what do we do if dki is not known? +  // especially what if we have neither private key NOR +  // DB entry? (maybe ancient revocation? should we ignore it?) +  if (NULL != dki)    {      GNUNET_assert (GNUNET_YES ==  		   GNUNET_CONTAINER_multihashmap_remove (key_state->denomkey_map,  							 denom_hash,  							 dki)); -    res = store_in_map (key_state->revoked_map, -			dki); -    if (GNUNET_NO == res) +    if (GNUNET_NO == +	GNUNET_CONTAINER_multihashmap_put (key_state->revoked_map, +                                           &dki->issue.properties.denom_hash, +                                           dki, +                                           GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY)) +    { +      /* revocation file must exist twice, keep only one of the dkis */ +      GNUNET_CRYPTO_rsa_private_key_free (dki->denom_priv.rsa_private_key); +      GNUNET_CRYPTO_rsa_public_key_free (dki->denom_pub.rsa_public_key); +      GNUNET_free (dki);        return GNUNET_OK; +    }    }    /* Try to insert DKI into DB until we succeed; note that if the DB       failure is persistent, we need to die, as we cannot continue | 
