aboutsummaryrefslogtreecommitdiff
path: root/src/gns/gns_api.h
diff options
context:
space:
mode:
authorChristian Grothoff <christian@grothoff.org>2018-03-05 23:10:22 +0100
committerChristian Grothoff <christian@grothoff.org>2018-03-05 23:10:22 +0100
commit8bd2218151fa06cd6209a575e3000b74616c4f02 (patch)
tree5f630db6b9b409a8930761811248b0b58479d4e2 /src/gns/gns_api.h
parent37f62bb432a79506cffaa1663e5e1bd6b6c96bea (diff)
downloadgnunet-8bd2218151fa06cd6209a575e3000b74616c4f02.tar.gz
gnunet-8bd2218151fa06cd6209a575e3000b74616c4f02.zip
adding missing/forgotten files
Diffstat (limited to 'src/gns/gns_api.h')
-rw-r--r--src/gns/gns_api.h76
1 files changed, 76 insertions, 0 deletions
diff --git a/src/gns/gns_api.h b/src/gns/gns_api.h
new file mode 100644
index 000000000..e4912338f
--- /dev/null
+++ b/src/gns/gns_api.h
@@ -0,0 +1,76 @@
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2009-2013, 2016, 2018 GNUnet e.V.
4
5 GNUnet is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published
7 by the Free Software Foundation; either version 3, or (at your
8 option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with GNUnet; see the file COPYING. If not, write to the
17 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18 Boston, MA 02110-1301, USA.
19*/
20/**
21 * @file gns/gns_api.h
22 * @brief shared data structures of libgnunetgns
23 * @author Martin Schanzenbach
24 * @author Christian Grothoff
25 */
26#ifndef GNS_API_H
27#define GNS_API_H
28
29#include "gnunet_gns_service.h"
30
31
32/**
33 * Connection to the GNS service.
34 */
35struct GNUNET_GNS_Handle
36{
37
38 /**
39 * Configuration to use.
40 */
41 const struct GNUNET_CONFIGURATION_Handle *cfg;
42
43 /**
44 * Connection to service (if available).
45 */
46 struct GNUNET_MQ_Handle *mq;
47
48 /**
49 * Head of linked list of active lookup requests.
50 */
51 struct GNUNET_GNS_LookupRequest *lookup_head;
52
53 /**
54 * Tail of linked list of active lookup requests.
55 */
56 struct GNUNET_GNS_LookupRequest *lookup_tail;
57
58 /**
59 * Reconnect task
60 */
61 struct GNUNET_SCHEDULER_Task *reconnect_task;
62
63 /**
64 * How long do we wait until we try to reconnect?
65 */
66 struct GNUNET_TIME_Relative reconnect_backoff;
67
68 /**
69 * Request Id generator. Incremented by one for each request.
70 */
71 uint32_t r_id_gen;
72
73};
74
75
76#endif