gns_api.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /*
  2. This file is part of GNUnet.
  3. Copyright (C) 2009-2013, 2016, 2018 GNUnet e.V.
  4. GNUnet is free software: you can redistribute it and/or modify it
  5. under the terms of the GNU Affero General Public License as published
  6. by the Free Software Foundation, either version 3 of the License,
  7. or (at your option) any later version.
  8. GNUnet is distributed in the hope that it will be useful, but
  9. WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Affero General Public License for more details.
  12. You should have received a copy of the GNU Affero General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. SPDX-License-Identifier: AGPL3.0-or-later
  15. */
  16. /**
  17. * @file gns/gns_api.h
  18. * @brief shared data structures of libgnunetgns
  19. * @author Martin Schanzenbach
  20. * @author Christian Grothoff
  21. */
  22. #ifndef GNS_API_H
  23. #define GNS_API_H
  24. #include "gnunet_gns_service.h"
  25. /**
  26. * Connection to the GNS service.
  27. */
  28. struct GNUNET_GNS_Handle
  29. {
  30. /**
  31. * Configuration to use.
  32. */
  33. const struct GNUNET_CONFIGURATION_Handle *cfg;
  34. /**
  35. * Connection to service (if available).
  36. */
  37. struct GNUNET_MQ_Handle *mq;
  38. /**
  39. * Head of linked list of active lookup requests.
  40. */
  41. struct GNUNET_GNS_LookupRequest *lookup_head;
  42. /**
  43. * Tail of linked list of active lookup requests.
  44. */
  45. struct GNUNET_GNS_LookupRequest *lookup_tail;
  46. /**
  47. * Reconnect task
  48. */
  49. struct GNUNET_SCHEDULER_Task *reconnect_task;
  50. /**
  51. * How long do we wait until we try to reconnect?
  52. */
  53. struct GNUNET_TIME_Relative reconnect_backoff;
  54. /**
  55. * Request Id generator. Incremented by one for each request.
  56. */
  57. uint32_t r_id_gen;
  58. };
  59. #endif