#include "platform.h"
#include "gnunet_common.h"
#include "gnunet_protocols.h"
-
-/**
- * Bit length used for the Paillier crypto system.
- */
-#define PAILLIER_BITS 2048
-
-/**
- * Big endian representation of the prime field order used
- * for ElGamal.
- */
-#define ELGAMAL_Q_DATA {0x00 /* FIXME */};
+#include "secretsharing.h"
GNUNET_NETWORK_STRUCT_BEGIN
-/**
- * Public key for the Paillier crypto system.
- */
-struct PaillierPublicKey
-{
- /**
- * Network order representation of the
- * g-component.
- */
- uint32_t g[PAILLIER_BITS / 8 / sizeof (uint32_t)];
-
- /**
- * Network order representation of the
- * n-component.
- */
- uint32_t n[PAILLIER_BITS / 8 / sizeof (uint32_t)];
-};
-
-
/**
* Consensus element data used in the first round of key generation.
*/
* Ephemeral paillier public key used by 'peer' for
* this session.
*/
- struct PaillierPublicKey pubkey GNUNET_PACKED;
+ struct GNUNET_CRYPTO_PaillierPublicKey pubkey;
/**
* Commitment of 'peer' to his presecret.
*/
/* values follow */
};
+
+/**
+ * Data of then element put in consensus
+ * for decrypting a value.
+ */
+struct GNUNET_SECRETSHARING_DecryptData
+{
+ /*
+ * Signature over rest of the message.
+ */
+ struct GNUNET_CRYPTO_EddsaSignature signature;
+ /*
+ * Signature purpose for signing the keygen commit data.
+ */
+ struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
+ /**
+ * Ciphertext we want to decrypt.
+ */
+ struct GNUNET_SECRETSHARING_Ciphertext ciphertext;
+ /**
+ * Peer that inserts this element.
+ */
+ struct GNUNET_PeerIdentity peer;
+ /**
+ * Partial decryption, computed as c_1^{s_i}
+ */
+ struct GNUNET_SECRETSHARING_FieldElement partial_decryption;
+ /**
+ * Commitment for the non-interactive zero knowledge proof.
+ * g^\beta, with \beta < q
+ */
+ struct GNUNET_SECRETSHARING_FieldElement nizk_commit1;
+ /**
+ * Commitment for the non-interactive zero knowledge proof.
+ * c_1^\beta, with \beta < q
+ */
+ struct GNUNET_SECRETSHARING_FieldElement nizk_commit2;
+ /**
+ * Reponse to the challenge computed from the protocol transcript.
+ * r = \beta + challenge \cdot share_i
+ */
+ struct GNUNET_SECRETSHARING_FieldElement nizk_response;
+};
+
GNUNET_NETWORK_STRUCT_END
#endif