2 This file is part of GNUnet.
3 Copyright (C) 2009-2013, 2016, 2018 GNUnet e.V.
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.
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.
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/>.
20 * @brief shared data structures of libgnunetgns
21 * @author Martin Schanzenbach
22 * @author Christian Grothoff
27 #include "gnunet_gns_service.h"
31 * Connection to the GNS service.
33 struct GNUNET_GNS_Handle
37 * Configuration to use.
39 const struct GNUNET_CONFIGURATION_Handle *cfg;
42 * Connection to service (if available).
44 struct GNUNET_MQ_Handle *mq;
47 * Head of linked list of active lookup requests.
49 struct GNUNET_GNS_LookupRequest *lookup_head;
52 * Tail of linked list of active lookup requests.
54 struct GNUNET_GNS_LookupRequest *lookup_tail;
59 struct GNUNET_SCHEDULER_Task *reconnect_task;
62 * How long do we wait until we try to reconnect?
64 struct GNUNET_TIME_Relative reconnect_backoff;
67 * Request Id generator. Incremented by one for each request.