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
44 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_STATUS.
46 struct GNUNET_MessageHeader header;
49 * Status from the 'enum GNUNET_ARM_ServiceStatus'
53 /* followed by a 0-terminated service name */
56 struct GNUNET_ARM_Message
59 * Reply to client, type is #GNUNET_MESSAGE_TYPE_ARM_RESULT or
60 * #GNUNET_MESSAGE_TYPE_ARM_LIST_RESULT.
62 * Request from client, type is #GNUNET_MESSAGE_TYPE_ARM_START or
63 * #GNUNET_MESSAGE_TYPE_ARM_STOP.
65 struct GNUNET_MessageHeader header;
73 * ID of a request that is being replied to.
75 * ID of a request that is being sent.
79 /* For requests - followed by a 0-terminated service name */
84 * Reply from ARM to client.
86 struct GNUNET_ARM_ResultMessage
89 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_RESULT, with an ID.
91 struct GNUNET_ARM_Message arm_msg;
94 * Result from the `enum GNUNET_ARM_Result`
99 struct GNUNET_ARM_ServiceInfoMessage
102 * String pool index for the service's name.
107 * String pool index for the service's binary.
109 uint16_t binary_index;
112 * Last process exit status.
114 int16_t last_exit_status;
122 * Status from the 'enum GNUNET_ARM_ServiceStatus'
127 * Time when the sevice will be restarted, if applicable
128 * to the current status.
130 struct GNUNET_TIME_AbsoluteNBO restart_at;
133 * Time when the sevice was first started, if applicable.
135 struct GNUNET_TIME_AbsoluteNBO last_started_at;
139 * Reply from ARM to client for the
140 * #GNUNET_MESSAGE_TYPE_ARM_LIST request followed by count
141 * '\0' terminated strings. header->size contains the
142 * total size (including all strings).
144 struct GNUNET_ARM_ListResultMessage
147 * Reply to client, of type is #GNUNET_MESSAGE_TYPE_ARM_LIST_RESULT,
150 struct GNUNET_ARM_Message arm_msg;
153 * Number of 'struct GNUNET_ARM_ServiceInfoMessage' that
154 * are at the end of this message.
158 /* struct GNUNET_ARM_ServiceInfoMessage[count]; */
159 /* pool of 0-terminated strings */
162 GNUNET_NETWORK_STRUCT_END