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 update data.
429 #define GNUNET_MESSAGE_TYPE_DATASTORE_UPDATE 96
432 * Message sent by datastore client to get data.
434 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET 97
437 * Message sent by datastore client to get random data.
439 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_REPLICATION 98
442 * Message sent by datastore client to get random data.
444 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_ZERO_ANONYMITY 99
447 * Message sent by datastore to client providing requested data
448 * (in response to GET or GET_RANDOM request).
450 #define GNUNET_MESSAGE_TYPE_DATASTORE_DATA 100
453 * Message sent by datastore to client signaling end of matching data.
454 * This message will also be sent for "GET_RANDOM", even though
455 * "GET_RANDOM" returns at most one data item.
457 #define GNUNET_MESSAGE_TYPE_DATASTORE_DATA_END 101
460 * Message sent by datastore client to remove data.
462 #define GNUNET_MESSAGE_TYPE_DATASTORE_REMOVE 102
465 * Message sent by datastore client to drop the database.
467 #define GNUNET_MESSAGE_TYPE_DATASTORE_DROP 103
470 * Message sent by datastore client to get data by key.
472 #define GNUNET_MESSAGE_TYPE_DATASTORE_GET_KEY 104
475 /*******************************************************************************
477 ******************************************************************************/
480 * Message sent by fs client to request LOC signature.
482 #define GNUNET_MESSAGE_TYPE_FS_REQUEST_LOC_SIGN 126
485 * Reply sent by fs service with LOC signature.
487 #define GNUNET_MESSAGE_TYPE_FS_REQUEST_LOC_SIGNATURE 127
490 * Message sent by fs client to start indexing.
492 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START 128
495 * Affirmative response to a request for start indexing.
497 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START_OK 129
500 * Response to a request for start indexing that
503 #define GNUNET_MESSAGE_TYPE_FS_INDEX_START_FAILED 130
506 * Request from client for list of indexed files.
508 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_GET 131
511 * Reply to client with an indexed file name.
513 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_ENTRY 132
516 * Reply to client indicating end of list.
518 #define GNUNET_MESSAGE_TYPE_FS_INDEX_LIST_END 133
521 * Request from client to unindex a file.
523 #define GNUNET_MESSAGE_TYPE_FS_UNINDEX 134
526 * Reply to client indicating unindex receipt.
528 #define GNUNET_MESSAGE_TYPE_FS_UNINDEX_OK 135
531 * Client asks FS service to start a (keyword) search.
533 #define GNUNET_MESSAGE_TYPE_FS_START_SEARCH 136
536 * P2P request for content (one FS to another).
538 #define GNUNET_MESSAGE_TYPE_FS_GET 137
541 * P2P response with content or active migration of content. Also
542 * used between the service and clients (in response to
543 * #GNUNET_MESSAGE_TYPE_FS_START_SEARCH).
545 #define GNUNET_MESSAGE_TYPE_FS_PUT 138
548 * Peer asks us to stop migrating content towards it for a while.
550 #define GNUNET_MESSAGE_TYPE_FS_MIGRATION_STOP 139
553 * P2P request for content (one FS to another via a cadet).
555 #define GNUNET_MESSAGE_TYPE_FS_CADET_QUERY 140
558 * P2P answer for content (one FS to another via a cadet).
560 #define GNUNET_MESSAGE_TYPE_FS_CADET_REPLY 141
563 /*******************************************************************************
565 ******************************************************************************/
567 * Client wants to store item in DHT.
569 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_PUT 142
572 * Client wants to lookup item in DHT.
574 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET 143
577 * Client wants to stop search in DHT.
579 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET_STOP 144
582 * Service returns result to client.
584 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_RESULT 145
587 * Peer is storing data in DHT.
589 #define GNUNET_MESSAGE_TYPE_DHT_P2P_PUT 146
592 * Peer tries to find data in DHT.
594 #define GNUNET_MESSAGE_TYPE_DHT_P2P_GET 147
597 * Data is returned to peer from DHT.
599 #define GNUNET_MESSAGE_TYPE_DHT_P2P_RESULT 148
602 * Receive information about transiting GETs
604 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_GET 149
607 * Receive information about transiting GET responses
609 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_GET_RESP 150
612 * Receive information about transiting PUTs
614 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_PUT 151
617 * Receive information about transiting PUT responses (TODO)
619 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_PUT_RESP 152
622 * Request information about transiting messages
624 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_START 153
627 * Stop information about transiting messages
629 #define GNUNET_MESSAGE_TYPE_DHT_MONITOR_STOP 154
632 * Acknowledge receiving PUT request
634 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_PUT_OK 155
637 * Certain results are already known to the client, filter those.
639 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_GET_RESULTS_KNOWN 156
642 * Further X-VINE DHT messages continued from 880
645 /*******************************************************************************
646 * HOSTLIST message types
647 ******************************************************************************/
650 * Hostlist advertisement message
652 #define GNUNET_MESSAGE_TYPE_HOSTLIST_ADVERTISEMENT 160
655 /*******************************************************************************
656 * STATISTICS message types
657 ******************************************************************************/
660 * Set a statistical value.
662 #define GNUNET_MESSAGE_TYPE_STATISTICS_SET 168
665 * Get a statistical value(s).
667 #define GNUNET_MESSAGE_TYPE_STATISTICS_GET 169
670 * Response to a STATISTICS_GET message (with value).
672 #define GNUNET_MESSAGE_TYPE_STATISTICS_VALUE 170
675 * Response to a STATISTICS_GET message (end of value stream).
677 #define GNUNET_MESSAGE_TYPE_STATISTICS_END 171
680 * Watch changes to a statistical value. Message format is the same
681 * as for GET, except that the subsystem and entry name must be given.
683 #define GNUNET_MESSAGE_TYPE_STATISTICS_WATCH 172
686 * Changes to a watched value.
688 #define GNUNET_MESSAGE_TYPE_STATISTICS_WATCH_VALUE 173
691 * Client is done sending service requests and will now disconnect.
693 #define GNUNET_MESSAGE_TYPE_STATISTICS_DISCONNECT 174
696 * Service confirms disconnect and that it is done processing
697 * all requests from the client.
699 #define GNUNET_MESSAGE_TYPE_STATISTICS_DISCONNECT_CONFIRM 175
701 /*******************************************************************************
703 ******************************************************************************/
706 * Type of messages between the gnunet-vpn-helper and the daemon
708 #define GNUNET_MESSAGE_TYPE_VPN_HELPER 185
711 * Type of messages containing an ICMP packet for a service.
713 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_SERVICE 190
716 * Type of messages containing an ICMP packet for the Internet.
718 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_INTERNET 191
721 * Type of messages containing an ICMP packet for the VPN
723 #define GNUNET_MESSAGE_TYPE_VPN_ICMP_TO_VPN 192
726 * Type of messages containing an DNS request for a DNS exit service.
728 #define GNUNET_MESSAGE_TYPE_VPN_DNS_TO_INTERNET 193
731 * Type of messages containing an DNS reply from a DNS exit service.
733 #define GNUNET_MESSAGE_TYPE_VPN_DNS_FROM_INTERNET 194
736 * Type of messages containing an TCP packet for a service.
738 #define GNUNET_MESSAGE_TYPE_VPN_TCP_TO_SERVICE_START 195
741 * Type of messages containing an TCP packet for the Internet.
743 #define GNUNET_MESSAGE_TYPE_VPN_TCP_TO_INTERNET_START 196
746 * Type of messages containing an TCP packet of an established connection.
748 #define GNUNET_MESSAGE_TYPE_VPN_TCP_DATA_TO_EXIT 197
751 * Type of messages containing an TCP packet of an established connection.
753 #define GNUNET_MESSAGE_TYPE_VPN_TCP_DATA_TO_VPN 198
756 * Type of messages containing an UDP packet for a service.
758 #define GNUNET_MESSAGE_TYPE_VPN_UDP_TO_SERVICE 199
761 * Type of messages containing an UDP packet for the Internet.
763 #define GNUNET_MESSAGE_TYPE_VPN_UDP_TO_INTERNET 200
766 * Type of messages containing an UDP packet from a remote host
768 #define GNUNET_MESSAGE_TYPE_VPN_UDP_REPLY 201
772 * Client asks VPN service to setup an IP to redirect traffic
773 * via an exit node to some global IP address.
775 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_REDIRECT_TO_IP 202
778 * Client asks VPN service to setup an IP to redirect traffic
779 * to some peer offering a service.
781 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_REDIRECT_TO_SERVICE 203
784 * VPN service responds to client with an IP to use for the
785 * requested redirection.
787 #define GNUNET_MESSAGE_TYPE_VPN_CLIENT_USE_IP 204
790 /*******************************************************************************
791 * VPN-DNS message types
792 ******************************************************************************/
796 * Initial message from client to DNS service for registration.
798 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_INIT 211
801 * Type of messages between the gnunet-helper-dns and the service
803 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_REQUEST 212
806 * Type of messages between the gnunet-helper-dns and the service
808 #define GNUNET_MESSAGE_TYPE_DNS_CLIENT_RESPONSE 213
811 * Type of messages between the gnunet-helper-dns and the service
813 #define GNUNET_MESSAGE_TYPE_DNS_HELPER 214
817 /*******************************************************************************
818 * CHAT message types START
819 ******************************************************************************/
822 * Message sent from client to join a chat room.
824 #define GNUNET_MESSAGE_TYPE_CHAT_JOIN_REQUEST 300
827 * Message sent to client to indicate joining of another room member.
829 #define GNUNET_MESSAGE_TYPE_CHAT_JOIN_NOTIFICATION 301
832 * Message sent to client to indicate leaving of another room member.
834 #define GNUNET_MESSAGE_TYPE_CHAT_LEAVE_NOTIFICATION 302
837 * Notification sent by service to client indicating that we've received a chat
840 #define GNUNET_MESSAGE_TYPE_CHAT_MESSAGE_NOTIFICATION 303
843 * Request sent by client to transmit a chat message to another room members.
845 #define GNUNET_MESSAGE_TYPE_CHAT_TRANSMIT_REQUEST 304
848 * Receipt sent from a message receiver to the service to confirm delivery of
851 #define GNUNET_MESSAGE_TYPE_CHAT_CONFIRMATION_RECEIPT 305
854 * Notification sent from the service to the original sender
855 * to acknowledge delivery of a chat message.
857 #define GNUNET_MESSAGE_TYPE_CHAT_CONFIRMATION_NOTIFICATION 306
860 * P2P message sent to indicate joining of another room member.
862 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_JOIN_NOTIFICATION 307
865 * P2P message sent to indicate leaving of another room member.
867 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_LEAVE_NOTIFICATION 308
870 * P2P message sent to a newly connected peer to request its known clients in
871 * order to synchronize room members.
873 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_SYNC_REQUEST 309
876 * Notification sent from one peer to another to indicate that we have received
879 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_MESSAGE_NOTIFICATION 310
882 * P2P receipt confirming delivery of a chat message.
884 #define GNUNET_MESSAGE_TYPE_CHAT_P2P_CONFIRMATION_RECEIPT 311
887 /*******************************************************************************
888 * NSE (network size estimation) message types
889 ******************************************************************************/
892 * client->service message indicating start
894 #define GNUNET_MESSAGE_TYPE_NSE_START 321
897 * P2P message sent from nearest peer
899 #define GNUNET_MESSAGE_TYPE_NSE_P2P_FLOOD 322
902 * service->client message indicating
904 #define GNUNET_MESSAGE_TYPE_NSE_ESTIMATE 323
907 /*******************************************************************************
908 * PEERINFO message types
909 ******************************************************************************/
912 * Request update and listing of a peer.
914 #define GNUNET_MESSAGE_TYPE_PEERINFO_GET 330
917 * Request update and listing of all peers.
919 #define GNUNET_MESSAGE_TYPE_PEERINFO_GET_ALL 331
922 * Information about one of the peers.
924 #define GNUNET_MESSAGE_TYPE_PEERINFO_INFO 332
927 * End of information about other peers.
929 #define GNUNET_MESSAGE_TYPE_PEERINFO_INFO_END 333
932 * Start notifying this client about all changes to
933 * the known peers until it disconnects.
935 #define GNUNET_MESSAGE_TYPE_PEERINFO_NOTIFY 334
937 /*******************************************************************************
939 ******************************************************************************/
942 * Type of the 'struct ClientStartMessage' sent by clients to ATS to
943 * identify the type of the client.
945 #define GNUNET_MESSAGE_TYPE_ATS_START 340
948 * Type of the 'struct RequestAddressMessage' sent by clients to ATS
949 * to request an address to help connect.
951 #define GNUNET_MESSAGE_TYPE_ATS_REQUEST_ADDRESS 341
954 * Type of the 'struct RequestAddressMessage' sent by clients to ATS
955 * to request an address to help connect.
957 #define GNUNET_MESSAGE_TYPE_ATS_REQUEST_ADDRESS_CANCEL 342
960 * Type of the 'struct AddressUpdateMessage' sent by clients to ATS
961 * to inform ATS about performance changes.
963 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_UPDATE 343
966 * Type of the 'struct AddressDestroyedMessage' sent by clients to ATS
967 * to inform ATS about an address being unavailable.
969 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_DESTROYED 344
972 * Type of the 'struct AddressSuggestionMessage' sent by ATS to clients
973 * to suggest switching to a different address.
975 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_SUGGESTION 345
978 * Type of the 'struct PeerInformationMessage' sent by ATS to clients
979 * to inform about QoS for a particular connection.
981 #define GNUNET_MESSAGE_TYPE_ATS_PEER_INFORMATION 346
984 * Type of the 'struct ReservationRequestMessage' sent by clients to ATS
985 * to ask for inbound bandwidth reservations.
987 #define GNUNET_MESSAGE_TYPE_ATS_RESERVATION_REQUEST 347
990 * Type of the 'struct ReservationResultMessage' sent by ATS to clients
991 * in response to a reservation request.
993 #define GNUNET_MESSAGE_TYPE_ATS_RESERVATION_RESULT 348
996 * Type of the 'struct ChangePreferenceMessage' sent by clients to ATS
997 * to ask for allocation preference changes.
999 #define GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_CHANGE 349
1002 * Type of the 'struct SessionReleaseMessage' sent by ATS to client
1003 * to confirm that a session ID was destroyed.
1005 #define GNUNET_MESSAGE_TYPE_ATS_SESSION_RELEASE 350
1008 * Type of the 'struct AddressUpdateMessage' sent by client to ATS
1009 * to add a new address
1011 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESS_ADD 353
1014 * Type of the 'struct AddressListRequestMessage' sent by client to ATS
1015 * to request information about addresses
1017 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESSLIST_REQUEST 354
1020 * Type of the 'struct AddressListResponseMessage' sent by ATS to client
1021 * with information about addresses
1023 #define GNUNET_MESSAGE_TYPE_ATS_ADDRESSLIST_RESPONSE 355
1026 * Type of the 'struct ChangePreferenceMessage' sent by clients to ATS
1027 * to ask for allocation preference changes.
1029 #define GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_FEEDBACK 356
1032 /*******************************************************************************
1033 * TRANSPORT message types
1034 ******************************************************************************/
1037 * Message from the core saying that the transport
1038 * server should start giving it messages. This
1039 * should automatically trigger the transmission of
1042 #define GNUNET_MESSAGE_TYPE_TRANSPORT_START 360
1045 * Message from TRANSPORT notifying about a
1046 * client that connected to us.
1048 #define GNUNET_MESSAGE_TYPE_TRANSPORT_CONNECT 361
1051 * Message from TRANSPORT notifying about a
1052 * client that disconnected from us.
1054 #define GNUNET_MESSAGE_TYPE_TRANSPORT_DISCONNECT 362
1057 * Request to TRANSPORT to transmit a message.
1059 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SEND 363
1062 * Confirmation from TRANSPORT that message for transmission has been
1063 * queued (and that the next message to this peer can now be passed to
1064 * the service). Note that this confirmation does NOT imply that the
1065 * message was fully transmitted.
1067 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SEND_OK 364
1070 * Message from TRANSPORT notifying about a
1071 * message that was received.
1073 #define GNUNET_MESSAGE_TYPE_TRANSPORT_RECV 365
1076 * Message telling transport to limit its receive rate.
1078 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SET_QUOTA 366
1081 * Request to look addresses of peers in server.
1083 #define GNUNET_MESSAGE_TYPE_TRANSPORT_ADDRESS_TO_STRING 367
1086 * Response to the address lookup request.
1088 #define GNUNET_MESSAGE_TYPE_TRANSPORT_ADDRESS_TO_STRING_REPLY 368
1091 * Register a client that wants to do blacklisting.
1093 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_INIT 369
1096 * Query to a blacklisting client (is this peer blacklisted)?
1098 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_QUERY 370
1101 * Reply from blacklisting client (answer to blacklist query).
1103 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BLACKLIST_REPLY 371
1106 * Transport PING message
1108 #define GNUNET_MESSAGE_TYPE_TRANSPORT_PING 372
1111 * Transport PONG message
1113 #define GNUNET_MESSAGE_TYPE_TRANSPORT_PONG 373
1116 * Transport SYN message exchanged between transport services to
1117 * indicate that a session should be marked as 'connected'.
1119 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_SYN 375
1122 * Transport SYN_ACK message exchanged between transport services to
1123 * indicate that a SYN message was accepted
1125 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_SYN_ACK 376
1128 * Transport ACK message exchanged between transport services to
1129 * indicate that a SYN_ACK message was accepted
1131 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_ACK 377
1134 * Transport DISCONNECT message exchanged between transport services to
1135 * indicate that a connection should be dropped.
1137 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_DISCONNECT 378
1140 * Message exchanged between transport services to
1141 * indicate that the sender should limit its transmission
1142 * rate to the indicated quota.
1144 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_QUOTA 379
1147 * Request to monitor addresses used by a peer or all peers.
1149 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_REQUEST 380
1152 * Message send by a peer to notify the other to keep the session alive
1153 * and measure latency in a regular interval
1155 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE 381
1158 * Response to a #GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE message to
1159 * measure latency in a regular interval
1161 #define GNUNET_MESSAGE_TYPE_TRANSPORT_SESSION_KEEPALIVE_RESPONSE 382
1164 * Response to #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_REQUEST
1165 * request to iterate over all known addresses.
1167 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE 383
1170 * Message send by a peer to notify the other to keep the session alive.
1172 #define GNUNET_MESSAGE_TYPE_TRANSPORT_BROADCAST_BEACON 384
1175 * Message containing traffic metrics for transport service
1177 #define GNUNET_MESSAGE_TYPE_TRANSPORT_TRAFFIC_METRIC 385
1180 * Request to start monitoring the connection state of plugins.
1182 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_START 388
1185 * Monitoring event about the connection state of plugins,
1186 * generated in response to a subscription initiated via
1187 * #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_START
1189 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_EVENT 389
1192 * Monitoring event notifying client that the initial iteration
1193 * is now completed and we are in sync with the state of the subsystem.
1195 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PLUGIN_SYNC 390
1198 * Response to #GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE_END
1199 * terminating list of replies.
1201 #define GNUNET_MESSAGE_TYPE_TRANSPORT_MONITOR_PEER_RESPONSE_END 391
1204 /*******************************************************************************
1205 * FS-PUBLISH-HELPER IPC Messages
1206 ******************************************************************************/
1209 * Progress information from the helper: found a file
1211 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_PROGRESS_FILE 420
1214 * Progress information from the helper: found a directory
1216 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_PROGRESS_DIRECTORY 421
1219 * Error signal from the helper.
1221 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_ERROR 422
1224 * Signal that helper skipped a file.
1226 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_SKIP_FILE 423
1229 * Signal that helper is done scanning the directory tree.
1231 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_COUNTING_DONE 424
1234 * Extracted meta data from the helper.
1236 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_META_DATA 425
1239 * Signal that helper is done.
1241 #define GNUNET_MESSAGE_TYPE_FS_PUBLISH_HELPER_FINISHED 426
1244 /*******************************************************************************
1245 * NAMECACHE message types
1246 ******************************************************************************/
1249 * Client to service: lookup block
1251 #define GNUNET_MESSAGE_TYPE_NAMECACHE_LOOKUP_BLOCK 431
1254 * Service to client: result of block lookup
1256 #define GNUNET_MESSAGE_TYPE_NAMECACHE_LOOKUP_BLOCK_RESPONSE 432
1259 * Client to service: cache a block
1261 #define GNUNET_MESSAGE_TYPE_NAMECACHE_BLOCK_CACHE 433
1264 * Service to client: result of block cache request
1266 #define GNUNET_MESSAGE_TYPE_NAMECACHE_BLOCK_CACHE_RESPONSE 434
1268 /*******************************************************************************
1269 * NAMESTORE message types
1270 ******************************************************************************/
1273 * Client to service: store records (as authority)
1275 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_STORE 435
1278 * Service to client: result of store operation.
1280 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_STORE_RESPONSE 436
1283 * Client to service: lookup label
1285 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_LOOKUP 437
1288 * Service to client: lookup label
1290 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_LOOKUP_RESPONSE 438
1293 * Client to service: "reverse" lookup for zone name based on zone key
1295 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_TO_NAME 439
1298 * Service to client: result of zone-to-name lookup.
1300 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_TO_NAME_RESPONSE 440
1303 * Client to service: start monitoring (yields sequence of
1304 * "ZONE_ITERATION_RESPONSES" --- forever).
1306 #define GNUNET_MESSAGE_TYPE_NAMESTORE_MONITOR_START 441
1309 * Service to client: you're now in sync.
1311 #define GNUNET_MESSAGE_TYPE_NAMESTORE_MONITOR_SYNC 442
1314 * Service to client: here is a (plaintext) record you requested.
1316 #define GNUNET_MESSAGE_TYPE_NAMESTORE_RECORD_RESULT 443
1319 * Client to service: please start iteration; receives
1320 * "GNUNET_MESSAGE_TYPE_NAMESTORE_LOOKUP_NAME_RESPONSE" messages in return.
1322 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_START 445
1325 * Client to service: next record in iteration please.
1327 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_NEXT 447
1330 * Client to service: stop iterating.
1332 #define GNUNET_MESSAGE_TYPE_NAMESTORE_ZONE_ITERATION_STOP 448
1334 /*******************************************************************************
1335 * LOCKMANAGER message types
1336 ******************************************************************************/
1339 * Message to acquire Lock
1341 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_ACQUIRE 450
1344 * Message to release lock
1346 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_RELEASE 451
1349 * SUCESS reply from lockmanager
1351 #define GNUNET_MESSAGE_TYPE_LOCKMANAGER_SUCCESS 452
1353 /*******************************************************************************
1354 * TESTBED message types
1355 ******************************************************************************/
1358 * Initial message from a client to a testing control service
1360 #define GNUNET_MESSAGE_TYPE_TESTBED_INIT 460
1363 * Message to add host
1365 #define GNUNET_MESSAGE_TYPE_TESTBED_ADD_HOST 461
1368 * Message to signal that a add host succeeded
1370 #define GNUNET_MESSAGE_TYPE_TESTBED_ADD_HOST_SUCCESS 462
1373 * Message to link delegated controller to slave controller
1375 #define GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS 463
1378 * Message to create a peer at a host
1380 #define GNUNET_MESSAGE_TYPE_TESTBED_CREATE_PEER 464
1383 * Message to reconfigure a peer
1385 #define GNUNET_MESSAGE_TYPE_TESTBED_RECONFIGURE_PEER 465
1388 * Message to start a peer at a host
1390 #define GNUNET_MESSAGE_TYPE_TESTBED_START_PEER 466
1393 * Message to stop a peer at a host
1395 #define GNUNET_MESSAGE_TYPE_TESTBED_STOP_PEER 467
1398 * Message to destroy a peer
1400 #define GNUNET_MESSAGE_TYPE_TESTBED_DESTROY_PEER 468
1403 * Configure underlay link message
1405 #define GNUNET_MESSAGE_TYPE_TESTBED_CONFIGURE_UNDERLAY_LINK 469
1408 * Message to connect peers in a overlay
1410 #define GNUNET_MESSAGE_TYPE_TESTBED_OVERLAY_CONNECT 470
1413 * Message for peer events
1415 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_EVENT 471
1418 * Message for peer connect events
1420 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_CONNECT_EVENT 472
1423 * Message for operation events
1425 #define GNUNET_MESSAGE_TYPE_TESTBED_OPERATION_FAIL_EVENT 473
1428 * Message to signal successful peer creation
1430 #define GNUNET_MESSAGE_TYPE_TESTBED_CREATE_PEER_SUCCESS 474
1433 * Message to signal a generic operation has been successful
1435 #define GNUNET_MESSAGE_TYPE_TESTBED_GENERIC_OPERATION_SUCCESS 475
1438 * Message to get a peer's information
1440 #define GNUNET_MESSAGE_TYPE_TESTBED_GET_PEER_INFORMATION 476
1443 * Message containing the peer's information
1445 #define GNUNET_MESSAGE_TYPE_TESTBED_PEER_INFORMATION 477
1448 * Message to request a controller to make one of its peer to connect to another
1449 * peer using the contained HELLO
1451 #define GNUNET_MESSAGE_TYPE_TESTBED_REMOTE_OVERLAY_CONNECT 478
1454 * Message to request configuration of a slave controller
1456 #define GNUNET_MESSAGE_TYPE_TESTBED_GET_SLAVE_CONFIGURATION 479
1459 * Message which contains the configuration of slave controller
1461 #define GNUNET_MESSAGE_TYPE_TESTBED_SLAVE_CONFIGURATION 480
1464 * Message to signal the result of #GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS request
1466 #define GNUNET_MESSAGE_TYPE_TESTBED_LINK_CONTROLLERS_RESULT 481
1469 * A controller receiving this message floods it to its directly-connected
1470 * sub-controllers and then stops and destroys all peers
1472 #define GNUNET_MESSAGE_TYPE_TESTBED_SHUTDOWN_PEERS 482
1475 * Message to start/stop a service of a peer
1477 #define GNUNET_MESSAGE_TYPE_TESTBED_MANAGE_PEER_SERVICE 483
1480 * Message to initialise a barrier. Messages of these type are flooded to all
1483 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_INIT 484
1486 * Message to cancel a barrier. This message is flooded to all sub-controllers
1488 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_CANCEL 485
1491 * Message for signalling status of a barrier
1493 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_STATUS 486
1496 * Message sent by a peer when it has reached a barrier and is waiting for it to
1499 #define GNUNET_MESSAGE_TYPE_TESTBED_BARRIER_WAIT 487
1502 * Not really a message, but for careful checks on the testbed messages; Should
1503 * always be the maximum and never be used to send messages with this type
1505 #define GNUNET_MESSAGE_TYPE_TESTBED_MAX 488
1508 * The initialization message towards gnunet-testbed-helper
1510 #define GNUNET_MESSAGE_TYPE_TESTBED_HELPER_INIT 495
1513 * The reply message from gnunet-testbed-helper
1515 #define GNUNET_MESSAGE_TYPE_TESTBED_HELPER_REPLY 496
1518 /******************************************************************************
1520 *****************************************************************************/
1523 * Client would like to resolve a name.
1525 #define GNUNET_MESSAGE_TYPE_GNS_LOOKUP 500
1528 * Service response to name resolution request from client.
1530 #define GNUNET_MESSAGE_TYPE_GNS_LOOKUP_RESULT 501
1535 #define GNUNET_MESSAGE_TYPE_GNS_REVERSE_LOOKUP 503
1538 * Response to reverse lookup
1540 #define GNUNET_MESSAGE_TYPE_GNS_REVERSE_LOOKUP_RESULT 504
1543 /*******************************************************************************
1544 * CONSENSUS message types
1545 ******************************************************************************/
1548 * Join a consensus session. Sent by client to service as first message.
1550 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_JOIN 520
1553 * Insert an element. Sent by client to service.
1555 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_INSERT 521
1558 * Begin accepting new elements from other participants.
1559 * Sent by client to service.
1561 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_BEGIN 522
1564 * Sent by service when a new element is added.
1566 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_RECEIVED_ELEMENT 523
1569 * Sent by client to service in order to start the consensus conclusion.
1571 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_CONCLUDE 524
1574 * Sent by service to client in order to signal a completed consensus conclusion.
1575 * Last message sent in a consensus session.
1577 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_CONCLUDE_DONE 525
1580 /* message types 526-539 reserved for consensus client/service messages */
1584 * Sent by client to service, telling whether a received element should
1585 * be accepted and propagated further or not.
1587 #define GNUNET_MESSAGE_TYPE_CONSENSUS_CLIENT_ACK 540
1592 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_DELTA_ESTIMATE 541
1595 * IBF containing all elements of a peer.
1597 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_DIFFERENCE_DIGEST 542
1600 * One or more elements that are sent from peer to peer.
1602 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS 543
1605 * Elements, and requests for further elements
1607 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS_REQUEST 544
1610 * Elements that a peer reports to be missing at the remote peer.
1612 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ELEMENTS_REPORT 545
1615 * Initialization message for consensus p2p communication.
1617 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_HELLO 546
1620 * Report that the peer is synced with the partner after successfuly decoding the invertible bloom filter.
1622 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_SYNCED 547
1625 * Interaction os over, got synched and reported all elements
1627 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_FIN 548
1630 * Abort a round, don't send requested elements anymore
1632 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ABORT 548
1635 * Abort a round, don't send requested elements anymore
1637 #define GNUNET_MESSAGE_TYPE_CONSENSUS_P2P_ROUND_CONTEXT 547
1640 /*******************************************************************************
1642 ******************************************************************************/
1645 * Demand the whole element from the other
1646 * peer, given only the hash code.
1648 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_DEMAND 566
1651 * Tell the other peer to send us a list of
1652 * hashes that match an IBF key.
1654 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_INQUIRY 567
1657 * Tell the other peer which hashes match a
1660 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_OFFER 568
1663 * Reject a set request.
1665 #define GNUNET_MESSAGE_TYPE_SET_REJECT 569
1668 * Cancel a set operation
1670 #define GNUNET_MESSAGE_TYPE_SET_CANCEL 570
1673 * Acknowledge result from iteration
1675 #define GNUNET_MESSAGE_TYPE_SET_ITER_ACK 571
1678 * Create an empty set
1680 #define GNUNET_MESSAGE_TYPE_SET_RESULT 572
1683 * Add element to set
1685 #define GNUNET_MESSAGE_TYPE_SET_ADD 573
1688 * Remove element from set
1690 #define GNUNET_MESSAGE_TYPE_SET_REMOVE 574
1693 * Listen for operation requests
1695 #define GNUNET_MESSAGE_TYPE_SET_LISTEN 575
1698 * Accept a set request
1700 #define GNUNET_MESSAGE_TYPE_SET_ACCEPT 576
1703 * Evaluate a set operation
1705 #define GNUNET_MESSAGE_TYPE_SET_EVALUATE 577
1708 * Start a set operation with the given set
1710 #define GNUNET_MESSAGE_TYPE_SET_CONCLUDE 578
1713 * Notify the client of a request from a remote peer
1715 #define GNUNET_MESSAGE_TYPE_SET_REQUEST 579
1718 * Create a new local set
1720 #define GNUNET_MESSAGE_TYPE_SET_CREATE 580
1723 * Request a set operation from a remote peer.
1725 #define GNUNET_MESSAGE_TYPE_SET_P2P_OPERATION_REQUEST 581
1730 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_SE 582
1733 * Invertible bloom filter.
1735 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_IBF 583
1738 * Actual set elements.
1740 #define GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENTS 584
1743 * Requests for the elements with the given hashes.
1745 #define GNUNET_MESSAGE_TYPE_SET_P2P_ELEMENT_REQUESTS 585
1748 * Set operation is done.
1750 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_DONE 586
1753 * Start iteration over set elements.
1755 #define GNUNET_MESSAGE_TYPE_SET_ITER_REQUEST 587
1758 * Element result for the iterating client.
1760 #define GNUNET_MESSAGE_TYPE_SET_ITER_ELEMENT 588
1763 * Iteration end marker for the client.
1765 #define GNUNET_MESSAGE_TYPE_SET_ITER_DONE 589
1768 * Compressed strata estimator.
1770 #define GNUNET_MESSAGE_TYPE_SET_UNION_P2P_SEC 590
1773 * Information about the element count for intersection
1775 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_ELEMENT_INFO 591
1778 * Bloom filter message for intersection exchange started by Bob.
1780 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_BF 592
1783 * Intersection operation is done.
1785 #define GNUNET_MESSAGE_TYPE_SET_INTERSECTION_P2P_DONE 593
1788 * Ask the set service to prepare a copy of a set.
1790 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_PREPARE 594
1793 * Give the client an ID for connecting to the set's copy.
1795 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_RESPONSE 595
1798 * Sent by the client to the server to connect to an existing,
1799 * lazily copied set.
1801 #define GNUNET_MESSAGE_TYPE_SET_COPY_LAZY_CONNECT 596
1804 /*******************************************************************************
1805 * TESTBED LOGGER message types
1806 ******************************************************************************/
1809 * Message for TESTBED LOGGER
1811 #define GNUNET_MESSAGE_TYPE_TESTBED_LOGGER_MSG 600
1814 * Message for TESTBED LOGGER acknowledgement
1816 #define GNUNET_MESSAGE_TYPE_TESTBED_LOGGER_ACK 601
1821 * Advertise regex capability.
1823 #define GNUNET_MESSAGE_TYPE_REGEX_ANNOUNCE 620
1826 * Search for peer with matching capability.
1828 #define GNUNET_MESSAGE_TYPE_REGEX_SEARCH 621
1831 * Result in response to regex search.
1833 #define GNUNET_MESSAGE_TYPE_REGEX_RESULT 622
1835 /*******************************************************************************
1836 * IDENTITY message types
1837 ******************************************************************************/
1840 * First message send from identity client to service (to subscribe to
1843 #define GNUNET_MESSAGE_TYPE_IDENTITY_START 624
1846 * Generic response from identity service with success and/or error message.
1848 #define GNUNET_MESSAGE_TYPE_IDENTITY_RESULT_CODE 625
1851 * Update about identity status from service to clients.
1853 #define GNUNET_MESSAGE_TYPE_IDENTITY_UPDATE 626
1856 * Client requests to know default identity for a subsystem.
1858 #define GNUNET_MESSAGE_TYPE_IDENTITY_GET_DEFAULT 627
1861 * Client sets default identity; or service informs about default identity.
1863 #define GNUNET_MESSAGE_TYPE_IDENTITY_SET_DEFAULT 628
1866 * Create new identity (client->service).
1868 #define GNUNET_MESSAGE_TYPE_IDENTITY_CREATE 629
1871 * Rename existing identity (client->service).
1873 #define GNUNET_MESSAGE_TYPE_IDENTITY_RENAME 630
1876 * Delete identity (client->service).
1878 #define GNUNET_MESSAGE_TYPE_IDENTITY_DELETE 631
1881 /*******************************************************************************
1882 * REVOCATION message types
1883 ******************************************************************************/
1886 * Client to service: was this key revoked?
1888 #define GNUNET_MESSAGE_TYPE_REVOCATION_QUERY 636
1891 * Service to client: answer if key was revoked!
1893 #define GNUNET_MESSAGE_TYPE_REVOCATION_QUERY_RESPONSE 637
1896 * Client to service OR peer-to-peer: revoke this key!
1898 #define GNUNET_MESSAGE_TYPE_REVOCATION_REVOKE 638
1901 * Service to client: revocation confirmed
1903 #define GNUNET_MESSAGE_TYPE_REVOCATION_REVOKE_RESPONSE 639
1906 /*******************************************************************************
1907 * SCALARPRODUCT message types
1908 ******************************************************************************/
1913 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_TO_ALICE 640
1918 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_TO_BOB 641
1921 * Client -> Alice multipart
1923 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_MULTIPART_ALICE 642
1926 * Client -> Bob multipart
1928 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_CLIENT_MULTIPART_BOB 643
1931 * Alice -> Bob session initialization
1933 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_SESSION_INITIALIZATION 644
1936 * Alice -> Bob SP crypto-data (after intersection)
1938 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ALICE_CRYPTODATA 645
1941 * Bob -> Alice SP crypto-data
1943 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_BOB_CRYPTODATA 647
1946 * Bob -> Alice SP crypto-data multipart
1948 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_BOB_CRYPTODATA_MULTIPART 648
1951 * Alice/Bob -> Client Result
1953 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_RESULT 649
1956 * Alice -> Bob ECC session initialization
1958 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_SESSION_INITIALIZATION 650
1961 * Alice -> Bob ECC crypto data
1963 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_ALICE_CRYPTODATA 651
1966 * Bob -> Alice ECC crypto data
1968 #define GNUNET_MESSAGE_TYPE_SCALARPRODUCT_ECC_BOB_CRYPTODATA 652
1974 /*******************************************************************************
1975 * PSYCSTORE message types
1976 ******************************************************************************/
1979 * Store a membership event.
1981 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MEMBERSHIP_STORE 660
1984 * Test for membership of a member at a particular point in time.
1986 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MEMBERSHIP_TEST 661
1988 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_FRAGMENT_STORE 662
1990 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_FRAGMENT_GET 663
1992 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MESSAGE_GET 664
1994 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_MESSAGE_GET_FRAGMENT 665
1996 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_COUNTERS_GET 666
2000 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_MODIFY 668
2002 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_SYNC 669
2004 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_RESET 670
2006 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_HASH_UPDATE 671
2008 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_GET 672
2010 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_STATE_GET_PREFIX 673
2013 * Generic response from PSYCstore service with success and/or error message.
2015 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_CODE 674
2017 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_FRAGMENT 675
2019 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_COUNTERS 676
2021 #define GNUNET_MESSAGE_TYPE_PSYCSTORE_RESULT_STATE 677
2024 /*******************************************************************************
2025 * PSYC message types
2026 ******************************************************************************/
2034 /** S->C: result of an operation */
2035 #define GNUNET_MESSAGE_TYPE_PSYC_RESULT_CODE 680
2037 /** C->S: request to start a channel as a master */
2038 #define GNUNET_MESSAGE_TYPE_PSYC_MASTER_START 681
2040 /** S->C: master start acknowledgement */
2041 #define GNUNET_MESSAGE_TYPE_PSYC_MASTER_START_ACK 682
2043 /** C->S: request to join a channel as a slave */
2044 #define GNUNET_MESSAGE_TYPE_PSYC_SLAVE_JOIN 683
2046 /** S->C: slave join acknowledgement */
2047 #define GNUNET_MESSAGE_TYPE_PSYC_SLAVE_JOIN_ACK 684
2051 /** M->S->C: incoming join request from multicast */
2052 #define GNUNET_MESSAGE_TYPE_PSYC_JOIN_REQUEST 687
2054 /** C->S->M: decision about a join request */
2055 #define GNUNET_MESSAGE_TYPE_PSYC_JOIN_DECISION 688
2058 /** C->S: request to add/remove channel slave in the membership database. */
2059 #define GNUNET_MESSAGE_TYPE_PSYC_CHANNEL_MEMBERSHIP_STORE 689
2063 /** S<--C: PSYC message which contains one or more message parts. */
2064 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE 691
2066 /** M<->S<->C: PSYC message which contains a header and one or more message parts. */
2067 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_HEADER 692 // FIXME: start using this where appropriate
2069 /** Message part: method */
2070 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_METHOD 693
2072 /** Message part: modifier */
2073 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_MODIFIER 694
2075 /** Message part: modifier continuation */
2076 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_MOD_CONT 695
2078 /** Message part: data */
2079 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_DATA 696
2081 /** Message part: end of message */
2082 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_END 697
2084 /** Message part: message cancelled */
2085 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_CANCEL 698
2087 /** S->C: message acknowledgement */
2088 #define GNUNET_MESSAGE_TYPE_PSYC_MESSAGE_ACK 699
2092 /** C->S: request channel history replay from PSYCstore. */
2093 #define GNUNET_MESSAGE_TYPE_PSYC_HISTORY_REPLAY 701
2095 /** S->C: result for a channel history request */
2096 #define GNUNET_MESSAGE_TYPE_PSYC_HISTORY_RESULT 702
2099 /** C->S: request best matching state variable from PSYCstore. */
2100 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_GET 703
2102 /** C->S: request state variables with a given prefix from PSYCstore. */
2103 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_GET_PREFIX 704
2105 /** S->C: result for a state request. */
2106 #define GNUNET_MESSAGE_TYPE_PSYC_STATE_RESULT 705
2109 /*******************************************************************************
2110 * CONVERSATION message types
2111 ******************************************************************************/
2114 * Message to transmit the audio between helper and speaker/microphone library.
2116 #define GNUNET_MESSAGE_TYPE_CONVERSATION_AUDIO 730
2119 * Client -> Server message to register a phone.
2121 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_REGISTER 731
2124 * Client -> Server message to reject/hangup a call
2126 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_PICK_UP 732
2129 * Client -> Server message to reject/hangup a call
2131 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_HANG_UP 733
2134 * Client <- Server message to indicate a ringing phone
2136 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_CALL 734
2139 * Client <- Server message to indicate a ringing phone
2141 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_RING 735
2144 * Client <-> Server message to suspend connection.
2146 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_SUSPEND 736
2149 * Client <-> Server message to resume connection.
2151 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_RESUME 737
2154 * Service -> Client message to notify that phone was picked up.
2156 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_PHONE_PICKED_UP 738
2159 * Client <-> Server message to send audio data.
2161 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CS_AUDIO 739
2164 * Cadet: call initiation
2166 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_RING 740
2169 * Cadet: hang up / refuse call
2171 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_HANG_UP 741
2174 * Cadet: pick up phone (establish audio channel)
2176 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_PICK_UP 742
2179 * Cadet: phone suspended.
2181 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_SUSPEND 743
2184 * Cadet: phone resumed.
2186 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_PHONE_RESUME 744
2191 #define GNUNET_MESSAGE_TYPE_CONVERSATION_CADET_AUDIO 745
2194 /*******************************************************************************
2195 * MULTICAST message types
2196 ******************************************************************************/
2205 * C->S: Start the origin.
2207 #define GNUNET_MESSAGE_TYPE_MULTICAST_ORIGIN_START 750
2210 * C->S: Join group as a member.
2212 #define GNUNET_MESSAGE_TYPE_MULTICAST_MEMBER_JOIN 751
2215 * C<--S<->T: A peer wants to join the group.
2217 * Unicast message to the origin or another group member.
2219 #define GNUNET_MESSAGE_TYPE_MULTICAST_JOIN_REQUEST 752
2222 * C<->S<->T: Response to a join request.
2224 * Unicast message from a group member to the peer wanting to join.
2226 #define GNUNET_MESSAGE_TYPE_MULTICAST_JOIN_DECISION 753
2229 * A peer wants to part the group.
2231 #define GNUNET_MESSAGE_TYPE_MULTICAST_PART_REQUEST 754
2234 * Acknowledgement sent in response to a part request.
2236 * Unicast message from a group member to the peer wanting to part.
2238 #define GNUNET_MESSAGE_TYPE_MULTICAST_PART_ACK 755
2243 #define GNUNET_MESSAGE_TYPE_MULTICAST_GROUP_END 756
2246 * C<->S<->T: Multicast message from the origin to all members.
2248 #define GNUNET_MESSAGE_TYPE_MULTICAST_MESSAGE 757
2251 * C<->S<->T: Unicast request from a group member to the origin.
2253 #define GNUNET_MESSAGE_TYPE_MULTICAST_REQUEST 758
2256 * C->S: Acknowledgement of a message or request fragment for the client.
2258 #define GNUNET_MESSAGE_TYPE_MULTICAST_FRAGMENT_ACK 759
2261 * C<->S<->T: Replay request from a group member to another member.
2263 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_REQUEST 760
2266 * C<->S<->T: Replay response from a group member to another member.
2268 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_RESPONSE 761
2271 * C<->S: End of replay response.
2273 #define GNUNET_MESSAGE_TYPE_MULTICAST_REPLAY_RESPONSE_END 762
2277 /*******************************************************************************
2278 * SECRETSHARING message types
2279 ******************************************************************************/
2283 * Establish a new session.
2285 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_GENERATE 780
2288 * Request the decryption of a ciphertext.
2290 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_DECRYPT 781
2293 * The service succeeded in decrypting a ciphertext.
2295 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_DECRYPT_DONE 782
2298 * The cryptosystem has been established.
2299 * Contains the peer's share.
2301 #define GNUNET_MESSAGE_TYPE_SECRETSHARING_CLIENT_SECRET_READY 783
2304 /*******************************************************************************
2305 * PEERSTORE message types
2306 ******************************************************************************/
2309 * Store request message
2311 #define GNUNET_MESSAGE_TYPE_PEERSTORE_STORE 820
2316 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE 821
2319 * Iteration record message
2321 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE_RECORD 822
2324 * Iteration end message
2326 #define GNUNET_MESSAGE_TYPE_PEERSTORE_ITERATE_END 823
2331 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH 824
2336 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH_RECORD 825
2339 * Watch cancel request
2341 #define GNUNET_MESSAGE_TYPE_PEERSTORE_WATCH_CANCEL 826
2343 /*******************************************************************************
2344 * SOCIAL message types
2345 ******************************************************************************/
2353 /** S->C: result of an operation */
2354 #define GNUNET_MESSAGE_TYPE_SOCIAL_RESULT_CODE 840
2356 /** C->S: request to enter a place as the host */
2357 #define GNUNET_MESSAGE_TYPE_SOCIAL_HOST_ENTER 841
2359 /** S->C: host enter acknowledgement */
2360 #define GNUNET_MESSAGE_TYPE_SOCIAL_HOST_ENTER_ACK 842
2362 /** C->S: request to enter a place as a guest */
2363 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER 843
2365 /** C->S: request to enter a place as a guest, using a GNS address */
2366 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER_BY_NAME 844
2368 /** S->C: guest enter acknowledgement */
2369 #define GNUNET_MESSAGE_TYPE_SOCIAL_GUEST_ENTER_ACK 845
2371 /** P->S->C: incoming entry request from PSYC */
2372 #define GNUNET_MESSAGE_TYPE_SOCIAL_ENTRY_REQUEST 846
2374 /** C->S->P: decision about an entry request */
2375 #define GNUNET_MESSAGE_TYPE_SOCIAL_ENTRY_DECISION 847
2377 /** C->S: request to leave a place */
2378 #define GNUNET_MESSAGE_TYPE_SOCIAL_PLACE_LEAVE 848
2380 /** C->S: add place to GNS zone */
2381 #define GNUNET_MESSAGE_TYPE_SOCIAL_ZONE_ADD_PLACE 849
2383 /** C->S: add nym to GNS zone */
2384 #define GNUNET_MESSAGE_TYPE_SOCIAL_ZONE_ADD_NYM 850
2386 /** C->S: connect application */
2387 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_CONNECT 851
2389 /** C->S: detach a place from application */
2390 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_DETACH 852
2392 /** S->C: notify about an existing ego */
2393 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_EGO 853
2395 /** S->C: end of ego list */
2396 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_EGO_END 854
2398 /** S->C: notify about an existing place */
2399 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_PLACE 855
2401 /** S->C: end of place list */
2402 #define GNUNET_MESSAGE_TYPE_SOCIAL_APP_PLACE_END 856
2404 /** C->S: set message processing flags */
2405 #define GNUNET_MESSAGE_TYPE_SOCIAL_MSG_PROC_SET 860
2407 /** C->S: clear message processing flags */
2408 #define GNUNET_MESSAGE_TYPE_SOCIAL_MSG_PROC_CLEAR 861
2410 /*******************************************************************************
2411 * X-VINE DHT messages
2412 ******************************************************************************/
2415 * Trail setup request is received by a peer.
2417 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP 880
2420 * Trail to a particular peer is returned to this peer.
2422 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP_RESULT 881
2425 * Verify if your immediate successor is still your immediate successor.
2427 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_VERIFY_SUCCESSOR 882
2430 * Notify your new immediate successor that you are its new predecessor.
2432 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_NOTIFY_NEW_SUCCESSOR 883
2435 * Message which contains the immediate predecessor of requested successor
2437 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_VERIFY_SUCCESSOR_RESULT 884
2440 * Message which contains the get result.
2442 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_GET_RESULT 885
2445 * Trail Rejection Message.
2447 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_SETUP_REJECTION 886
2450 * Trail Tear down Message.
2452 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_TRAIL_TEARDOWN 887
2455 * Routing table add message.
2457 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_ADD_TRAIL 888
2460 * Peer is storing the data in DHT.
2462 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_PUT 890
2465 * Peer tries to find data in DHT.
2467 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_GET 891
2470 * Send back peer that considers you are its successor, a confirmation
2471 * that you got the notify successor message.
2473 #define GNUNET_MESSAGE_TYPE_XDHT_P2P_NOTIFY_SUCCESSOR_CONFIRMATION 892
2475 #if ENABLE_MALICIOUS
2477 * Turn X-VINE DHT service malicious
2479 #define GNUNET_MESSAGE_TYPE_DHT_ACT_MALICIOUS 893
2482 * Acknowledge receiving ACT MALICIOUS request
2484 #define GNUNET_MESSAGE_TYPE_DHT_CLIENT_ACT_MALICIOUS_OK 894
2489 /*******************************************************************************
2490 * Whanau DHT messages
2491 ******************************************************************************/
2495 * This message contains the query for performing a random walk
2497 #define GNUNET_MESSAGE_TYPE_WDHT_RANDOM_WALK 910
2500 * This message contains the result of a random walk
2502 #define GNUNET_MESSAGE_TYPE_WDHT_RANDOM_WALK_RESPONSE 911
2505 * This message contains a notification for the death of a trail
2507 #define GNUNET_MESSAGE_TYPE_WDHT_TRAIL_DESTROY 912
2510 * This message are used to route a query to a peer
2512 #define GNUNET_MESSAGE_TYPE_WDHT_TRAIL_ROUTE 913
2515 * This message contains the query to transfer successor values.
2517 #define GNUNET_MESSAGE_TYPE_WDHT_SUCCESSOR_FIND 914
2520 * Message which contains the get query
2522 #define GNUNET_MESSAGE_TYPE_WDHT_GET 915
2525 * Message which contains the "put", a response to
2526 * #GNUNET_MESSAGE_TYPE_WDHT_SUCCESSOR_FIND.
2528 #define GNUNET_MESSAGE_TYPE_WDHT_PUT 916
2531 * Message which contains the get result, a response
2532 * to #GNUNET_MESSAGE_TYPE_WDHT_GET.
2534 #define GNUNET_MESSAGE_TYPE_WDHT_GET_RESULT 917
2537 /*******************************************************************************
2539 ******************************************************************************/
2544 * RPS check liveliness message to check liveliness of other peer
2546 #define GNUNET_MESSAGE_TYPE_RPS_PP_CHECK_LIVE 950
2549 * RPS PUSH message to push own ID to another peer
2551 #define GNUNET_MESSAGE_TYPE_RPS_PP_PUSH 951
2554 * RPS PULL REQUEST message to request the local view of another peer
2556 #define GNUNET_MESSAGE_TYPE_RPS_PP_PULL_REQUEST 952
2559 * RPS PULL REPLY message which contains the view of the other peer
2561 #define GNUNET_MESSAGE_TYPE_RPS_PP_PULL_REPLY 953
2565 /* Client-Service Messages */
2568 * RPS CS REQUEST Message for the Client to request (a) random peer(s)
2570 #define GNUNET_MESSAGE_TYPE_RPS_CS_REQUEST 954
2573 * RPS CS REPLY Message for the Server to send (a) random peer(s)
2575 #define GNUNET_MESSAGE_TYPE_RPS_CS_REPLY 955
2578 * RPS CS REQUEST CANCEL Message for the Client to cancel a request
2580 #define GNUNET_MESSAGE_TYPE_RPS_CS_REQUEST_CANCEL 956
2583 * RPS CS SEED Message for the Client to seed peers into rps
2585 #define GNUNET_MESSAGE_TYPE_RPS_CS_SEED 957
2587 #ifdef ENABLE_MALICIOUS
2589 * Turn RPS service malicious
2591 #define GNUNET_MESSAGE_TYPE_RPS_ACT_MALICIOUS 958
2593 #endif /* ENABLE_MALICIOUS */
2595 /******************************************************************************/
2598 /**************************************************
2600 * IDENTITY PROVIDER MESSAGE TYPES
2602 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ISSUE 961
2604 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_EXCHANGE 962
2606 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_ISSUE_RESULT 963
2608 #define GNUNET_MESSAGE_TYPE_IDENTITY_PROVIDER_EXCHANGE_RESULT 964
2610 /******************************************************************************/
2613 /******************************************************************************/
2614 /*********************************** CADET **********************************/
2615 /******************************************************************************/
2616 /* CADET: message types 1000-1059
2617 * 1000-1009 Connection-level Messages
2618 * 1010-1019 Channel-level Messages
2619 * 1020-1029 Local Client-Service
2620 * 1030-1039 Local Service Monitoring
2621 * 1040-1049 Application Data
2622 * 1050-1059 Reserved
2625 /******************************** Connection ********************************/
2628 * Request the creation of a connection
2630 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_CREATE 1000
2633 * Send origin an ACK that the connection is complete
2635 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_CREATE_ACK 1001
2638 * Notify that a connection is no longer valid
2640 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_BROKEN 1002
2643 * Request the destuction of a connection
2645 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_DESTROY 1003
2648 * At some point, the route will spontaneously change TODO
2650 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_PATH_CHANGED_UNIMPLEMENTED 1004
2653 * Hop-by-hop, connection dependent ACK.
2657 #define GNUNET_MESSAGE_TYPE_CADET_CONNECTION_HOP_BY_HOP_ENCRYPTED_ACK 1005
2660 * We do not bother with ACKs for
2661 * #GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED messages, but we instead
2662 * poll for one if we got nothing for a while and start to be worried.
2666 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED_POLL 1006
2669 * Axolotl key exchange.
2671 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_KX 1007
2674 * Axolotl encrypted data.
2676 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_ENCRYPTED 1008
2679 * Axolotl key exchange response with authentication.
2681 #define GNUNET_MESSAGE_TYPE_CADET_TUNNEL_KX_AUTH 1009
2685 /********************************** Channel *********************************/
2688 * Payload data (inside an encrypted tunnel).
2690 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_APP_DATA 1010
2693 * Confirm payload data end-to-end.
2695 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_APP_DATA_ACK 1011
2698 * Announce connection is still alive (direction sensitive).
2700 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_KEEPALIVE 1012
2703 * Ask the cadet service to create a new channel.
2705 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN 1013
2708 * Ask the cadet service to destroy a channel.
2710 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_DESTROY 1014
2713 * Confirm the creation of a channel
2715 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN_ACK 1015
2718 * Reject the creation of a channel
2722 #define GNUNET_MESSAGE_TYPE_CADET_CHANNEL_OPEN_NACK_DEPRECATED 1016
2724 /*********************************** Local **********************************/
2727 * Payload client <-> service
2729 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_DATA 1020
2732 * Local ACK for data.
2734 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_ACK 1021
2737 * Start listening on a port.
2739 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_PORT_OPEN 1022
2742 * Stop listening on a port.
2744 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_PORT_CLOSE 1023
2747 * Ask the cadet service to create a new channel.
2749 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_CHANNEL_CREATE 1024
2752 * Tell client that a channel was destroyed.
2754 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_CHANNEL_DESTROY 1025
2756 /********************************** Monitor *********************************/
2760 * Local information about all channels of service.
2762 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CHANNELS 1030
2765 * Local information of service about a specific channel.
2767 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CHANNEL 1031
2770 * Local information about all tunnels of service.
2772 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_TUNNELS 1032
2775 * Local information of service about a specific tunnel.
2777 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_TUNNEL 1033
2780 * Local information about all connections of service.
2782 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CONNECTIONS 1034
2785 * Local information of service about a specific connection.
2787 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_CONNECTION 1035
2790 * Local information about all peers known to the service.
2792 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEERS 1036
2795 * Local information of service about a specific peer.
2797 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEER 1037
2802 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_DUMP 1038
2805 * End of local information about all peers known to the service.
2807 #define GNUNET_MESSAGE_TYPE_CADET_LOCAL_INFO_PEER_END 1039
2809 /******************************** Application *******************************/
2812 * Traffic (net-cat style) used by the Command Line Interface.
2814 #define GNUNET_MESSAGE_TYPE_CADET_CLI 1040
2816 /******************************************************************************/
2819 /******************************************************************************/
2820 /************************************* NAT **********************************/
2821 /******************************************************************************/
2824 * Message to ask NAT service to register a client.
2826 #define GNUNET_MESSAGE_TYPE_NAT_REGISTER 1060
2829 * Message to ask NAT service to handle a STUN packet.
2831 #define GNUNET_MESSAGE_TYPE_NAT_HANDLE_STUN 1061
2834 * Message to ask NAT service to request connection reversal.
2836 #define GNUNET_MESSAGE_TYPE_NAT_REQUEST_CONNECTION_REVERSAL 1062
2839 * Message to from NAT service notifying us that connection reversal
2840 * was requested by another peer.
2842 #define GNUNET_MESSAGE_TYPE_NAT_CONNECTION_REVERSAL_REQUESTED 1063
2845 * Message to from NAT service notifying us that one of our
2846 * addresses changed.
2848 #define GNUNET_MESSAGE_TYPE_NAT_ADDRESS_CHANGE 1064
2851 * Message to ask NAT service to request autoconfiguration.
2853 #define GNUNET_MESSAGE_TYPE_NAT_AUTO_REQUEST_CFG 1067
2856 * Message from NAT service with the autoconfiguration result.
2858 #define GNUNET_MESSAGE_TYPE_NAT_AUTO_CFG_RESULT 1068
2861 /* 1080-1109 reserved for TMCG (Heiko Stamer, see gnunet-developers, January 2017) */
2864 /******************************************************************************/
2865 /*********************************** AUCTION ********************************/
2866 /******************************************************************************/
2869 * Client wants to create a new auction.
2871 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_CREATE 1110
2874 * Client wants to join an existing auction.
2876 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_JOIN 1111
2879 * Service reports the auction outcome to the client.
2881 #define GNUNET_MESSAGE_TYPE_AUCTION_CLIENT_OUTCOME 1112
2885 * Next available: 1130
2890 * Type used to match 'all' message types.
2892 #define GNUNET_MESSAGE_TYPE_ALL 65535
2895 #if 0 /* keep Emacsens' auto-indent happy */
2902 /* ifndef GNUNET_PROTOCOLS_H */
2905 /** @} */ /* end of group protocols */
2907 /* end of gnunet_protocols.h */