2 This file is part of GNUnet.
3 Copyright (C) 2009 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/>.
18 SPDX-License-Identifier: AGPL3.0-or-later
22 * @author Christian Grothoff
28 #include "gnunet_common.h"
31 * This option will turn on the DEBUG loglevel for
32 * all processes controlled by this ARM!
34 #define DEBUG_ARM GNUNET_EXTRA_LOGGING
36 GNUNET_NETWORK_STRUCT_BEGIN
39 * Status update from ARM to client.
41 struct GNUNET_ARM_StatusMessage {
43 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_STATUS.
45 struct GNUNET_MessageHeader header;
48 * Status from the 'enum GNUNET_ARM_ServiceStatus'
52 /* followed by a 0-terminated service name */
55 struct GNUNET_ARM_Message {
57 * Reply to client, type is #GNUNET_MESSAGE_TYPE_ARM_RESULT or
58 * #GNUNET_MESSAGE_TYPE_ARM_LIST_RESULT.
60 * Request from client, type is #GNUNET_MESSAGE_TYPE_ARM_START or
61 * #GNUNET_MESSAGE_TYPE_ARM_STOP.
63 struct GNUNET_MessageHeader header;
71 * ID of a request that is being replied to.
73 * ID of a request that is being sent.
77 /* For requests - followed by a 0-terminated service name */
82 * Reply from ARM to client.
84 struct GNUNET_ARM_ResultMessage {
86 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_RESULT, with an ID.
88 struct GNUNET_ARM_Message arm_msg;
91 * Result from the `enum GNUNET_ARM_Result`
96 struct GNUNET_ARM_ServiceInfoMessage {
98 * String pool index for the service's name.
103 * String pool index for the service's binary.
105 uint16_t binary_index;
108 * Last process exit status.
110 int16_t last_exit_status;
118 * Status from the 'enum GNUNET_ARM_ServiceStatus'
123 * Time when the sevice will be restarted, if applicable
124 * to the current status.
126 struct GNUNET_TIME_AbsoluteNBO restart_at;
129 * Time when the sevice was first started, if applicable.
131 struct GNUNET_TIME_AbsoluteNBO last_started_at;
135 * Reply from ARM to client for the
136 * #GNUNET_MESSAGE_TYPE_ARM_LIST request followed by count
137 * '\0' terminated strings. header->size contains the
138 * total size (including all strings).
140 struct GNUNET_ARM_ListResultMessage {
142 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_LIST_RESULT,
145 struct GNUNET_ARM_Message arm_msg;
148 * Number of 'struct GNUNET_ARM_ServiceInfoMessage' that
149 * are at the end of this message.
153 /* struct GNUNET_ARM_ServiceInfoMessage[count]; */
154 /* pool of 0-terminated strings */
157 GNUNET_NETWORK_STRUCT_END