consensus now implemented with primitive conclusion group selection
[oweals/gnunet.git] / src / consensus / consensus_protocol.h
1 /*
2       This file is part of GNUnet
3       (C) 2012 Christian Grothoff (and other contributing authors)
4
5       GNUnet is free software; you can redistribute it and/or modify
6       it under the terms of the GNU General Public License as published
7       by the Free Software Foundation; either version 2, or (at your
8       option) any later version.
9
10       GNUnet is distributed in the hope that it will be useful, but
11       WITHOUT ANY WARRANTY; without even the implied warranty of
12       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13       General Public License for more details.
14
15       You should have received a copy of the GNU General Public License
16       along with GNUnet; see the file COPYING.  If not, write to the
17       Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18       Boston, MA 02111-1307, USA.
19 */
20
21
22 /**
23  * @file consensus/consensus_protocol.h
24  * @brief p2p message definitions for consensus
25  * @author Florian Dold
26  */
27
28 #ifndef GNUNET_CONSENSUS_PROTOCOL_H
29 #define GNUNET_CONSENSUS_PROTOCOL_H
30
31 #include "platform.h"
32 #include "gnunet_common.h"
33 #include "gnunet_protocols.h"
34
35
36 GNUNET_NETWORK_STRUCT_BEGIN
37
38 struct StrataMessage
39 {
40   struct GNUNET_MessageHeader header;
41   /**
42    * Number of elements the sender currently has.
43    */
44   uint16_t num_elements;
45   /**
46    * Number of strata in this estimator.
47    */
48   uint16_t num_strata;
49   /* struct GNUNET_HashCode hash_buckets[ibf_size*num_strata] */
50   /* struct GNUNET_HashCode id_buckets[ibf_size*num_strata] */
51   /* uint8_t count_buckets[ibf_size*num_strata] */
52 };
53
54 struct DifferenceDigest
55 {
56   struct GNUNET_MessageHeader header;
57   uint8_t order;
58   uint8_t round;
59 };
60
61 struct Element
62 {
63   struct GNUNET_MessageHeader header;
64   struct GNUNET_HashCode hash;
65 };
66
67
68 struct ElementRequest
69 {
70   struct GNUNET_MessageHeader header;
71   /* struct GNUNET_HashCode[] rest */
72 };
73
74 struct ConsensusHello
75 {
76   struct GNUNET_MessageHeader header;
77   struct GNUNET_HashCode global_id;
78   uint8_t round;
79 };
80
81
82 GNUNET_NETWORK_STRUCT_END
83
84 #endif