adding capabilities
[oweals/gnunet.git] / src / experimentation / gnunet-daemon-experimentation.h
1 /*
2      This file is part of GNUnet.
3      (C) 2009 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 experimentation/gnunet-daemon-experimentation.h
23  * @brief experimentation daemon
24  * @author Christian Grothoff
25  * @author Matthias Wachs
26  */
27 #include "platform.h"
28 #include "gnunet_getopt_lib.h"
29 #include "gnunet_util_lib.h"
30 #include "gnunet_core_service.h"
31 #include "gnunet_statistics_service.h"
32
33
34 /**
35  * Timeout between request and expected response
36  */
37 #define EXP_RESPONSE_TIMEOUT GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, 10)
38
39 extern struct GNUNET_STATISTICS_Handle *GSE_stats;
40
41 extern struct GNUNET_CONFIGURATION_Handle *GSE_cfg;
42
43 /**
44  * A experimentation node
45  */
46 struct Node
47 {
48         /**
49          * Peer id
50          */
51         struct GNUNET_PeerIdentity id;
52
53         /**
54          * Task for response timeout
55          */
56         GNUNET_SCHEDULER_TaskIdentifier timeout_task;
57
58         /**
59          * Core transmission handle
60          */
61         struct GNUNET_CORE_TransmitHandle *cth;
62 };
63
64 /**
65  * Experimentation request message
66  * Used to detect experimentation capability
67  */
68 struct Experimentation_Request
69 {
70         struct GNUNET_MessageHeader msg;
71 };
72
73 /**
74  * Experimentation response message
75  * Sent if peer is running the daemon
76  */
77 struct Experimentation_Response
78 {
79         struct GNUNET_MessageHeader msg;
80 };
81
82
83 /**
84  * Start the nodes management
85  */
86 void
87 GNUNET_EXPERIMENTATION_nodes_start ();
88
89
90 /**
91  * Stop the nodes management
92  */
93 void
94 GNUNET_EXPERIMENTATION_nodes_stop ();
95
96
97 /**
98  * Start the detecting capabilities
99  */
100 void
101 GNUNET_EXPERIMENTATION_capabilities_start ();
102
103 /**
104  * Stop the detecting capabilities
105  */
106 void
107 GNUNET_EXPERIMENTATION_capabilities_stop ();
108
109
110 /* end of gnunet-daemon-experimentation.h */