GNUnet debian-0.24.3-28-g4f2a77692
 
Loading...
Searching...
No Matches
gnunet-daemon-topology.c
Go to the documentation of this file.
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2007-2016 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
20
30#include "platform.h"
31#include "gnunet_util_lib.h"
33#include "gnunet_constants.h"
34#include "gnunet_core_service.h"
35#include "gnunet_pils_service.h"
36#include "gnunet_protocols.h"
40#include <assert.h>
41
42
46#define HELLO_ADVERTISEMENT_MIN_FREQUENCY \
47 GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_MINUTES, 5)
48
52#define HELLO_ADVERTISEMENT_MIN_REPEAT_FREQUENCY \
53 GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_HOURS, 4)
54
55
110
114struct StoreHelloEntry
115{
119 struct StoreHelloEntry *prev;
120
124 struct StoreHelloEntry *next;
125
130};
131
137
138
144
148static const struct GNUNET_CONFIGURATION_Handle *cfg;
149
154
159
164
169
174
181
186
192
196static unsigned int connection_count;
197
201static unsigned int target_connection_count;
202
207
212
221static int
222free_peer (void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
223{
224 struct Peer *pos = value;
225
226 GNUNET_break (NULL == pos->mq);
229 if (NULL != pos->hello_delay_task)
230 {
232 pos->hello_delay_task = NULL;
233 }
234 if (NULL != pos->ash)
235 {
237 pos->ash = NULL;
238 }
239 if (NULL != pos->hello)
240 {
241 GNUNET_free (pos->hello);
242 pos->hello = NULL;
243 }
244 if (NULL != pos->filter)
245 {
247 pos->filter = NULL;
248 }
249 GNUNET_free (pos);
250 return GNUNET_YES;
251}
252
253
260static void
262{
263 uint32_t strength;
265
267 "Checking if we want to attempt connection to `%s'\n",
268 GNUNET_i2s(&pos->pid));
269 if (0 == GNUNET_memcmp (&my_identity, &pos->pid))
270 return; /* This is myself, nothing to do. */
272 strength = 1;
273 else
274 strength = 0;
275 if (NULL != pos->mq)
276 strength *= 2; /* existing connections preferred */
277 if (NULL != pos->ash)
278 {
280 pos->ash = NULL;
281 }
282 pos->strength = strength;
283 if (0 != strength)
284 {
286 "Asking to connect to `%s' with strength %u\n",
287 GNUNET_i2s (&pos->pid),
288 (unsigned int) strength);
290 gettext_noop ("# connect requests issued to ATS"),
291 1,
292 GNUNET_NO);
293 // TODO Use strength somehow.
294 bw.value__ = 0;
296 &pos->pid,
298 bw);
299 }
300}
301
302
310static struct Peer *
311make_peer (const struct GNUNET_PeerIdentity *peer,
312 const struct GNUNET_MessageHeader *hello)
313{
314 struct Peer *ret;
315
316 ret = GNUNET_new (struct Peer);
317 ret->pid = *peer;
318 if (NULL != hello)
319 {
320 ret->hello = GNUNET_malloc (ntohs (hello->size));
321 GNUNET_memcpy (ret->hello, hello, ntohs (hello->size));
322 }
325 peers,
326 peer,
327 ret,
329 return ret;
330}
331
332
338static void
339setup_filter (struct Peer *peer)
340{
341 struct GNUNET_HashCode hc;
342
343 /* 2^{-5} chance of not sending a HELLO to a peer is
344 * acceptably small (if the filter is 50% full);
345 * 64 bytes of memory are small compared to the rest
346 * of the data structure and would only really become
347 * "useless" once a HELLO has been passed on to ~100
348 * other peers, which is likely more than enough in
349 * any case; hence 64, 5 as bloomfilter parameters. */peer->filter = GNUNET_CONTAINER_bloomfilter_init (NULL, 64, 5);
350 peer->filter_expiration =
352 /* never send a peer its own HELLO */
353 GNUNET_CRYPTO_hash (&peer->pid, sizeof(struct GNUNET_PeerIdentity), &hc);
355}
356
357
362{
366 struct Peer *peer;
367
371 struct Peer *result;
372
376 size_t max_size;
377
379};
380
381
390static int
392 const struct GNUNET_PeerIdentity *pid,
393 void *value)
394{
395 struct FindAdvHelloContext *fah = cls;
396 struct Peer *pos = value;
397 struct GNUNET_TIME_Relative rst_time;
398 struct GNUNET_HashCode hc;
399 size_t hs;
400
402 "find_advertisable_hello\n");
403 if (pos == fah->peer)
404 return GNUNET_YES;
406 "find_advertisable_hello 2\n");
407 if (pos->hello == NULL)
408 return GNUNET_YES;
410 "find_advertisable_hello 3\n");
412 if (0 == rst_time.rel_value_us)
413 {
414 /* time to discard... */
416 setup_filter (pos);
417 }
418 fah->next_adv = GNUNET_TIME_relative_min (rst_time, fah->next_adv);
419 hs = pos->hello->size;
420 if (hs > fah->max_size)
421 return GNUNET_YES;
423 "find_advertisable_hello 4\n");
425 sizeof(struct GNUNET_PeerIdentity),
426 &hc);
428 fah->result = pos;
429 return GNUNET_YES;
430}
431
432
439static void
441{
442 struct Peer *pl = cls;
443 struct FindAdvHelloContext fah;
444 struct GNUNET_MQ_Envelope *env;
445 size_t want;
446 struct GNUNET_TIME_Relative delay;
447 struct GNUNET_HashCode hc;
448
450 "schedule_next_hello\n");
451 pl->hello_delay_task = NULL;
452 GNUNET_assert (NULL != pl->mq);
453 /* find applicable HELLOs */
454 fah.peer = pl;
455 fah.result = NULL;
459 if (NULL == fah.result)
460 {
461 pl->hello_delay_task =
463
464 return;
465 }
466 want = ntohs (fah.result->hello->size);
468 "Sending HELLO with %u bytes for peer %s\n",
469 (unsigned int) want,
470 GNUNET_i2s (&pl->pid));
472 GNUNET_MQ_send (pl->mq, env);
473
474 /* avoid sending this one again soon */
475 GNUNET_CRYPTO_hash (&pl->pid, sizeof(struct GNUNET_PeerIdentity), &hc);
477
479 gettext_noop ("# HELLO messages gossipped"),
480 1,
481 GNUNET_NO);
482 /* prepare to send the next one */
488}
489
490
501static int
503 const struct GNUNET_PeerIdentity *pid,
504 void *value)
505{
506 struct Peer *peer = value;
507 (void) cls;
508
510 "Reschedule for `%s'\n",
511 GNUNET_i2s (&peer->pid));
512 if (NULL == peer->mq)
513 return GNUNET_YES;
514 if (NULL != peer->hello_delay_task)
515 {
517 peer->hello_delay_task = NULL;
518 }
520 "Schedule_next_hello\n");
521 peer->hello_delay_task =
523 return GNUNET_YES;
524}
525
526
536static void *
537connect_notify (void *cls,
538 const struct GNUNET_PeerIdentity *peer,
539 struct GNUNET_MQ_Handle *mq,
540 enum GNUNET_CORE_PeerClass class)
541{
542 struct Peer *pos;
543
545 "Core told us that we are connecting to `%s'\n",
546 GNUNET_i2s (peer));
547 if (0 == GNUNET_memcmp (&my_identity, peer))
548 return NULL;
552 gettext_noop ("# peers connected"),
554 GNUNET_NO);
556 if (NULL == pos)
557 {
558 pos = make_peer (peer, NULL);
559 }
560 else
561 {
562 GNUNET_assert (NULL == pos->mq);
563 }
564 pos->mq = mq;
565 reschedule_hellos (NULL, peer, pos);
566 return pos;
567}
568
569
578static int
579try_add_peers (void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
580{
581 struct Peer *pos = value;
582
583 attempt_connect (pos);
584 return GNUNET_YES;
585}
586
587
593static void
594add_peer_task (void *cls)
595{
596 add_task = NULL;
597
599}
600
601
609static void
611 const struct GNUNET_PeerIdentity *peer,
612 void *internal_cls)
613{
614 struct Peer *pos = internal_cls;
615
616 if (NULL == pos)
617 return; /* myself, we're shutting down */
619 "Core told us that we disconnected from `%s'\n",
620 GNUNET_i2s (peer));
621 if (NULL == pos->mq)
622 {
623 GNUNET_break (0);
624 return;
625 }
626 pos->mq = NULL;
628 if (NULL != pos->hello_delay_task)
629 {
631 pos->hello_delay_task = NULL;
632 }
634 gettext_noop ("# peers connected"),
636 GNUNET_NO);
638 (NULL == add_task))
640
641}
642
643
651static void
653 const struct GNUNET_PeerIdentity *pid,
654 const char *uri)
655{
656 int *flag = cls;
657 (void) pid;
658
659 *flag = *flag + 1;
660 // *flag = GNUNET_YES;
661}
662
663
670static void
672{
673 int num_addresses_old = 0;
674 int num_addresses_new = 0;
675 struct GNUNET_HELLO_Parser *parser;
676 const struct GNUNET_PeerIdentity *pid;
677 struct Peer *peer;
678 uint16_t size;
679
681 if (NULL == parser)
682 {
683 return;
684 }
687 &num_addresses_new);
689 "consider 0 for %s\n",
690 GNUNET_i2s (pid));
691 if (0 == num_addresses_new)
692 {
694 return; /* no point in advertising this one... */
695 }
697 if (NULL == peer)
698 {
699 peer = make_peer (pid, hello);
700 }
701 else if (NULL != peer->hello)
702 {
704 struct GNUNET_TIME_Absolute new_hello_exp =
706 struct GNUNET_TIME_Absolute old_hello_exp =
708 struct GNUNET_HELLO_Parser *parser_old =
710
711 GNUNET_HELLO_parser_iterate (parser_old,
713 &num_addresses_old);
714 GNUNET_HELLO_parser_free (parser_old);
715 if (GNUNET_TIME_absolute_cmp (new_hello_exp, >, now) &&
716 (GNUNET_TIME_absolute_cmp (new_hello_exp, >, old_hello_exp) ||
717 num_addresses_old < num_addresses_new))
718 {
719 GNUNET_free (peer->hello);
720 size = ntohs (hello->size);
721 peer->hello = GNUNET_malloc (size);
722 GNUNET_memcpy (peer->hello, hello, size);
723 }
724 else
725 {
727 "consider 3\n");
729 return;
730 }
731 }
732 else
733 {
734 size = ntohs (hello->size);
735 peer->hello = GNUNET_malloc (size);
736 GNUNET_memcpy (peer->hello, hello, size);
737 }
739 "Found HELLO from peer `%s' for advertising\n",
740 GNUNET_i2s (pid));
741 if (NULL != peer->filter)
742 {
744 peer->filter = NULL;
745 }
746 setup_filter (peer);
747 /* since we have a new HELLO to pick from, re-schedule all
748 * HELLO requests that are not bound by the HELLO send rate! */
751}
752
753
754static void
755error_cb (void *cls)
756{
758 _ (
759 "Error in communication with PEERSTORE service to monitor.\n"));
760 return;
761}
762
763
764static void
765sync_cb (void *cls)
766{
768 _ ("Finished initial PEERSTORE iteration in monitor.\n"));
769 return;
770}
771
772
782static void
783process_peer (void *cls,
784 const struct GNUNET_PEERSTORE_Record *record,
785 const char *err_msg)
786{
787 struct Peer *pos;
788 struct GNUNET_MessageHeader *hello;
789
790 if (NULL != err_msg)
791 {
793 _ ("Error in communication with PEERSTORE service: %s\n"),
794 err_msg);
799 "peerstore",
800 NULL,
802 error_cb,
803 NULL,
804 sync_cb,
805 NULL,
807 NULL);
808 return;
809 }
810 GNUNET_assert (NULL != record);
812 "Processing HELLO from peerstore from peer `%s'\n",
813 GNUNET_i2s (&record->peer));
814 hello = record->value;
815 if (NULL == hello)
816 {
817 /* free existing HELLO, if any */
819 if (NULL != pos)
820 {
821 GNUNET_free (pos->hello);
822 pos->hello = NULL;
823 if (NULL != pos->filter)
824 {
826 pos->filter = NULL;
827 }
828 if (NULL == pos->mq)
829 free_peer (NULL, &pos->pid, pos);
830 }
832 return;
833 }
836 if (NULL == pos)
837 pos = make_peer (&record->peer, hello);
838 attempt_connect (pos);
840}
841
842
843static void
844start_notify (void *cls)
845{
846 (void) cls;
847
849 "Starting to process new hellos for gossiping.\n");
853 "peerstore",
854 NULL,
856 &error_cb,
857 NULL,
858 &sync_cb,
859 NULL,
861 NULL);
862}
863
864static void
865pid_change_cb (void *cls,
866 const struct GNUNET_HELLO_Parser *parser,
867 const struct GNUNET_HashCode *addr_hash)
868{
870}
871
879static void
880core_init (void *cls, const struct GNUNET_PeerIdentity *my_id)
881{
882 if (NULL == my_id)
883 {
884 GNUNET_log (
886 _ ("Failed to connect to core service, can not manage topology!\n"));
888 return;
889 }
890 my_identity = *my_id;
891 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "I am peer `%s'\n", GNUNET_i2s (my_id));
895 NULL);
896}
897
898
908static int
909check_hello (void *cls, const struct GNUNET_MessageHeader *msg)
910{
912 const struct GNUNET_PeerIdentity *pid = GNUNET_HELLO_parser_get_id (parser);
913
914 if (NULL == pid)
915 {
916 GNUNET_break_op (0);
917 return GNUNET_SYSERR;
918 }
919 return GNUNET_OK;
920}
921
922
923static void
924shc_cont (void *cls, int success)
925{
926 struct StoreHelloEntry *she = cls;
927
928 she->sc = NULL;
929 if (GNUNET_YES == success)
931 "Hello stored successfully!\n");
932 else
934 "Error storing hello!\n");
936 GNUNET_free (she);
937}
938
939
947static void
948handle_hello (void *cls, const struct GNUNET_MessageHeader *msg)
949{
950 struct StoreHelloEntry *she;
951 const struct GNUNET_PeerIdentity *other = cls;
952 struct GNUNET_HELLO_Parser *parser;
953
955 "Received encrypted HELLO from peer `%s'\n",
956 GNUNET_i2s (other));
958 gettext_noop ("# HELLO messages received"),
959 1,
960 GNUNET_NO);
962 she = GNUNET_new (struct StoreHelloEntry);
964 if (NULL != she->sc)
965 {
967 }
968 else
969 GNUNET_free (she);
971}
972
973
980static void
981cleaning_task (void *cls)
982{
983 struct StoreHelloEntry *pos;
984
985 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Topology shutdown\n");
986 while (NULL != (pos = she_head))
987 {
989 if (NULL != pos->sc)
991 GNUNET_free (pos);
992 }
993 if (NULL != peerstore_notify)
994 {
996 peerstore_notify = NULL;
997 }
998 else if (NULL != peerstore_notify_task)
999 {
1001 }
1002 if (NULL != pils)
1003 {
1005 pils = NULL;
1006 }
1007 if (NULL != handle)
1008 {
1010 handle = NULL;
1011 }
1012 if (NULL != add_task)
1013 {
1015 add_task = NULL;
1016 }
1019 peers = NULL;
1020 if (NULL != transport)
1021 {
1023 transport = NULL;
1024 }
1025 if (NULL != ps)
1026 {
1028 ps = NULL;
1029 }
1030 if (NULL != stats)
1031 {
1033 stats = NULL;
1034 }
1035}
1036
1037
1046static void
1047run (void *cls,
1048 char *const *args,
1049 const char *cfgfile,
1050 const struct GNUNET_CONFIGURATION_Handle *c)
1051{
1053 { GNUNET_MQ_hd_var_size (hello,
1055 struct GNUNET_MessageHeader,
1056 NULL),
1058 unsigned long long opt;
1059 const struct GNUNET_CORE_ServiceInfo service_info =
1060 {
1062 .version = { 1, 0 },
1063 .version_max = { 1, 0 },
1064 .version_min = { 1, 0 },
1065 };
1066
1067 cfg = c;
1068 stats = GNUNET_STATISTICS_create ("topology", cfg);
1069
1070 if (GNUNET_OK !=
1072 "TOPOLOGY",
1073 "TARGET-CONNECTION-COUNT",
1074 &opt))
1075 opt = 16;
1076 target_connection_count = (unsigned int) opt;
1078 GNUNET_NO);
1082 NULL,
1083 &core_init,
1086 handlers,
1087 &service_info);
1090 if (NULL == pils)
1091 {
1093 _ ("Failed to connect to `%s' service.\n"),
1094 "pils");
1096 return;
1097 }
1098 if (NULL == handle)
1099 {
1101 _ ("Failed to connect to `%s' service.\n"),
1102 "core");
1104 return;
1105 }
1106}
1107
1108
1116int
1117main (int argc, char *const *argv)
1118{
1119 static const struct GNUNET_GETOPT_CommandLineOption options[] = {
1121 };
1122 int ret;
1123
1124 ret = (GNUNET_OK ==
1126 argc,
1127 argv,
1128 "gnunet-daemon-topology",
1129 _ ("GNUnet topology control"),
1130 options,
1131 &run,
1132 NULL))
1133 ? 0
1134 : 1;
1135 return ret;
1136}
1137
1138
1139#if defined(__linux__) && defined(__GLIBC__)
1140#include <malloc.h>
1141
1142void __attribute__ ((constructor))
1143GNUNET_TOPOLOGY_memory_init (void);
1144
1148void __attribute__ ((constructor))
1149GNUNET_TOPOLOGY_memory_init (void)
1150{
1151 mallopt (M_TRIM_THRESHOLD, 4 * 1024);
1152 mallopt (M_TOP_PAD, 1 * 1024);
1153 malloc_trim (0);
1154}
1155
1156
1157#endif
1158
1159/* end of gnunet-daemon-topology.c */
struct GNUNET_GETOPT_CommandLineOption options[]
Definition 002.c:5
struct GNUNET_MQ_MessageHandlers handlers[]
Definition 003.c:1
struct GNUNET_MessageHeader * msg
Definition 005.c:2
struct GNUNET_MQ_Envelope * env
Definition 005.c:1
int main()
Program to simulate results from GCP_get_desirability_of_path() for various plausible inputs.
#define gettext_noop(String)
Definition gettext.h:74
static int ret
Final status code.
Definition gnunet-arm.c:93
static void record(void *cls, size_t data_size, const void *data)
Process recorded audio data.
static struct GNUNET_CORE_Handle * handle
Handle to the CORE service.
static struct GNUNET_CONTAINER_MultiPeerMap * peers
All of our current neighbours and all peers for which we have HELLOs.
static void handle_hello(void *cls, const struct GNUNET_MessageHeader *msg)
This function is called whenever an encrypted HELLO message is received.
static int check_hello(void *cls, const struct GNUNET_MessageHeader *msg)
This function is called whenever an encrypted HELLO message is received.
static void sync_cb(void *cls)
static void cleaning_task(void *cls)
Last task run during shutdown.
static void add_peer_task(void *cls)
Add peers and schedule connection attempt.
static struct GNUNET_PeerIdentity my_identity
Identity of this peer.
static void consider_for_advertising(const struct GNUNET_MessageHeader *hello)
We've gotten a HELLO from another peer.
static unsigned int target_connection_count
Target number of connections.
static void schedule_next_hello(void *cls)
Calculate when we would like to send the next HELLO to this peer and ask for it.
static struct GNUNET_PEERSTORE_Handle * ps
Handle to the PEERSTORE service.
static struct GNUNET_PEERSTORE_Monitor * peerstore_notify
Our peerstore notification context.
static void disconnect_notify(void *cls, const struct GNUNET_PeerIdentity *peer, void *internal_cls)
Method called whenever a peer disconnects.
static struct GNUNET_STATISTICS_Handle * stats
Handle for reporting statistics.
static const struct GNUNET_CONFIGURATION_Handle * cfg
Our configuration.
static void address_iterator(void *cls, const struct GNUNET_PeerIdentity *pid, const char *uri)
Iterator called on each address.
static unsigned int connection_count
Number of peers that we are currently connected to.
static struct StoreHelloEntry * she_head
Head of the linkd list to store the store context for hellos.
static void start_notify(void *cls)
static struct StoreHelloEntry * she_tail
Tail of the linkd list to store the store context for hellos.
struct GNUNET_SCHEDULER_Task * peerstore_notify_task
The task to delayed start the notification process initially.
static void process_peer(void *cls, const struct GNUNET_PEERSTORE_Record *record, const char *err_msg)
PEERSTORE calls this function to let us know about a possible peer that we might want to connect to.
static void run(void *cls, char *const *args, const char *cfgfile, const struct GNUNET_CONFIGURATION_Handle *c)
Main function that will be run.
static void core_init(void *cls, const struct GNUNET_PeerIdentity *my_id)
Function called after GNUNET_CORE_connect has succeeded (or failed for good).
static void shc_cont(void *cls, int success)
#define HELLO_ADVERTISEMENT_MIN_REPEAT_FREQUENCY
After what time period do we expire the HELLO Bloom filter?
static int reschedule_hellos(void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
Cancel existing requests for sending HELLOs to this peer and recalculate when we should send HELLOs t...
static void pid_change_cb(void *cls, const struct GNUNET_HELLO_Parser *parser, const struct GNUNET_HashCode *addr_hash)
struct GNUNET_TRANSPORT_ApplicationHandle * transport
Handle to Transport service.
#define HELLO_ADVERTISEMENT_MIN_FREQUENCY
At what frequency do we sent HELLOs to a peer?
static void setup_filter(struct Peer *peer)
Setup bloom filter for the given peer entry.
static int free_peer(void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
Free all resources associated with the given peer.
static void error_cb(void *cls)
static struct GNUNET_SCHEDULER_Task * add_task
Task scheduled to asynchronously reconsider adding/removing peer connectivity suggestions.
static void attempt_connect(struct Peer *pos)
Recalculate how much we want to be connected to the specified peer and let ATS know about the result.
static int find_advertisable_hello(void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
Find a peer that would be reasonable for advertising.
static struct Peer * make_peer(const struct GNUNET_PeerIdentity *peer, const struct GNUNET_MessageHeader *hello)
Create a new entry in the peer list.
static int try_add_peers(void *cls, const struct GNUNET_PeerIdentity *pid, void *value)
Try to add more peers to our connection set.
static void * connect_notify(void *cls, const struct GNUNET_PeerIdentity *peer, struct GNUNET_MQ_Handle *mq, enum GNUNET_CORE_PeerClass class)
Method called whenever a peer connects.
static struct GNUNET_PILS_Handle * pils
Handle to the PILS service.
static char * value
Value of the record to add/remove.
static struct GNUNET_FS_Uri * uri
Value of URI provided on command-line (when not publishing a file but just creating UBlocks to refer ...
static struct GNUNET_PeerIdentity pid
Identity of the peer we transmit to / connect to.
Core service; the main API for encrypted P2P communications.
Helper library for handling HELLO URIs.
API to the peerstore service.
struct GNUNET_PILS_Handle * GNUNET_PILS_connect(const struct GNUNET_CONFIGURATION_Handle *cfg, GNUNET_PILS_PidChangeCallback pid_change_cb, void *cls)
Connect to the PILS service.
Definition pils_api.c:367
void GNUNET_PILS_disconnect(struct GNUNET_PILS_Handle *handle)
Disconnect from the PILS service.
Definition pils_api.c:390
struct GNUNET_PQ_ResultSpec __attribute__
Constants for network protocols.
API to create, modify and access statistics.
Bandwidth allocation API for applications to interact with.
#define GNUNET_MAX_MESSAGE_SIZE
Largest supported message (to be precise, one byte more than the largest possible message,...
struct GNUNET_TRANSPORT_ApplicationSuggestHandle * GNUNET_TRANSPORT_application_suggest(struct GNUNET_TRANSPORT_ApplicationHandle *ch, const struct GNUNET_PeerIdentity *peer, enum GNUNET_MQ_PriorityPreferences pk, struct GNUNET_BANDWIDTH_Value32NBO bw)
An application would like TRANSPORT to connect to a peer.
void GNUNET_TRANSPORT_application_done(struct GNUNET_TRANSPORT_ApplicationHandle *ch)
Shutdown TRANSPORT application client.
void GNUNET_TRANSPORT_application_suggest_cancel(struct GNUNET_TRANSPORT_ApplicationSuggestHandle *sh)
We no longer care about being connected to a peer.
struct GNUNET_TRANSPORT_ApplicationHandle * GNUNET_TRANSPORT_application_init(const struct GNUNET_CONFIGURATION_Handle *cfg)
Initialize the TRANSPORT application client handle.
struct GNUNET_CONTAINER_BloomFilter * GNUNET_CONTAINER_bloomfilter_init(const char *data, size_t size, unsigned int k)
Create a Bloom filter from raw bits.
void GNUNET_CONTAINER_bloomfilter_add(struct GNUNET_CONTAINER_BloomFilter *bf, const struct GNUNET_HashCode *e)
Add an element to the filter.
bool GNUNET_CONTAINER_bloomfilter_test(const struct GNUNET_CONTAINER_BloomFilter *bf, const struct GNUNET_HashCode *e)
Test if an element is in the filter.
void GNUNET_CONTAINER_bloomfilter_free(struct GNUNET_CONTAINER_BloomFilter *bf)
Free the space associated with a filter in memory, flush to drive if needed (do not free the space on...
enum GNUNET_GenericReturnValue GNUNET_CONFIGURATION_get_value_number(const struct GNUNET_CONFIGURATION_Handle *cfg, const char *section, const char *option, unsigned long long *number)
Get a configuration value that should be a number.
GNUNET_CORE_PeerClass
The peer class gives a hint about the capabilities of a peer.
struct GNUNET_CORE_Handle * GNUNET_CORE_connect(const struct GNUNET_CONFIGURATION_Handle *cfg, void *cls, GNUNET_CORE_StartupCallback init, GNUNET_CORE_ConnectEventHandler connects, GNUNET_CORE_DisconnectEventHandler disconnects, const struct GNUNET_MQ_MessageHandler *handlers, struct GNUNET_CORE_ServiceInfo *service_info)
Connect to the core service.
Definition core_api.c:698
void GNUNET_CORE_disconnect(struct GNUNET_CORE_Handle *handle)
Disconnect from the core service.
Definition core_api.c:744
@ GNUNET_CORE_SERVICE_TOPOLOGY
Identifier for topology service.
#define GNUNET_CONTAINER_DLL_remove(head, tail, element)
Remove an element from a DLL.
#define GNUNET_CONTAINER_DLL_insert(head, tail, element)
Insert an element at the head of a DLL.
#define GNUNET_GETOPT_OPTION_END
Marker for the end of the list of options.
void GNUNET_CRYPTO_hash(const void *block, size_t size, struct GNUNET_HashCode *ret)
Compute hash of a given block.
Definition crypto_hash.c:41
void * GNUNET_CONTAINER_multipeermap_get(const struct GNUNET_CONTAINER_MultiPeerMap *map, const struct GNUNET_PeerIdentity *key)
Given a key find a value in the map matching the key.
void GNUNET_CONTAINER_multipeermap_destroy(struct GNUNET_CONTAINER_MultiPeerMap *map)
Destroy a hash map.
int GNUNET_CONTAINER_multipeermap_iterate(struct GNUNET_CONTAINER_MultiPeerMap *map, GNUNET_CONTAINER_PeerMapIterator it, void *it_cls)
Iterate over all entries in the map.
struct GNUNET_CONTAINER_MultiPeerMap * GNUNET_CONTAINER_multipeermap_create(unsigned int len, int do_not_copy_keys)
Create a multi peer map (hash map for public keys of peers).
int GNUNET_CONTAINER_multipeermap_put(struct GNUNET_CONTAINER_MultiPeerMap *map, const struct GNUNET_PeerIdentity *key, void *value, enum GNUNET_CONTAINER_MultiHashMapOption opt)
Store a key-value pair in the map.
enum GNUNET_GenericReturnValue GNUNET_CONTAINER_multipeermap_remove(struct GNUNET_CONTAINER_MultiPeerMap *map, const struct GNUNET_PeerIdentity *key, const void *value)
Remove the given key-value pair from the map.
@ GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY
There must only be one value per key; storing a value should fail if a value under the same key alrea...
void GNUNET_HELLO_parser_free(struct GNUNET_HELLO_Parser *parser)
Release resources of a builder.
Definition hello-uri.c:379
struct GNUNET_HELLO_Parser * GNUNET_HELLO_parser_from_msg(const struct GNUNET_MessageHeader *msg)
Parse msg.
Definition hello-uri.c:415
const struct GNUNET_PeerIdentity * GNUNET_HELLO_parser_iterate(const struct GNUNET_HELLO_Parser *parser, GNUNET_HELLO_UriCallback uc, void *uc_cls)
Iterate over URIs in a parser.
Definition hello-uri.c:975
struct GNUNET_TIME_Absolute GNUNET_HELLO_get_expiration_time_from_msg(const struct GNUNET_MessageHeader *msg)
Get the expiration time for this HELLO.
Definition hello-uri.c:597
const struct GNUNET_PeerIdentity * GNUNET_HELLO_parser_get_id(const struct GNUNET_HELLO_Parser *parser)
Get the PeerIdentity for this builder.
Definition hello-uri.c:353
#define GNUNET_log(kind,...)
#define GNUNET_memcmp(a, b)
Compare memory in a and b, where both must be of the same pointer type.
#define GNUNET_memcpy(dst, src, n)
Call memcpy() but check for n being 0 first.
uint16_t size
The length of the struct (in bytes, including the length field itself), in big-endian format.
@ GNUNET_OK
@ GNUNET_YES
@ GNUNET_NO
@ GNUNET_SYSERR
#define GNUNET_break_op(cond)
Use this for assertion violations caused by other peers (i.e.
const char * GNUNET_i2s(const struct GNUNET_PeerIdentity *pid)
Convert a peer identity to a string (for printing debug messages).
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
#define GNUNET_break(cond)
Use this for internal assertion violations that are not fatal (can be handled) but should not occur.
@ GNUNET_ERROR_TYPE_ERROR
@ GNUNET_ERROR_TYPE_DEBUG
#define GNUNET_new(type)
Allocate a struct or union of the given type.
#define GNUNET_malloc(size)
Wrapper around malloc.
#define GNUNET_free(ptr)
Wrapper around free.
struct GNUNET_MQ_Envelope * GNUNET_MQ_msg_copy(const struct GNUNET_MessageHeader *hdr)
Create a new envelope by copying an existing message.
Definition mq.c:550
void GNUNET_MQ_set_options(struct GNUNET_MQ_Handle *mq, enum GNUNET_MQ_PriorityPreferences pp)
Set application-specific options for this queue.
Definition mq.c:888
void GNUNET_MQ_send(struct GNUNET_MQ_Handle *mq, struct GNUNET_MQ_Envelope *ev)
Send a message with the given message queue.
Definition mq.c:305
#define GNUNET_MQ_handler_end()
End-marker for the handlers array.
#define GNUNET_MQ_hd_var_size(name, code, str, ctx)
@ GNUNET_MQ_PRIO_BEST_EFFORT
Best-effort traffic (e.g.
const struct GNUNET_OS_ProjectData * GNUNET_OS_project_data_gnunet(void)
Return default project data used by 'libgnunetutil' for GNUnet.
void GNUNET_PEERSTORE_monitor_stop(struct GNUNET_PEERSTORE_Monitor *zm)
Stop monitoring.
void GNUNET_PEERSTORE_disconnect(struct GNUNET_PEERSTORE_Handle *h)
Disconnect from the PEERSTORE service.
struct GNUNET_PEERSTORE_Monitor * GNUNET_PEERSTORE_monitor_start(const struct GNUNET_CONFIGURATION_Handle *cfg, int iterate_first, const char *sub_system, const struct GNUNET_PeerIdentity *peer, const char *key, GNUNET_SCHEDULER_TaskCallback error_cb, void *error_cb_cls, GNUNET_SCHEDULER_TaskCallback sync_cb, void *sync_cb_cls, GNUNET_PEERSTORE_Processor callback, void *callback_cls)
Request watching a given key The monitoring can be filtered to contain only records matching peer and...
struct GNUNET_PEERSTORE_Handle * GNUNET_PEERSTORE_connect(const struct GNUNET_CONFIGURATION_Handle *cfg)
Connect to the PEERSTORE service.
void GNUNET_PEERSTORE_monitor_next(struct GNUNET_PEERSTORE_Monitor *zm, uint64_t limit)
Calls the monitor processor specified in GNUNET_PEERSTORE_monitor_start for the next record(s).
void GNUNET_PEERSTORE_hello_add_cancel(struct GNUNET_PEERSTORE_StoreHelloContext *huc)
Cancel the request to add a hello.
#define GNUNET_PEERSTORE_HELLO_KEY
Key used for storing HELLO in the peerstore.
struct GNUNET_PEERSTORE_StoreHelloContext * GNUNET_PEERSTORE_hello_add(struct GNUNET_PEERSTORE_Handle *h, const struct GNUNET_MessageHeader *msg, GNUNET_PEERSTORE_Continuation cont, void *cont_cls)
Add hello to peerstore.
enum GNUNET_GenericReturnValue GNUNET_PROGRAM_run(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, const char *binaryName, const char *binaryHelp, const struct GNUNET_GETOPT_CommandLineOption *options, GNUNET_PROGRAM_Main task, void *task_cls)
Run a standard GNUnet command startup sequence (initialize loggers and configuration,...
Definition program.c:407
#define GNUNET_MESSAGE_TYPE_HELLO_URI
Latest HELLO messages used for communicating peer addresses.
void GNUNET_SCHEDULER_shutdown(void)
Request the shutdown of a scheduler.
Definition scheduler.c:567
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_shutdown(GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run on shutdown, that is when a CTRL-C signal is received,...
Definition scheduler.c:1339
void * GNUNET_SCHEDULER_cancel(struct GNUNET_SCHEDULER_Task *task)
Cancel the task with the specified identifier.
Definition scheduler.c:980
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_now(GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run as soon as possible.
Definition scheduler.c:1304
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_delayed(struct GNUNET_TIME_Relative delay, GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run with a specified delay.
Definition scheduler.c:1277
struct GNUNET_STATISTICS_Handle * GNUNET_STATISTICS_create(const char *subsystem, const struct GNUNET_CONFIGURATION_Handle *cfg)
Get handle for the statistics service.
void GNUNET_STATISTICS_set(struct GNUNET_STATISTICS_Handle *handle, const char *name, uint64_t value, int make_persistent)
Set statistic value for the peer.
void GNUNET_STATISTICS_update(struct GNUNET_STATISTICS_Handle *handle, const char *name, int64_t delta, int make_persistent)
Set statistic value for the peer.
void GNUNET_STATISTICS_destroy(struct GNUNET_STATISTICS_Handle *h, int sync_first)
Destroy a handle (free all state associated with it).
struct GNUNET_TIME_Relative GNUNET_TIME_relative_min(struct GNUNET_TIME_Relative t1, struct GNUNET_TIME_Relative t2)
Return the minimum of two relative time values.
Definition time.c:344
#define GNUNET_TIME_UNIT_FOREVER_REL
Constant used to specify "forever".
#define GNUNET_TIME_UNIT_SECONDS
One second.
struct GNUNET_TIME_Relative GNUNET_TIME_absolute_get_remaining(struct GNUNET_TIME_Absolute future)
Given a timestamp in the future, how much time remains until then?
Definition time.c:406
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get(void)
Get the current time.
Definition time.c:111
struct GNUNET_TIME_Absolute GNUNET_TIME_relative_to_absolute(struct GNUNET_TIME_Relative rel)
Convert relative time to an absolute time in the future.
Definition time.c:316
#define GNUNET_TIME_absolute_cmp(t1, op, t2)
Compare two absolute times.
static unsigned int size
Size of the "table".
Definition peer.c:68
#define _(String)
GNU gettext support macro.
Definition platform.h:179
static struct GNUNET_MQ_Handle * mq
Our connection to the resolver service, created on-demand, but then persists until error or shutdown.
Closure for find_advertisable_hello().
size_t max_size
Maximum HELLO size we can use right now.
struct Peer * peer
Peer we want to advertise to.
struct GNUNET_TIME_Relative next_adv
struct Peer * result
Where to store the result (peer selected for advertising).
32-bit bandwidth used for network exchange by GNUnet, in bytes per second.
uint32_t value__
The actual value (bytes per second).
Internal representation of the hash map.
Context for the core service connection.
Definition core_api.c:78
Gnunet service info - identifying compatibility with a range of version of a service communicating ov...
enum GNUNET_CORE_Service service
Identifier of the service on top of CORE.
Definition of a command line option.
Context for parsing HELLOs.
Definition hello-uri.c:232
A 512-bit hashcode.
Handle to a message queue.
Definition mq.c:87
Message handler for a specific message type.
Header for all communications.
Handle to the PEERSTORE service.
Context for a add hello uri request.
A handle for the PILS service.
Definition pils_api.c:82
The identity of the host (wraps the signing key of the peer).
Entry in list of pending tasks.
Definition scheduler.c:136
Handle for the service.
Time for absolute times used by GNUnet, in microseconds.
Time for relative time used by GNUnet, in microseconds.
uint64_t rel_value_us
The actual value.
Handle to the TRANSPORT subsystem for application management.
Handle for TRANSPORT address suggestion requests.
Record for neighbours and blacklisted peers.
struct GNUNET_PeerIdentity pid
Which peer is this entry about?
struct GNUNET_MessageHeader * hello
Pointer to the hello uri of this peer; can be NULL.
struct GNUNET_TIME_Absolute next_hello_allowed
Next time we are allowed to transmit a HELLO to this peer?
struct GNUNET_CONTAINER_BloomFilter * filter
Bloom filter used to mark which peers already got the HELLO from this peer.
struct GNUNET_SCHEDULER_Task * hello_delay_task
ID of task we use to wait for the time to send the next HELLO to this peer.
struct GNUNET_TIME_Absolute filter_expiration
When should we reset the bloom filter of this entry?
struct GNUNET_TRANSPORT_ApplicationSuggestHandle * ash
Transport suggest handle.
uint32_t strength
How much would we like to connect to this peer?
struct GNUNET_MQ_Handle * mq
Our handle for transmitting to this peer; NULL if peer is not connected.
Context for a add hello uri request.
struct GNUNET_PEERSTORE_StoreHelloContext * sc
Store hello ctx.
struct StoreHelloEntry * prev
Kept (also) in a DLL.
struct StoreHelloEntry * next
Kept (also) in a DLL.