fix #3284: support lib/MULTIARCH/ paths in installation, use GNUNET_PREFIX=@libdir...
[oweals/gnunet.git] / src / core / gnunet-service-core.h
1 /*
2      This file is part of GNUnet.
3      (C) 2009, 2010, 2011 Christian Grothoff (and other contributing authors)
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., 59 Temple Place - Suite 330,
18      Boston, MA 02111-1307, USA.
19 */
20
21 /**
22  * @file core/gnunet-service-core.h
23  * @brief Globals for gnunet-service-core
24  * @author Christian Grothoff
25  */
26 #ifndef GNUNET_SERVICE_CORE_H
27 #define GNUNET_SERVICE_CORE_H
28
29 #include "gnunet_statistics_service.h"
30 #include "core.h"
31
32 /**
33  * Opaque handle to a client.
34  */
35 struct GSC_Client;
36
37
38 /**
39  * Record kept for each request for transmission issued by a
40  * client that is still pending. (This struct is used by
41  * both the 'CLIENTS' and 'SESSIONS' subsystems.)
42  */
43 struct GSC_ClientActiveRequest
44 {
45
46   /**
47    * Active requests are kept in a doubly-linked list of
48    * the respective target peer.
49    */
50   struct GSC_ClientActiveRequest *next;
51
52   /**
53    * Active requests are kept in a doubly-linked list of
54    * the respective target peer.
55    */
56   struct GSC_ClientActiveRequest *prev;
57
58   /**
59    * Which peer is the message going to be for?
60    */
61   struct GNUNET_PeerIdentity target;
62
63   /**
64    * Handle to the client.
65    */
66   struct GSC_Client *client_handle;
67
68   /**
69    * By what time would the client want to see this message out?
70    */
71   struct GNUNET_TIME_Absolute deadline;
72
73   /**
74    * How important is this request.
75    */
76   uint32_t priority;
77
78   /**
79    * Has this request been solicited yet?
80    */
81   int was_solicited;
82
83   /**
84    * How many bytes does the client intend to send?
85    */
86   uint16_t msize;
87
88   /**
89    * Unique request ID (in big endian).
90    */
91   uint16_t smr_id;
92
93 };
94
95
96 /**
97  * Our configuration.
98  */
99 extern const struct GNUNET_CONFIGURATION_Handle *GSC_cfg;
100
101 /**
102  * For creating statistics.
103  */
104 extern struct GNUNET_STATISTICS_Handle *GSC_stats;
105
106 /**
107  * Our identity.
108  */
109 extern struct GNUNET_PeerIdentity GSC_my_identity;
110
111
112 #endif