2 This file is part of GNUnet
3 Copyright (C) 2012 GNUnet e.V.
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 3, or (at your
8 option) any later version.
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.
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., 51 Franklin Street, Fifth Floor,
18 Boston, MA 02110-1301, USA.
23 * @file consensus/consensus_protocol.h
24 * @brief p2p message definitions for consensus
25 * @author Florian Dold
28 #ifndef GNUNET_CONSENSUS_PROTOCOL_H
29 #define GNUNET_CONSENSUS_PROTOCOL_H
32 #include "gnunet_util_lib.h"
33 #include "gnunet_common.h"
34 #include "gnunet_protocols.h"
37 GNUNET_NETWORK_STRUCT_BEGIN
40 * Sent as context message for set reconciliation.
42 * Essentially contains all the fields
43 * from 'struct TaskKey', but in NBO.
45 struct GNUNET_CONSENSUS_RoundContextMessage
48 * Type: GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ROUND_CONTEXT
50 struct GNUNET_MessageHeader header;
53 * A value from 'enum PhaseKind'.
58 * Number of the first peer
64 * Number of the second peer in canonical order.
69 * Repetition of the gradecast phase.
74 * Leader in the gradecast phase.
76 * Can be different from both peer1 and peer2.
81 * Non-zero if this set reconciliation
82 * had elements removed because they were contested.
84 * Will be considered when grading broadcasts.
86 * Ignored for set operations that are not within gradecasts.
88 uint16_t is_contested;
93 CONSENSUS_MARKER_CONTESTED = 1,
94 CONSENSUS_MARKER_SIZE = 2,
99 * Consensus element, either marker or payload.
101 struct ConsensusElement
104 * Payload element_type, only valid
105 * if this is not a marker element.
107 uint16_t payload_type;
110 * Is this a marker element?
114 /* rest: element data */
118 struct ConsensusSizeElement
120 struct ConsensusElement ce GNUNET_PACKED;
122 uint64_t size GNUNET_PACKED;
123 uint8_t sender_index;
126 struct ConsensusStuffedElement
128 struct ConsensusElement ce GNUNET_PACKED;
129 struct GNUNET_HashCode rand GNUNET_PACKED;
133 GNUNET_NETWORK_STRUCT_END