2 This file is part of GNUnet.
3 Copyright (C) 2001--2015 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.
22 * @author Christian Grothoff
25 * Constants for network protocols
27 * @defgroup protocols Network protocol definitions
28 * Types of messages used in GNUnet.
30 * @see [Documentation](https://gnunet.org/ipc)
35 /*******************************************************************************
36 * TODO: we need a way to register message types centrally (via some webpage).
37 * For now: unofficial extensions should start at 48k, internal extensions
38 * defined here should leave some room (4-10 additional messages to the previous
40 ******************************************************************************/
42 #ifndef GNUNET_PROTOCOLS_H
43 #define GNUNET_PROTOCOLS_H
48 #if 0 /* keep Emacsens' auto-indent happy */
53 /*******************************************************************************
55 ******************************************************************************/
58 * Test if service is online.
62 #define GNUNET_MESSAGE_TYPE_TEST 1
65 * Dummy messages for testing / benchmarking.
67 #define GNUNET_MESSAGE_TYPE_DUMMY 2
69 /*******************************************************************************
70 * RESOLVER message types
71 ******************************************************************************/
74 * Request DNS resolution.
76 #define GNUNET_MESSAGE_TYPE_RESOLVER_REQUEST 4
79 * Response to a DNS resolution request.
81 #define GNUNET_MESSAGE_TYPE_RESOLVER_RESPONSE 5
83 /*******************************************************************************
85 ******************************************************************************/
88 * Request to ARM to start a service.
90 #define GNUNET_MESSAGE_TYPE_ARM_START 8
93 * Request to ARM to stop a service.
95 #define GNUNET_MESSAGE_TYPE_ARM_STOP 9
100 #define GNUNET_MESSAGE_TYPE_ARM_RESULT 10
103 * Status update from ARM.
105 #define GNUNET_MESSAGE_TYPE_ARM_STATUS 11
108 * Request to ARM to list all currently running services
110 #define GNUNET_MESSAGE_TYPE_ARM_LIST 12
113 * Response from ARM for listing currently running services
115 #define GNUNET_MESSAGE_TYPE_ARM_LIST_RESULT 13
118 * Request to ARM to notify client of service status changes
120 #define GNUNET_MESSAGE_TYPE_ARM_MONITOR 14
123 * Test if ARM service is online.
125 #define GNUNET_MESSAGE_TYPE_ARM_TEST 15
127 /*******************************************************************************
128 * HELLO message types
129 ******************************************************************************/
132 * Previously used for HELLO messages used for communicating peer addresses.
133 * Managed by libgnunethello.
135 #define GNUNET_MESSAGE_TYPE_HELLO_LEGACY 16
138 * HELLO message with friend only flag used for communicating peer addresses.
139 * Managed by libgnunethello.
142 #define GNUNET_MESSAGE_TYPE_HELLO 17
144 /*******************************************************************************
145 * FRAGMENTATION message types
146 ******************************************************************************/
149 * FRAGMENT of a larger message.
150 * Managed by libgnunetfragment.
152 #define GNUNET_MESSAGE_TYPE_FRAGMENT 18
155 * Acknowledgement of a FRAGMENT of a larger message.
156 * Managed by libgnunetfragment.
158 #define GNUNET_MESSAGE_TYPE_FRAGMENT_ACK 19
160 /*******************************************************************************
161 * Transport-WLAN message types
162 ******************************************************************************/
165 * Type of data messages from the plugin to the gnunet-wlan-helper
167 #define GNUNET_MESSAGE_TYPE_WLAN_DATA_TO_HELPER 39
170 * Type of data messages from the gnunet-wlan-helper to the plugin
172 #define GNUNET_MESSAGE_TYPE_WLAN_DATA_FROM_HELPER 40
175 * Control message between the gnunet-wlan-helper and the daemon (with the MAC).
177 #define GNUNET_MESSAGE_TYPE_WLAN_HELPER_CONTROL 41
180 * Type of messages for advertisement over wlan
182 #define GNUNET_MESSAGE_TYPE_WLAN_ADVERTISEMENT 42
185 * Type of messages for data over the wlan
187 #define GNUNET_MESSAGE_TYPE_WLAN_DATA 43
190 /*******************************************************************************
191 * Transport-DV message types
192 ******************************************************************************/
195 * DV service to DV Plugin message, when a message is
196 * unwrapped by the DV service and handed to the plugin
199 #define GNUNET_MESSAGE_TYPE_DV_RECV 44
202 * DV Plugin to DV service message, indicating a message
203 * should be sent out.
205 #define GNUNET_MESSAGE_TYPE_DV_SEND 45
208 * DV service to DV api message, containing a confirmation
209 * or failure of a DV_SEND message.
211 #define GNUNET_MESSAGE_TYPE_DV_SEND_ACK 46
214 * P2P DV message encapsulating some real message
216 #define GNUNET_MESSAGE_TYPE_DV_ROUTE 47
219 * DV Plugin to DV service message, indicating
222 #define GNUNET_MESSAGE_TYPE_DV_START 48
225 * P2P DV message telling plugin that a peer connected
227 #define GNUNET_MESSAGE_TYPE_DV_CONNECT 49
230 * P2P DV message telling plugin that a peer disconnected
232 #define GNUNET_MESSAGE_TYPE_DV_DISCONNECT 50
235 * P2P DV message telling plugin that a message transmission failed (negative ACK)
237 #define GNUNET_MESSAGE_TYPE_DV_SEND_NACK 51
240 * P2P DV message telling plugin that our distance to a peer changed
242 #define GNUNET_MESSAGE_TYPE_DV_DISTANCE_CHANGED 52
245 * DV message box for boxing multiple messages.
247 #define GNUNET_MESSAGE_TYPE_DV_BOX 53
250 /*******************************************************************************
251 * Transport-UDP message types
252 ******************************************************************************/
255 * Normal UDP message type.
257 #define GNUNET_MESSAGE_TYPE_TRANSPORT_UDP_MESSAGE 56
262 #define GNUNET_MESSAGE_TYPE_TRANSPORT_UDP_ACK 57
264 /*******************************************************************************
265 * Transport-TCP message types
266 ******************************************************************************/
269 * TCP NAT probe message, send from NAT'd peer to
270 * other peer to establish bi-directional communication
272 #define GNUNET_MESSAGE_TYPE_TRANSPORT_TCP_NAT_PROBE 60
275 * Welcome message between TCP transports.
277 #define GNUNET_MESSAGE_TYPE_TRANSPORT_TCP_WELCOME 61
280 * Message to force transport to update bandwidth assignment (LEGACY)
282 #define GNUNET_MESSAGE_TYPE_TRANSPORT_ATS 62
284 /*******************************************************************************
286 ******************************************************************************/
289 * Message to ask NAT server to perform traversal test
291 #define GNUNET_MESSAGE_TYPE_NAT_TEST 63
293 /*******************************************************************************
295 ******************************************************************************/
298 * Initial setup message from core client to core.
300 #define GNUNET_MESSAGE_TYPE_CORE_INIT 64
303 * Response from core to core client to INIT message.
305 #define GNUNET_MESSAGE_TYPE_CORE_INIT_REPLY 65
308 * Notify clients about new peer-to-peer connections (triggered
309 * after key exchange).
311 #define GNUNET_MESSAGE_TYPE_CORE_NOTIFY_CONNECT 67
314 * Notify clients about peer disconnecting.
316 #define GNUNET_MESSAGE_TYPE_CORE_NOTIFY_DISCONNECT 68
319 * Notify clients about peer status change.
321 #define GNUNET_MESSAGE_TYPE_CORE_NOTIFY_STATUS_CHANGE 69
324 * Notify clients about incoming P2P messages.
326 #define GNUNET_MESSAGE_TYPE_CORE_NOTIFY_INBOUND 70
329 * Notify clients about outgoing P2P transmissions.
331 #define GNUNET_MESSAGE_TYPE_CORE_NOTIFY_OUTBOUND 71
334 * Request from client to transmit message.
336 #define GNUNET_MESSAGE_TYPE_CORE_SEND_REQUEST 74
339 * Confirmation from core that message can now be sent
341 #define GNUNET_MESSAGE_TYPE_CORE_SEND_READY 75
344 * Client with message to transmit (after SEND_READY confirmation
347 #define GNUNET_MESSAGE_TYPE_CORE_SEND 76
350 * Request for connection monitoring from CORE service.
352 #define GNUNET_MESSAGE_TYPE_CORE_MONITOR_PEERS 78
355 * Reply for monitor by CORE service.
357 #define GNUNET_MESSAGE_TYPE_CORE_MONITOR_NOTIFY 79
360 * Encapsulation for an encrypted message between peers.
362 #define GNUNET_MESSAGE_TYPE_CORE_ENCRYPTED_MESSAGE 82
365 * Check that other peer is alive (challenge).
367 #define GNUNET_MESSAGE_TYPE_CORE_PING 83
370 * Confirmation that other peer is alive.
372 #define GNUNET_MESSAGE_TYPE_CORE_PONG 84
375 * Request by the other peer to terminate the connection.
377 #define GNUNET_MESSAGE_TYPE_CORE_HANGUP 85
380 * gzip-compressed type map of the sender
382 #define GNUNET_MESSAGE_TYPE_CORE_COMPRESSED_TYPE_MAP 86
385 * uncompressed type map of the sender
387 #define GNUNET_MESSAGE_TYPE_CORE_BINARY_TYPE_MAP 87
390 * Session key exchange between peers.
392 #define GNUNET_MESSAGE_TYPE_CORE_EPHEMERAL_KEY 88
395 * Other peer confirms having received the type map
397 #define GNUNET_MESSAGE_TYPE_CORE_CONFIRM_TYPE_MAP 89
400 /*******************************************************************************
401 * DATASTORE message types
402 ******************************************************************************/
405 * Message sent by datastore client on join.
407 #define GNUNET_MESSAGE_TYPE_DATASTORE_RESERVE 92
410 * Message sent by datastore client on join.
412 #define GNUNET_MESSAGE_TYPE_DATASTORE_RELEASE_RESERVE 93
415 * Message sent by datastore to client informing about status
416 * processing a request
417 * (in response to RESERVE, RELEASE_RESERVE, PUT, UPDATE and REMOVE requests).
419 #define GNUNET_MESSAGE_TYPE_DATASTORE_STATUS 94
422 * Message sent by datastore client to store data.
424 #define GNUNET_MESSAGE_TYPE_DATASTORE_PUT 95
427 * Message sent by datastore client to get data.
429 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET 97
432 * Message sent by datastore client to get random data.
434 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_REPLICATION 98
437 * Message sent by datastore client to get random data.
439 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_ZERO_ANONYMITY 99
442 * Message sent by datastore to client providing requested data
443 * (in response to GET or GET_RANDOM request).
445 #define GNUNET_MESSAGE_TYPE_DATASTORE_DATA 100
448 * Message sent by datastore to client signaling end of matching data.
449 * This message will also be sent for "GET_RANDOM", even though
450 * "GET_RANDOM" returns at most one data item.
452 #define GNUNET_MESSAGE_TYPE_DATASTORE_DATA_END 101
455 * Message sent by datastore client to remove data.
457 #define GNUNET_MESSAGE_TYPE_DATASTORE_REMOVE 102
460 * Message sent by datastore client to drop the database.
462 #define GNUNET_MESSAGE_TYPE_DATASTORE_DROP 103
465 * Message sent by datastore client to get data by key.
467 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_KEY 104
470 /*******************************************************************************
472 ******************************************************************************/
475 * Message sent by fs client to request LOC signature.
477 #define GNUNET_MESSAGE_TYPE_FS_REQUEST_LOC_SIGN 126
480 * Reply sent by fs service with LOC signature.
482 #define GNUNET_MESSAGE_TYPE_FS_REQUEST_LOC_SIGNATURE 127
485 * Message sent by fs client to start indexing.
487 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START 128
490 * Affirmative response to a request for start indexing.
492 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START_OK 129
495 * Response to a request for start indexing that
498 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START_FAILED 130
501 * Request from client for list of indexed files.
503 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_GET 131
506 * Reply to client with an indexed file name.
508 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_ENTRY 132
511 * Reply to client indicating end of list.
513 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_END 133
516 * Request from client to unindex a file.
518 #define GNUNET_MESSAGE_TYPE_FS_UNINDEX 134
521 * Reply to client indicating unindex receipt.
523 #define GNUNET_MESSAGE_TYPE_FS_UNINDEX_OK 135
526 * Client asks FS service to start a (keyword) search.
528 #define GNUNET_MESSAGE_TYPE_FS_START_SEARCH 136
531 * P2P request for content (one FS to another).
533 #define GNUNET_MESSAGE_TYPE_FS_GET 137
536 * P2P response with content or active migration of content. Also
537 * used between the service and clients (in response to
538 * #GNUNET_MESSAGE_TYPE_FS_START_SEARCH).
540 #define GNUNET_MESSAGE_TYPE_FS_PUT 138
543 * Peer asks us to stop migrating content towards it for a while.
545 #define GNUNET_MESSAGE_TYPE_FS_MIGRATION_STOP 139
548 * P2P request for content (one FS to another via a cadet).
550 #define GNUNET_MESSAGE_TYPE_FS_CADET_QUERY 140
553 * P2P answer for content (one FS to another via a cadet).
555 #define GNUNET_MESSAGE_TYPE_FS_CADET_REPLY 141
558 /*******************************************************************************
560 ******************************************************************************/
562 * Client wants to store item in DHT.
564 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_PUT 142
567 * Client wants to lookup item in DHT.
569 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET 143
572 * Client wants to stop search in DHT.
574 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET_STOP 144
577 * Service returns result to client.
579 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_RESULT 145
582 * Peer is storing data in DHT.
584 #define GNUNET_MESSAGE_TYPE_DHT_P2P_PUT 146
587 * Peer tries to find data in DHT.
589 #define GNUNET_MESSAGE_TYPE_DHT_P2P_GET 147
592 * Data is returned to peer from DHT.
594 #define GNUNET_MESSAGE_TYPE_DHT_P2P_RESULT 148
597 * Receive information about transiting GETs
599 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_GET 149
602 * Receive information about transiting GET responses
604 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_GET_RESP 150
607 * Receive information about transiting PUTs
609 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_PUT 151
612 * Receive information about transiting PUT responses (TODO)
614 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_PUT_RESP 152
617 * Request information about transiting messages
619 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_START 153
622 * Stop information about transiting messages
624 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_STOP 154
627 * Acknowledge receiving PUT request
629 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_PUT_OK 155
632 * Certain results are already known to the client, filter those.
634 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET_RESULTS_KNOWN 156
637 * Further X-VINE DHT messages continued from 880
640 /*******************************************************************************
641 * HOSTLIST message types
642 ******************************************************************************/
645 * Hostlist advertisement message
647 #define GNUNET_MESSAGE_TYPE_HOSTLIST_ADVERTISEMENT 160
650 /*******************************************************************************
651 * STATISTICS message types
652 ******************************************************************************/
655 * Set a statistical value.
657 #define GNUNET_MESSAGE_TYPE_STATISTICS_SET 168
660 * Get a statistical value(s).
662 #define GNUNET_MESSAGE_TYPE_STATISTICS_GET 169
665 * Response to a STATISTICS_GET message (with value).
667 #define GNUNET_MESSAGE_TYPE_STATISTICS_VALUE 170
670 * Response to a STATISTICS_GET message (end of value stream).
672 #define GNUNET_MESSAGE_TYPE_STATISTICS_END 171
675 * Watch changes to a statistical value. Message format is the same
676 * as for GET, except that the subsystem and entry name must be given.
678 #define GNUNET_MESSAGE_TYPE_STATISTICS_WATCH 172
681 * Changes to a watched value.
683 #define GNUNET_MESSAGE_TYPE_STATISTICS_WATCH_VALUE 173
686 * Client is done sending service requests and will now disconnect.
688 #define GNUNET_MESSAGE_TYPE_STATISTICS_DISCONNECT 174
691 * Service confirms disconnect and that it is done processing
692 * all requests from the client.
694 #define GNUNET_MESSAGE_TYPE_STATISTICS_DISCONNECT_CONFIRM 175
696 /*******************************************************************************
698 ******************************************************************************/
701 * Type of messages between the gnunet-vpn-helper and the daemon
703 #define GNUNET_MESSAGE_TYPE_VPN_HELPER 185
706 * Type of messages containing an ICMP packet for a service.
708 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_SERVICE 190
711 * Type of messages containing an ICMP packet for the Internet.
713 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_INTERNET 191
716 * Type of messages containing an ICMP packet for the VPN
718 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_VPN 192
721 * Type of messages containing an DNS request for a DNS exit service.
723 #define GNUNET_MESSAGE_TYPE_VPN_DNS_TO_INTERNET 193
726 * Type of messages containing an DNS reply from a DNS exit service.
728 #define GNUNET_MESSAGE_TYPE_VPN_DNS_FROM_INTERNET 194
731 * Type of messages containing an TCP packet for a service.
733 #define GNUNET_MESSAGE_TYPE_VPN_TCP_TO_SERVICE_START 195
736 * Type of messages containing an TCP packet for the Internet.
738 #define GNUNET_MESSAGE_TYPE_VPN_TCP_TO_INTERNET_START 196
741 * Type of messages containing an TCP packet of an established connection.
743 #define GNUNET_MESSAGE_TYPE_VPN_TCP_DATA_TO_EXIT 197
746 * Type of messages containing an TCP packet of an established connection.
748 #define GNUNET_MESSAGE_TYPE_VPN_TCP_DATA_TO_VPN 198
751 * Type of messages containing an UDP packet for a service.
753 #define GNUNET_MESSAGE_TYPE_VPN_UDP_TO_SERVICE 199
756 * Type of messages containing an UDP packet for the Internet.
758 #define GNUNET_MESSAGE_TYPE_VPN_UDP_TO_INTERNET 200
761 * Type of messages containing an UDP packet from a remote host
763 #define GNUNET_MESSAGE_TYPE_VPN_UDP_REPLY 201
767 * Client asks VPN service to setup an IP to redirect traffic
768 * via an exit node to some global IP address.
770 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_REDIRECT_TO_IP 202
773 * Client asks VPN service to setup an IP to redirect traffic
774 * to some peer offering a service.
776 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_REDIRECT_TO_SERVICE 203
779 * VPN service responds to client with an IP to use for the
780 * requested redirection.
782 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_USE_IP 204
785 /*******************************************************************************
786 * VPN-DNS message types
787 ******************************************************************************/
791 * Initial message from client to DNS service for registration.
793 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_INIT 211
796 * Type of messages between the gnunet-helper-dns and the service
798 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_REQUEST 212
801 * Type of messages between the gnunet-helper-dns and the service
803 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_RESPONSE 213
806 * Type of messages between the gnunet-helper-dns and the service
808 #define GNUNET_MESSAGE_TYPE_DNS_HELPER 214
812 /*******************************************************************************
813 * CHAT message types START
814 ******************************************************************************/
817 * Message sent from client to join a chat room.
819 #define GNUNET_MESSAGE_TYPE_CHAT_JOIN_REQUEST 300
822 * Message sent to client to indicate joining of another room member.
824 #define GNUNET_MESSAGE_TYPE_CHAT_JOIN_NOTIFICATION 301
827 * Message sent to client to indicate leaving of another room member.
829 #define GNUNET_MESSAGE_TYPE_CHAT_LEAVE_NOTIFICATION 302
832 * Notification sent by service to client indicating that we've received a chat
835 #define GNUNET_MESSAGE_TYPE_CHAT_MESSAGE_NOTIFICATION 303
838 * Request sent by client to transmit a chat message to another room members.
840 #define GNUNET_MESSAGE_TYPE_CHAT_TRANSMIT_REQUEST 304
843 * Receipt sent from a message receiver to the service to confirm delivery of
846 #define GNUNET_MESSAGE_TYPE_CHAT_CONFIRMATION_RECEIPT 305
849 * Notification sent from the service to the original sender
850 * to acknowledge delivery of a chat message.
852 #define GNUNET_MESSAGE_TYPE_CHAT_CONFIRMATION_NOTIFICATION 306
855 * P2P message sent to indicate joining of another room member.
857 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_JOIN_NOTIFICATION 307
860 * P2P message sent to indicate leaving of another room member.
862 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_LEAVE_NOTIFICATION 308
865 * P2P message sent to a newly connected peer to request its known clients in
866 * order to synchronize room members.
868 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_SYNC_REQUEST 309
871 * Notification sent from one peer to another to indicate that we have received
874 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_MESSAGE_NOTIFICATION 310
877 * P2P receipt confirming delivery of a chat message.
879 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_CONFIRMATION_RECEIPT 311
882 /*******************************************************************************
883 * NSE (network size estimation) message types
884 ******************************************************************************/
887 * client->service message indicating start
889 #define GNUNET_MESSAGE_TYPE_NSE_START 321
892 * P2P message sent from nearest peer
894 #define GNUNET_MESSAGE_TYPE_NSE_P2P_FLOOD 322
897 * service->client message indicating
899 #define GNUNET_MESSAGE_TYPE_NSE_ESTIMATE 323
902 /*******************************************************************************
903 * PEERINFO message types
904 ******************************************************************************/
907 * Request update and listing of a peer.
909 #define GNUNET_MESSAGE_TYPE_PEERINFO_GET 330
912 * Request update and listing of all peers.
914 #define GNUNET_MESSAGE_TYPE_PEERINFO_GET_ALL 331
917 * Information about one of the peers.
919 #define GNUNET_MESSAGE_TYPE_PEERINFO_INFO 332
922 * End of information about other peers.
924 #define GNUNET_MESSAGE_TYPE_PEERINFO_INFO_END 333
927 * Start notifying this client about all changes to
928 * the known peers until it disconnects.
930 #define GNUNET_MESSAGE_TYPE_PEERINFO_NOTIFY 334
932 /*******************************************************************************
934 ******************************************************************************/
937 * Type of the 'struct ClientStartMessage' sent by clients to ATS to
938 * identify the type of the client.
940 #define GNUNET_MESSAGE_TYPE_ATS_START 340
943 * Type of the 'struct RequestAddressMessage' sent by clients to ATS
944 * to request an address to help connect.
946 #define GNUNET_MESSAGE_TYPE_ATS_REQUEST_ADDRESS 341
949 * Type of the 'struct RequestAddressMessage' sent by clients to ATS
950 * to request an address to help connect.
952 #define GNUNET_MESSAGE_TYPE_ATS_REQUEST_ADDRESS_CANCEL 342
955 * Type of the 'struct AddressUpdateMessage' sent by clients to ATS
956 * to inform ATS about performance changes.
958 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_UPDATE 343
961 * Type of the 'struct AddressDestroyedMessage' sent by clients to ATS
962 * to inform ATS about an address being unavailable.
964 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_DESTROYED 344
967 * Type of the 'struct AddressSuggestionMessage' sent by ATS to clients
968 * to suggest switching to a different address.
970 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_SUGGESTION 345
973 * Type of the 'struct PeerInformationMessage' sent by ATS to clients
974 * to inform about QoS for a particular connection.
976 #define GNUNET_MESSAGE_TYPE_ATS_PEER_INFORMATION 346
979 * Type of the 'struct ReservationRequestMessage' sent by clients to ATS
980 * to ask for inbound bandwidth reservations.
982 #define GNUNET_MESSAGE_TYPE_ATS_RESERVATION_REQUEST 347
985 * Type of the 'struct ReservationResultMessage' sent by ATS to clients
986 * in response to a reservation request.
988 #define GNUNET_MESSAGE_TYPE_ATS_RESERVATION_RESULT 348
991 * Type of the 'struct ChangePreferenceMessage' sent by clients to ATS
992 * to ask for allocation preference changes.
994 #define GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_CHANGE 349
997 * Type of the 'struct SessionReleaseMessage' sent by ATS to client
998 * to confirm that a session ID was destroyed.
1000 #define GNUNET_MESSAGE_TYPE_ATS_SESSION_RELEASE 350
1003 * Type of the 'struct AddressUpdateMessage' sent by client to ATS
1004 * to add a new address
1006 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_ADD 353
1009 * Type of the 'struct AddressListRequestMessage' sent by client to ATS
1010 * to request information about addresses
1012 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESSLIST_REQUEST 354
1015 * Type of the 'struct AddressListResponseMessage' sent by ATS to client
1016 * with information about addresses
1018 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESSLIST_RESPONSE 355
1021 * Type of the 'struct ChangePreferenceMessage' sent by clients to ATS
1022 * to ask for allocation preference changes.
1024 #define GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_FEEDBACK 356
1027 /*******************************************************************************
1028 * TRANSPORT message types
1029 ******************************************************************************/
1032 * Message from the core saying that the transport
1033 * server should start giving it messages. This
1034 * should automatically trigger the transmission of
1037 #define GNUNET_MESSAGE_TYPE_TRANSPORT_START 360
1040 * Message from TRANSPORT notifying about a
1041 * client that connected to us.
1043 #define GNUNET_MESSAGE_TYPE_TRANSPORT_CONNECT 361
1046 * Message from TRANSPORT notifying about a
1047 * client that disconnected from us.
1049 #define GNUNET_MESSAGE_TYPE_TRANSPORT_DISCONNECT 362
1052 * Request to TRANSPORT to transmit a message.
1054 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SEND 363
1057 * Confirmation from TRANSPORT that message for transmission has been
1058 * queued (and that the next message to this peer can now be passed to
1059 * the service). Note that this confirmation does NOT imply that the
1060 * message was fully transmitted.
1062 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SEND_OK 364
1065 * Message from TRANSPORT notifying about a
1066 * message that was received.
1068 #define GNUNET_MESSAGE_TYPE_TRANSPORT_RECV 365
1071 * Message telling transport to limit its receive rate.
1073 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SET_QUOTA 366
1076 * Request to look addresses of peers in server.
1078 #define GNUNET_MESSAGE_TYPE_TRANSPORT_ADDRESS_TO_STRING 367
1081 * Response to the address lookup request.
1083 #define GNUNET_MESSAGE_TYPE_TRANSPORT_ADDRESS_TO_STRING_REPLY 368
1086 * Register a client that wants to do blacklisting.
1088 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_INIT 369
1091 * Query to a blacklisting client (is this peer blacklisted)?
1093 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_QUERY 370
1096 * Reply from blacklisting client (answer to blacklist query).
1098 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_REPLY 371
1101 * Transport PING message
1103 #define GNUNET_MESSAGE_TYPE_TRANSPORT_PING 372
1106 * Transport PONG message
1108 #define GNUNET_MESSAGE_TYPE_TRANSPORT_PONG 373
1111 * Transport SYN message exchanged between transport services to
1112 * indicate that a session should be marked as 'connected'.
1114 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_SYN 375
1117 * Transport SYN_ACK message exchanged between transport services to
1118 * indicate that a SYN message was accepted
1120 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_SYN_ACK 376
1123 * Transport ACK message exchanged between transport services to
1124 * indicate that a SYN_ACK message was accepted
1126 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_ACK 377
1129 * Transport DISCONNECT message exchanged between transport services to
1130 * indicate that a connection should be dropped.
1132 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_DISCONNECT 378
1135 * Message exchanged between transport services to
1136 * indicate that the sender should limit its transmission
1137 * rate to the indicated quota.
1139 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_QUOTA 379
1142 * Request to monitor addresses used by a peer or all peers.
1144 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_REQUEST 380
1147 * Message send by a peer to notify the other to keep the session alive
1148 * and measure latency in a regular interval
1150 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE 381
1153 * Response to a #GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE message to
1154 * measure latency in a regular interval
1156 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE_RESPONSE 382
1159 * Response to #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_REQUEST
1160 * request to iterate over all known addresses.
1162 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE 383
1165 * Message send by a peer to notify the other to keep the session alive.
1167 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BROADCAST_BEACON 384
1170 * Message containing traffic metrics for transport service
1172 #define GNUNET_MESSAGE_TYPE_TRANSPORT_TRAFFIC_METRIC 385
1175 * Request to start monitoring the connection state of plugins.
1177 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_START 388
1180 * Monitoring event about the connection state of plugins,
1181 * generated in response to a subscription initiated via
1182 * #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_START
1184 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_EVENT 389
1187 * Monitoring event notifying client that the initial iteration
1188 * is now completed and we are in sync with the state of the subsystem.
1190 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_SYNC 390
1193 * Response to #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE_END
1194 * terminating list of replies.
1196 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE_END 391
1199 /*******************************************************************************
1200 * FS-PUBLISH-HELPER IPC Messages
1201 ******************************************************************************/
1204 * Progress information from the helper: found a file
1206 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_PROGRESS_FILE 420
1209 * Progress information from the helper: found a directory
1211 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_PROGRESS_DIRECTORY 421
1214 * Error signal from the helper.
1216 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_ERROR 422
1219 * Signal that helper skipped a file.
1221 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_SKIP_FILE 423
1224 * Signal that helper is done scanning the directory tree.
1226 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_COUNTING_DONE 424
1229 * Extracted meta data from the helper.
1231 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_META_DATA 425
1234 * Signal that helper is done.
1236 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_FINISHED 426
1239 /*******************************************************************************
1240 * NAMECACHE message types
1241 ******************************************************************************/
1244 * Client to service: lookup block
1246 #define GNUNET_MESSAGE_TYPE_NAMECACHE_LOOKUP_BLOCK 431
1249 * Service to client: result of block lookup
1251 #define GNUNET_MESSAGE_TYPE_NAMECACHE_LOOKUP_BLOCK_RESPONSE 432
1254 * Client to service: cache a block
1256 #define GNUNET_MESSAGE_TYPE_NAMECACHE_BLOCK_CACHE 433
1259 * Service to client: result of block cache request
1261 #define GNUNET_MESSAGE_TYPE_NAMECACHE_BLOCK_CACHE_RESPONSE 434
1263 /*******************************************************************************
1264 * NAMESTORE message types
1265 ******************************************************************************/
1268 * Client to service: store records (as authority)
1270 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_STORE 435
1273 * Service to client: result of store operation.
1275 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_STORE_RESPONSE 436
1278 * Client to service: lookup label
1280 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_LOOKUP 437
1283 * Service to client: lookup label
1285 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_LOOKUP_RESPONSE 438
1288 * Client to service: "reverse" lookup for zone name based on zone key
1290 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_TO_NAME 439
1293 * Service to client: result of zone-to-name lookup.
1295 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_TO_NAME_RESPONSE 440
1298 * Client to service: start monitoring (yields sequence of
1299 * "ZONE_ITERATION_RESPONSES" --- forever).
1301 #define GNUNET_MESSAGE_TYPE_NAMESTORE_MONITOR_START 441
1304 * Service to client: you're now in sync.
1306 #define GNUNET_MESSAGE_TYPE_NAMESTORE_MONITOR_SYNC 442
1309 * Service to client: here is a (plaintext) record you requested.
1311 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_RESULT 443
1314 * Client to service: please start iteration; receives
1315 * "GNUNET_MESSAGE_TYPE_NAMESTORE_LOOKUP_NAME_RESPONSE" messages in return.
1317 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_START 445
1320 * Client to service: next record in iteration please.
1322 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_NEXT 447
1325 * Client to service: stop iterating.
1327 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_STOP 448
1329 /*******************************************************************************
1330 * LOCKMANAGER message types
1331 ******************************************************************************/
1334 * Message to acquire Lock
1336 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_ACQUIRE 450
1339 * Message to release lock
1341 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_RELEASE 451
1344 * SUCESS reply from lockmanager
1346 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_SUCCESS 452
1348 /*******************************************************************************
1349 * TESTBED message types
1350 ******************************************************************************/
1353 * Initial message from a client to a testing control service
1355 #define GNUNET_MESSAGE_TYPE_TESTBED_INIT 460
1358 * Message to add host
1360 #define GNUNET_MESSAGE_TYPE_TESTBED_ADD_HOST 461
1363 * Message to signal that a add host succeeded
1365 #define GNUNET_MESSAGE_TYPE_TESTBED_ADD_HOST_SUCCESS 462
1368 * Message to link delegated controller to slave controller
1370 #define GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS 463
1373 * Message to create a peer at a host
1375 #define GNUNET_MESSAGE_TYPE_TESTBED_CREATE_PEER 464
1378 * Message to reconfigure a peer
1380 #define GNUNET_MESSAGE_TYPE_TESTBED_RECONFIGURE_PEER 465
1383 * Message to start a peer at a host
1385 #define GNUNET_MESSAGE_TYPE_TESTBED_START_PEER 466
1388 * Message to stop a peer at a host
1390 #define GNUNET_MESSAGE_TYPE_TESTBED_STOP_PEER 467
1393 * Message to destroy a peer
1395 #define GNUNET_MESSAGE_TYPE_TESTBED_DESTROY_PEER 468
1398 * Configure underlay link message
1400 #define GNUNET_MESSAGE_TYPE_TESTBED_CONFIGURE_UNDERLAY_LINK 469
1403 * Message to connect peers in a overlay
1405 #define GNUNET_MESSAGE_TYPE_TESTBED_OVERLAY_CONNECT 470
1408 * Message for peer events
1410 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_EVENT 471
1413 * Message for peer connect events
1415 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_CONNECT_EVENT 472
1418 * Message for operation events
1420 #define GNUNET_MESSAGE_TYPE_TESTBED_OPERATION_FAIL_EVENT 473
1423 * Message to signal successful peer creation
1425 #define GNUNET_MESSAGE_TYPE_TESTBED_CREATE_PEER_SUCCESS 474
1428 * Message to signal a generic operation has been successful
1430 #define GNUNET_MESSAGE_TYPE_TESTBED_GENERIC_OPERATION_SUCCESS 475
1433 * Message to get a peer's information
1435 #define GNUNET_MESSAGE_TYPE_TESTBED_GET_PEER_INFORMATION 476
1438 * Message containing the peer's information
1440 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_INFORMATION 477
1443 * Message to request a controller to make one of its peer to connect to another
1444 * peer using the contained HELLO
1446 #define GNUNET_MESSAGE_TYPE_TESTBED_REMOTE_OVERLAY_CONNECT 478
1449 * Message to request configuration of a slave controller
1451 #define GNUNET_MESSAGE_TYPE_TESTBED_GET_SLAVE_CONFIGURATION 479
1454 * Message which contains the configuration of slave controller
1456 #define GNUNET_MESSAGE_TYPE_TESTBED_SLAVE_CONFIGURATION 480
1459 * Message to signal the result of #GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS request
1461 #define GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS_RESULT 481
1464 * A controller receiving this message floods it to its directly-connected
1465 * sub-controllers and then stops and destroys all peers
1467 #define GNUNET_MESSAGE_TYPE_TESTBED_SHUTDOWN_PEERS 482
1470 * Message to start/stop a service of a peer
1472 #define GNUNET_MESSAGE_TYPE_TESTBED_MANAGE_PEER_SERVICE 483
1475 * Message to initialise a barrier. Messages of these type are flooded to all
1478 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_INIT 484
1481 * Message to cancel a barrier. This message is flooded to all sub-controllers
1483 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_CANCEL 485
1486 * Message for signalling status of a barrier
1488 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_STATUS 486
1491 * Message sent by a peer when it has reached a barrier and is waiting for it to
1494 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_WAIT 487
1497 * Not really a message, but for careful checks on the testbed messages; Should
1498 * always be the maximum and never be used to send messages with this type
1500 #define GNUNET_MESSAGE_TYPE_TESTBED_MAX 488
1503 * The initialization message towards gnunet-testbed-helper
1505 #define GNUNET_MESSAGE_TYPE_TESTBED_HELPER_INIT 495
1508 * The reply message from gnunet-testbed-helper
1510 #define GNUNET_MESSAGE_TYPE_TESTBED_HELPER_REPLY 496
1513 /******************************************************************************
1515 *****************************************************************************/
1518 * Client would like to resolve a name.
1520 #define GNUNET_MESSAGE_TYPE_GNS_LOOKUP 500
1523 * Service response to name resolution request from client.
1525 #define GNUNET_MESSAGE_TYPE_GNS_LOOKUP_RESULT 501
1530 #define GNUNET_MESSAGE_TYPE_GNS_REVERSE_LOOKUP 503
1533 * Response to reverse lookup
1535 #define GNUNET_MESSAGE_TYPE_GNS_REVERSE_LOOKUP_RESULT 504
1538 /*******************************************************************************
1539 * CONSENSUS message types
1540 ******************************************************************************/
1543 * Join a consensus session. Sent by client to service as first message.
1545 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_JOIN 520
1548 * Insert an element. Sent by client to service.
1550 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_INSERT 521
1553 * Begin accepting new elements from other participants.
1554 * Sent by client to service.
1556 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_BEGIN 522
1559 * Sent by service when a new element is added.
1561 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_RECEIVED_ELEMENT 523
1564 * Sent by client to service in order to start the consensus conclusion.
1566 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_CONCLUDE 524
1569 * Sent by service to client in order to signal a completed consensus conclusion.
1570 * Last message sent in a consensus session.
1572 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_CONCLUDE_DONE 525
1575 /* message types 526-539 reserved for consensus client/service messages */
1579 * Sent by client to service, telling whether a received element should
1580 * be accepted and propagated further or not.
1582 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_ACK 540
1587 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_DELTA_ESTIMATE 541
1590 * IBF containing all elements of a peer.
1592 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_DIFFERENCE_DIGEST 542
1595 * One or more elements that are sent from peer to peer.
1597 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS 543
1600 * Elements, and requests for further elements
1602 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS_REQUEST 544
1605 * Elements that a peer reports to be missing at the remote peer.
1607 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS_REPORT 545
1610 * Initialization message for consensus p2p communication.
1612 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_HELLO 546
1615 * Report that the peer is synced with the partner after successfuly decoding the invertible bloom filter.
1617 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_SYNCED 547
1620 * Interaction os over, got synched and reported all elements
1622 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_FIN 548
1625 * Abort a round, don't send requested elements anymore
1627 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ABORT 548
1630 * Abort a round, don't send requested elements anymore
1632 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ROUND_CONTEXT 547
1635 /*******************************************************************************
1637 ******************************************************************************/
1640 * Demand the whole element from the other
1641 * peer, given only the hash code.
1643 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_REQUEST_FULL 565
1646 * Demand the whole element from the other
1647 * peer, given only the hash code.
1649 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_DEMAND 566
1652 * Tell the other peer to send us a list of
1653 * hashes that match an IBF key.
1655 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_INQUIRY 567
1658 * Tell the other peer which hashes match a
1661 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_OFFER 568
1664 * Reject a set request.
1666 #define GNUNET_MESSAGE_TYPE_SET_REJECT 569
1669 * Cancel a set operation
1671 #define GNUNET_MESSAGE_TYPE_SET_CANCEL 570
1674 * Acknowledge result from iteration
1676 #define GNUNET_MESSAGE_TYPE_SET_ITER_ACK 571
1679 * Create an empty set
1681 #define GNUNET_MESSAGE_TYPE_SET_RESULT 572
1684 * Add element to set
1686 #define GNUNET_MESSAGE_TYPE_SET_ADD 573
1689 * Remove element from set
1691 #define GNUNET_MESSAGE_TYPE_SET_REMOVE 574
1694 * Listen for operation requests
1696 #define GNUNET_MESSAGE_TYPE_SET_LISTEN 575
1699 * Accept a set request
1701 #define GNUNET_MESSAGE_TYPE_SET_ACCEPT 576
1704 * Evaluate a set operation
1706 #define GNUNET_MESSAGE_TYPE_SET_EVALUATE 577
1709 * Start a set operation with the given set
1711 #define GNUNET_MESSAGE_TYPE_SET_CONCLUDE 578
1714 * Notify the client of a request from a remote peer
1716 #define GNUNET_MESSAGE_TYPE_SET_REQUEST 579
1719 * Create a new local set
1721 #define GNUNET_MESSAGE_TYPE_SET_CREATE 580
1724 * Request a set operation from a remote peer.
1726 #define GNUNET_MESSAGE_TYPE_SET_P2P_OPERATION_REQUEST 581
1731 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_SE 582
1734 * Invertible bloom filter.
1736 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_IBF 583
1739 * Actual set elements.
1741 #define GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENTS 584
1744 * Requests for the elements with the given hashes.
1746 #define GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENT_REQUESTS 585
1749 * Set operation is done.
1751 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_DONE 586
1754 * Start iteration over set elements.
1756 #define GNUNET_MESSAGE_TYPE_SET_ITER_REQUEST 587
1759 * Element result for the iterating client.
1761 #define GNUNET_MESSAGE_TYPE_SET_ITER_ELEMENT 588
1764 * Iteration end marker for the client.
1766 #define GNUNET_MESSAGE_TYPE_SET_ITER_DONE 589
1769 * Compressed strata estimator.
1771 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_SEC 590
1774 * Information about the element count for intersection
1776 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_ELEMENT_INFO 591
1779 * Bloom filter message for intersection exchange started by Bob.
1781 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_BF 592
1784 * Intersection operation is done.
1786 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_DONE 593
1789 * Ask the set service to prepare a copy of a set.
1791 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_PREPARE 594
1794 * Give the client an ID for connecting to the set's copy.
1796 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_RESPONSE 595
1799 * Sent by the client to the server to connect to an existing,
1800 * lazily copied set.
1802 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_CONNECT 596
1805 * Request all missing elements from the other peer,
1806 * based on their sets and the elements we previously sent
1807 * with #GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENTS.
1809 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_FULL_DONE 597
1812 * Send a set element, not as response to a demand but because
1813 * we're sending the full set.
1815 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_FULL_ELEMENT 598
1818 * Request all missing elements from the other peer,
1819 * based on their sets and the elements we previously sent
1820 * with #GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENTS.
1822 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_OVER 599
1825 /*******************************************************************************
1826 * TESTBED LOGGER message types
1827 ******************************************************************************/
1830 * Message for TESTBED LOGGER
1832 #define GNUNET_MESSAGE_TYPE_TESTBED_LOGGER_MSG 600
1835 * Message for TESTBED LOGGER acknowledgement
1837 #define GNUNET_MESSAGE_TYPE_TESTBED_LOGGER_ACK 601
1842 * Advertise regex capability.
1844 #define GNUNET_MESSAGE_TYPE_REGEX_ANNOUNCE 620
1847 * Search for peer with matching capability.
1849 #define GNUNET_MESSAGE_TYPE_REGEX_SEARCH 621
1852 * Result in response to regex search.
1854 #define GNUNET_MESSAGE_TYPE_REGEX_RESULT 622
1856 /*******************************************************************************
1857 * IDENTITY message types
1858 ******************************************************************************/
1861 * First message send from identity client to service (to subscribe to
1864 #define GNUNET_MESSAGE_TYPE_IDENTITY_START 624
1867 * Generic response from identity service with success and/or error message.
1869 #define GNUNET_MESSAGE_TYPE_IDENTITY_RESULT_CODE 625
1872 * Update about identity status from service to clients.
1874 #define GNUNET_MESSAGE_TYPE_IDENTITY_UPDATE 626
1877 * Client requests to know default identity for a subsystem.
1879 #define GNUNET_MESSAGE_TYPE_IDENTITY_GET_DEFAULT 627
1882 * Client sets default identity; or service informs about default identity.
1884 #define GNUNET_MESSAGE_TYPE_IDENTITY_SET_DEFAULT 628
1887 * Create new identity (client->service).
1889 #define GNUNET_MESSAGE_TYPE_IDENTITY_CREATE 629
1892 * Rename existing identity (client->service).
1894 #define GNUNET_MESSAGE_TYPE_IDENTITY_RENAME 630
1897 * Delete identity (client->service).
1899 #define GNUNET_MESSAGE_TYPE_IDENTITY_DELETE 631
1902 /*******************************************************************************
1903 * REVOCATION message types
1904 ******************************************************************************/
1907 * Client to service: was this key revoked?
1909 #define GNUNET_MESSAGE_TYPE_REVOCATION_QUERY 636
1912 * Service to client: answer if key was revoked!
1914 #define GNUNET_MESSAGE_TYPE_REVOCATION_QUERY_RESPONSE 637
1917 * Client to service OR peer-to-peer: revoke this key!
1919 #define GNUNET_MESSAGE_TYPE_REVOCATION_REVOKE 638
1922 * Service to client: revocation confirmed
1924 #define GNUNET_MESSAGE_TYPE_REVOCATION_REVOKE_RESPONSE 639
1927 /*******************************************************************************
1928 * SCALARPRODUCT message types
1929 ******************************************************************************/
1934 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_TO_ALICE 640
1939 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_TO_BOB 641
1942 * Client -> Alice multipart
1944 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_MULTIPART_ALICE 642
1947 * Client -> Bob multipart
1949 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_MULTIPART_BOB 643
1952 * Alice -> Bob session initialization
1954 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_SESSION_INITIALIZATION 644
1957 * Alice -> Bob SP crypto-data (after intersection)
1959 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ALICE_CRYPTODATA 645
1962 * Bob -> Alice SP crypto-data
1964 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_BOB_CRYPTODATA 647
1967 * Bob -> Alice SP crypto-data multipart
1969 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_BOB_CRYPTODATA_MULTIPART 648
1972 * Alice/Bob -> Client Result
1974 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_RESULT 649
1977 * Alice -> Bob ECC session initialization
1979 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_SESSION_INITIALIZATION 650
1982 * Alice -> Bob ECC crypto data
1984 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_ALICE_CRYPTODATA 651
1987 * Bob -> Alice ECC crypto data
1989 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_BOB_CRYPTODATA 652
1995 /*******************************************************************************
1996 * PSYCSTORE message types
1997 ******************************************************************************/
2000 * Store a membership event.
2002 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MEMBERSHIP_STORE 660
2005 * Test for membership of a member at a particular point in time.
2007 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MEMBERSHIP_TEST 661
2009 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_FRAGMENT_STORE 662
2011 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_FRAGMENT_GET 663
2013 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MESSAGE_GET 664
2015 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MESSAGE_GET_FRAGMENT 665
2017 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_COUNTERS_GET 666
2021 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_MODIFY 668
2023 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_SYNC 669
2025 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_RESET 670
2027 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_HASH_UPDATE 671
2029 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_GET 672
2031 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_GET_PREFIX 673
2034 * Generic response from PSYCstore service with success and/or error message.
2036 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_CODE 674
2038 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_FRAGMENT 675
2040 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_COUNTERS 676
2042 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_STATE 677
2045 /*******************************************************************************
2046 * PSYC message types
2047 ******************************************************************************/
2055 /** S->C: result of an operation */
2056 #define GNUNET_MESSAGE_TYPE_PSYC_RESULT_CODE 680
2058 /** C->S: request to start a channel as a master */
2059 #define GNUNET_MESSAGE_TYPE_PSYC_MASTER_START 681
2061 /** S->C: master start acknowledgement */
2062 #define GNUNET_MESSAGE_TYPE_PSYC_MASTER_START_ACK 682
2064 /** C->S: request to join a channel as a slave */
2065 #define GNUNET_MESSAGE_TYPE_PSYC_SLAVE_JOIN 683
2067 /** S->C: slave join acknowledgement */
2068 #define GNUNET_MESSAGE_TYPE_PSYC_SLAVE_JOIN_ACK 684
2070 /** C->S: request to part from a channel */
2071 #define GNUNET_MESSAGE_TYPE_PSYC_PART_REQUEST 685
2073 /** S->C: acknowledgement that a slave of master parted from a channel */
2074 #define GNUNET_MESSAGE_TYPE_PSYC_PART_ACK 686
2076 /** M->S->C: incoming join request from multicast */
2077 #define GNUNET_MESSAGE_TYPE_PSYC_JOIN_REQUEST 687
2079 /** C->S->M: decision about a join request */
2080 #define GNUNET_MESSAGE_TYPE_PSYC_JOIN_DECISION 688
2083 /** C->S: request to add/remove channel slave in the membership database. */
2084 #define GNUNET_MESSAGE_TYPE_PSYC_CHANNEL_MEMBERSHIP_STORE 689
2088 /** S<--C: PSYC message which contains one or more message parts. */
2089 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE 691
2091 /** M<->S<->C: PSYC message which contains a header and one or more message parts. */
2092 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_HEADER 692 // FIXME: start using this where appropriate
2094 /** Message part: method */
2095 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_METHOD 693
2097 /** Message part: modifier */
2098 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_MODIFIER 694
2100 /** Message part: modifier continuation */
2101 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_MOD_CONT 695
2103 /** Message part: data */
2104 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_DATA 696
2106 /** Message part: end of message */
2107 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_END 697
2109 /** Message part: message cancelled */
2110 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_CANCEL 698
2112 /** S->C: message acknowledgement */
2113 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_ACK 699
2117 /** C->S: request channel history replay from PSYCstore. */
2118 #define GNUNET_MESSAGE_TYPE_PSYC_HISTORY_REPLAY 701
2120 /** S->C: result for a channel history request */
2121 #define GNUNET_MESSAGE_TYPE_PSYC_HISTORY_RESULT 702
2124 /** C->S: request best matching state variable from PSYCstore. */
2125 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_GET 703
2127 /** C->S: request state variables with a given prefix from PSYCstore. */
2128 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_GET_PREFIX 704
2130 /** S->C: result for a state request. */
2131 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_RESULT 705
2134 /*******************************************************************************
2135 * CONVERSATION message types
2136 ******************************************************************************/
2139 * Message to transmit the audio between helper and speaker/microphone library.
2141 #define GNUNET_MESSAGE_TYPE_CONVERSATION_AUDIO 730
2144 * Client -> Server message to register a phone.
2146 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_REGISTER 731
2149 * Client -> Server message to reject/hangup a call
2151 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_PICK_UP 732
2154 * Client -> Server message to reject/hangup a call
2156 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_HANG_UP 733
2159 * Client <- Server message to indicate a ringing phone
2161 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_CALL 734
2164 * Client <- Server message to indicate a ringing phone
2166 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_RING 735
2169 * Client <-> Server message to suspend connection.
2171 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_SUSPEND 736
2174 * Client <-> Server message to resume connection.
2176 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_RESUME 737
2179 * Service -> Client message to notify that phone was picked up.
2181 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_PICKED_UP 738
2184 * Client <-> Server message to send audio data.
2186 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_AUDIO 739
2189 * Cadet: call initiation
2191 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_RING 740
2194 * Cadet: hang up / refuse call
2196 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_HANG_UP 741
2199 * Cadet: pick up phone (establish audio channel)
2201 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_PICK_UP 742
2204 * Cadet: phone suspended.
2206 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_SUSPEND 743
2209 * Cadet: phone resumed.
2211 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_RESUME 744
2216 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_AUDIO 745
2219 /*******************************************************************************
2220 * MULTICAST message types
2221 ******************************************************************************/
2230 * C->S: Start the origin.
2232 #define GNUNET_MESSAGE_TYPE_MULTICAST_ORIGIN_START 750
2235 * C->S: Join group as a member.
2237 #define GNUNET_MESSAGE_TYPE_MULTICAST_MEMBER_JOIN 751
2240 * C<--S<->T: A peer wants to join the group.
2242 * Unicast message to the origin or another group member.
2244 #define GNUNET_MESSAGE_TYPE_MULTICAST_JOIN_REQUEST 752
2247 * C<->S<->T: Response to a join request.
2249 * Unicast message from a group member to the peer wanting to join.
2251 #define GNUNET_MESSAGE_TYPE_MULTICAST_JOIN_DECISION 753
2254 * A peer wants to part the group.
2256 #define GNUNET_MESSAGE_TYPE_MULTICAST_PART_REQUEST 754
2259 * Acknowledgement sent in response to a part request.
2261 * Unicast message from a group member to the peer wanting to part.
2263 #define GNUNET_MESSAGE_TYPE_MULTICAST_PART_ACK 755
2265 // FIXME: this is never used!
2269 #define GNUNET_MESSAGE_TYPE_MULTICAST_GROUP_END 756
2272 * C<->S<->T: Multicast message from the origin to all members.
2274 #define GNUNET_MESSAGE_TYPE_MULTICAST_MESSAGE 757
2277 * C<->S<->T: Unicast request from a group member to the origin.
2279 #define GNUNET_MESSAGE_TYPE_MULTICAST_REQUEST 758
2282 * C->S: Acknowledgement of a message or request fragment for the client.
2284 #define GNUNET_MESSAGE_TYPE_MULTICAST_FRAGMENT_ACK 759
2287 * C<->S<->T: Replay request from a group member to another member.
2289 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_REQUEST 760
2292 * C<->S<->T: Replay response from a group member to another member.
2294 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_RESPONSE 761
2297 * C<->S: End of replay response.
2299 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_RESPONSE_END 762
2303 /*******************************************************************************
2304 * SECRETSHARING message types
2305 ******************************************************************************/
2309 * Establish a new session.
2311 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_GENERATE 780
2314 * Request the decryption of a ciphertext.
2316 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_DECRYPT 781
2319 * The service succeeded in decrypting a ciphertext.
2321 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_DECRYPT_DONE 782
2324 * The cryptosystem has been established.
2325 * Contains the peer's share.
2327 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_SECRET_READY 783
2330 /*******************************************************************************
2331 * PEERSTORE message types
2332 ******************************************************************************/
2335 * Store request message
2337 #define GNUNET_MESSAGE_TYPE_PEERSTORE_STORE 820
2342 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE 821
2345 * Iteration record message
2347 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE_RECORD 822
2350 * Iteration end message
2352 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE_END 823
2357 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH 824
2362 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH_RECORD 825
2365 * Watch cancel request
2367 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH_CANCEL 826
2369 /*******************************************************************************
2370 * SOCIAL message types
2371 ******************************************************************************/
2379 /** S->C: result of an operation */
2380 #define GNUNET_MESSAGE_TYPE_SOCIAL_RESULT_CODE 840
2382 /** C->S: request to enter a place as the host */
2383 #define GNUNET_MESSAGE_TYPE_SOCIAL_HOST_ENTER 841
2385 /** S->C: host enter acknowledgement */
2386 #define GNUNET_MESSAGE_TYPE_SOCIAL_HOST_ENTER_ACK 842
2388 /** C->S: request to enter a place as a guest */
2389 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER 843
2391 /** C->S: request to enter a place as a guest, using a GNS address */
2392 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER_BY_NAME 844
2394 /** S->C: guest enter acknowledgement */
2395 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER_ACK 845
2397 /** P->S->C: incoming entry request from PSYC */
2398 #define GNUNET_MESSAGE_TYPE_SOCIAL_ENTRY_REQUEST 846
2400 /** C->S->P: decision about an entry request */
2401 #define GNUNET_MESSAGE_TYPE_SOCIAL_ENTRY_DECISION 847
2403 /** C->S: request to leave a place */
2404 #define GNUNET_MESSAGE_TYPE_SOCIAL_PLACE_LEAVE 848
2406 /** S->C: place leave acknowledgement */
2407 #define GNUNET_MESSAGE_TYPE_SOCIAL_PLACE_LEAVE_ACK 849
2409 /** C->S: add place to GNS zone */
2410 #define GNUNET_MESSAGE_TYPE_SOCIAL_ZONE_ADD_PLACE 850
2412 /** C->S: add nym to GNS zone */
2413 #define GNUNET_MESSAGE_TYPE_SOCIAL_ZONE_ADD_NYM 851
2415 /** C->S: connect application */
2416 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_CONNECT 852
2418 /** C->S: detach a place from application */
2419 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_DETACH 853
2421 /** S->C: notify about an existing ego */
2422 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_EGO 854
2424 /** S->C: end of ego list */
2425 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_EGO_END 855
2427 /** S->C: notify about an existing place */
2428 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_PLACE 856
2430 /** S->C: end of place list */
2431 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_PLACE_END 857
2433 /** C->S: set message processing flags */
2434 #define GNUNET_MESSAGE_TYPE_SOCIAL_MSG_PROC_SET 858
2436 /** C->S: clear message processing flags */
2437 #define GNUNET_MESSAGE_TYPE_SOCIAL_MSG_PROC_CLEAR 859
2439 /*******************************************************************************
2440 * X-VINE DHT messages
2441 ******************************************************************************/
2444 * Trail setup request is received by a peer.
2446 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP 880
2449 * Trail to a particular peer is returned to this peer.
2451 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP_RESULT 881
2454 * Verify if your immediate successor is still your immediate successor.
2456 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_VERIFY_SUCCESSOR 882
2459 * Notify your new immediate successor that you are its new predecessor.
2461 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_NOTIFY_NEW_SUCCESSOR 883
2464 * Message which contains the immediate predecessor of requested successor
2466 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_VERIFY_SUCCESSOR_RESULT 884
2469 * Message which contains the get result.
2471 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_GET_RESULT 885
2474 * Trail Rejection Message.
2476 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP_REJECTION 886
2479 * Trail Tear down Message.
2481 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_TEARDOWN 887
2484 * Routing table add message.
2486 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_ADD_TRAIL 888
2489 * Peer is storing the data in DHT.
2491 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_PUT 890
2494 * Peer tries to find data in DHT.
2496 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_GET 891
2499 * Send back peer that considers you are its successor, a confirmation
2500 * that you got the notify successor message.
2502 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_NOTIFY_SUCCESSOR_CONFIRMATION 892
2504 #if ENABLE_MALICIOUS
2506 * Turn X-VINE DHT service malicious
2508 #define GNUNET_MESSAGE_TYPE_DHT_ACT_MALICIOUS 893
2511 * Acknowledge receiving ACT MALICIOUS request
2513 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_ACT_MALICIOUS_OK 894
2518 /*******************************************************************************
2519 * Whanau DHT messages
2520 ******************************************************************************/
2524 * This message contains the query for performing a random walk
2526 #define GNUNET_MESSAGE_TYPE_WDHT_RANDOM_WALK 910
2529 * This message contains the result of a random walk
2531 #define GNUNET_MESSAGE_TYPE_WDHT_RANDOM_WALK_RESPONSE 911
2534 * This message contains a notification for the death of a trail
2536 #define GNUNET_MESSAGE_TYPE_WDHT_TRAIL_DESTROY 912
2539 * This message are used to route a query to a peer
2541 #define GNUNET_MESSAGE_TYPE_WDHT_TRAIL_ROUTE 913
2544 * This message contains the query to transfer successor values.
2546 #define GNUNET_MESSAGE_TYPE_WDHT_SUCCESSOR_FIND 914
2549 * Message which contains the get query
2551 #define GNUNET_MESSAGE_TYPE_WDHT_GET 915
2554 * Message which contains the "put", a response to
2555 * #GNUNET_MESSAGE_TYPE_WDHT_SUCCESSOR_FIND.
2557 #define GNUNET_MESSAGE_TYPE_WDHT_PUT 916
2560 * Message which contains the get result, a response
2561 * to #GNUNET_MESSAGE_TYPE_WDHT_GET.
2563 #define GNUNET_MESSAGE_TYPE_WDHT_GET_RESULT 917
2566 /*******************************************************************************
2568 ******************************************************************************/
2573 * RPS check liveliness message to check liveliness of other peer
2575 #define GNUNET_MESSAGE_TYPE_RPS_PP_CHECK_LIVE 950
2578 * RPS PUSH message to push own ID to another peer
2580 #define GNUNET_MESSAGE_TYPE_RPS_PP_PUSH 951
2583 * RPS PULL REQUEST message to request the local view of another peer
2585 #define GNUNET_MESSAGE_TYPE_RPS_PP_PULL_REQUEST 952
2588 * RPS PULL REPLY message which contains the view of the other peer
2590 #define GNUNET_MESSAGE_TYPE_RPS_PP_PULL_REPLY 953
2594 /* Client-Service Messages */
2597 * RPS CS REQUEST Message for the Client to request (a) random peer(s)
2599 #define GNUNET_MESSAGE_TYPE_RPS_CS_REQUEST 954
2602 * RPS CS REPLY Message for the Server to send (a) random peer(s)
2604 #define GNUNET_MESSAGE_TYPE_RPS_CS_REPLY 955
2607 * RPS CS REQUEST CANCEL Message for the Client to cancel a request
2609 #define GNUNET_MESSAGE_TYPE_RPS_CS_REQUEST_CANCEL 956
2612 * RPS CS SEED Message for the Client to seed peers into rps
2614 #define GNUNET_MESSAGE_TYPE_RPS_CS_SEED 957
2616 #ifdef ENABLE_MALICIOUS
2618 * Turn RPS service malicious
2620 #define GNUNET_MESSAGE_TYPE_RPS_ACT_MALICIOUS 958
2622 #endif /* ENABLE_MALICIOUS */
2624 /******************************************************************************/
2627 /**************************************************
2629 * IDENTITY PROVIDER MESSAGE TYPES
2631 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_STORE 961
2633 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_STORE_RESPONSE 962
2635 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_ITERATION_START 963
2637 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_ITERATION_STOP 964
2639 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_ITERATION_NEXT 965
2641 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ATTRIBUTE_RESULT 966
2643 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ISSUE_TICKET 967
2645 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_TICKET_RESULT 968
2647 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_REVOKE_TICKET 969
2649 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_REVOKE_TICKET_RESULT 970
2651 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_CONSUME_TICKET 971
2653 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_CONSUME_TICKET_RESULT 972
2655 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_TICKET_ITERATION_START 973
2657 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_TICKET_ITERATION_STOP 974
2659 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_TICKET_ITERATION_NEXT 975
2661 /**************************************************
2663 * CREDENTIAL MESSAGE TYPES
2665 #define GNUNET_MESSAGE_TYPE_CREDENTIAL_VERIFY 981
2667 #define GNUNET_MESSAGE_TYPE_CREDENTIAL_VERIFY_RESULT 982
2669 #define GNUNET_MESSAGE_TYPE_CREDENTIAL_COLLECT 983
2671 #define GNUNET_MESSAGE_TYPE_CREDENTIAL_COLLECT_RESULT 984
2673 /******************************************************************************/
2676 /******************************************************************************/
2677 /*********************************** CADET **********************************/
2678 /******************************************************************************/
2679 /* CADET: message types 1000-1059
2680 * 1000-1009 Connection-level Messages
2681 * 1010-1019 Channel-level Messages
2682 * 1020-1029 Local Client-Service
2683 * 1030-1039 Local Service Monitoring
2684 * 1040-1049 Application Data
2685 * 1050-1059 Reserved
2688 /******************************** Connection ********************************/
2691 * Request the creation of a connection
2693 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_CREATE 1000
2696 * Send origin an ACK that the connection is complete
2698 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_CREATE_ACK 1001
2701 * Notify that a connection is no longer valid
2703 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_BROKEN 1002
2706 * Request the destuction of a connection
2708 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_DESTROY 1003
2711 * At some point, the route will spontaneously change TODO
2713 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_PATH_CHANGED_UNIMPLEMENTED 1004
2716 * Hop-by-hop, connection dependent ACK.
2720 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_HOP_BY_HOP_ENCRYPTED_ACK 1005
2723 * We do not bother with ACKs for
2724 * #GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED messages, but we instead
2725 * poll for one if we got nothing for a while and start to be worried.
2729 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED_POLL 1006
2732 * Axolotl key exchange.
2734 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_KX 1007
2737 * Axolotl encrypted data.
2739 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED 1008
2742 * Axolotl key exchange response with authentication.
2744 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_KX_AUTH 1009
2748 /********************************** Channel *********************************/
2751 * Payload data (inside an encrypted tunnel).
2753 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_APP_DATA 1010
2756 * Confirm payload data end-to-end.
2758 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_APP_DATA_ACK 1011
2761 * Announce connection is still alive (direction sensitive).
2763 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_KEEPALIVE 1012
2766 * Ask the cadet service to create a new channel.
2768 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN 1013
2771 * Ask the cadet service to destroy a channel.
2773 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_DESTROY 1014
2776 * Confirm the creation of a channel
2778 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN_ACK 1015
2781 * Reject the creation of a channel
2785 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN_NACK_DEPRECATED 1016
2787 /*********************************** Local **********************************/
2790 * Payload client <-> service
2792 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_DATA 1020
2795 * Local ACK for data.
2797 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_ACK 1021
2800 * Start listening on a port.
2802 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_PORT_OPEN 1022
2805 * Stop listening on a port.
2807 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_PORT_CLOSE 1023
2810 * Ask the cadet service to create a new channel.
2812 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_CHANNEL_CREATE 1024
2815 * Tell client that a channel was destroyed.
2817 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_CHANNEL_DESTROY 1025
2819 /********************************** Monitor *********************************/
2823 * Local information about all channels of service.
2825 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CHANNELS 1030
2828 * Local information of service about a specific channel.
2830 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CHANNEL 1031
2833 * Local information about all tunnels of service.
2835 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_TUNNELS 1032
2838 * Local information of service about a specific tunnel.
2840 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_TUNNEL 1033
2843 * Local information about all connections of service.
2845 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CONNECTIONS 1034
2848 * Local information of service about a specific connection.
2850 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CONNECTION 1035
2853 * Local information about all peers known to the service.
2855 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEERS 1036
2858 * Local information of service about a specific peer.
2860 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEER 1037
2865 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_DUMP 1038
2868 * End of local information about all peers known to the service.
2870 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEER_END 1039
2872 /******************************** Application *******************************/
2875 * Traffic (net-cat style) used by the Command Line Interface.
2877 #define GNUNET_MESSAGE_TYPE_CADET_CLI 1040
2879 /******************************************************************************/
2882 /******************************************************************************/
2883 /************************************* NAT **********************************/
2884 /******************************************************************************/
2887 * Message to ask NAT service to register a client.
2889 #define GNUNET_MESSAGE_TYPE_NAT_REGISTER 1060
2892 * Message to ask NAT service to handle a STUN packet.
2894 #define GNUNET_MESSAGE_TYPE_NAT_HANDLE_STUN 1061
2897 * Message to ask NAT service to request connection reversal.
2899 #define GNUNET_MESSAGE_TYPE_NAT_REQUEST_CONNECTION_REVERSAL 1062
2902 * Message to from NAT service notifying us that connection reversal
2903 * was requested by another peer.
2905 #define GNUNET_MESSAGE_TYPE_NAT_CONNECTION_REVERSAL_REQUESTED 1063
2908 * Message to from NAT service notifying us that one of our
2909 * addresses changed.
2911 #define GNUNET_MESSAGE_TYPE_NAT_ADDRESS_CHANGE 1064
2914 * Message to ask NAT service to request autoconfiguration.
2916 #define GNUNET_MESSAGE_TYPE_NAT_AUTO_REQUEST_CFG 1067
2919 * Message from NAT service with the autoconfiguration result.
2921 #define GNUNET_MESSAGE_TYPE_NAT_AUTO_CFG_RESULT 1068
2924 /* 1080-1109 reserved for TMCG (Heiko Stamer, see gnunet-developers, January 2017) */
2927 /******************************************************************************/
2928 /*********************************** AUCTION ********************************/
2929 /******************************************************************************/
2932 * Client wants to create a new auction.
2934 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_CREATE 1110
2937 * Client wants to join an existing auction.
2939 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_JOIN 1111
2942 * Service reports the auction outcome to the client.
2944 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_OUTCOME 1112
2948 * Next available: 1130
2953 * Type used to match 'all' message types.
2955 #define GNUNET_MESSAGE_TYPE_ALL 65535
2958 #if 0 /* keep Emacsens' auto-indent happy */
2965 /* ifndef GNUNET_PROTOCOLS_H */
2968 /** @} */ /* end of group protocols */
2970 /* end of gnunet_protocols.h */