2 This file is part of GNUnet.
3 Copyright (C) 2007, 2008, 2009, 2016 GNUnet e.V.
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.
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.
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., 51 Franklin Street, Fifth Floor,
18 Boston, MA 02110-1301, USA.
23 #include "gnunet_util_lib.h"
24 #include "gnunet_protocols.h"
27 static int special_ret = 0;
30 * Handler for STOP message.
32 * @param cls client identification of the client
33 * @param message the actual message
36 handle_stop (void *cls,
37 const struct GNUNET_MessageHeader *message)
39 struct GNUNET_SERVICE_Client *client = cls;
41 GNUNET_log (GNUNET_ERROR_TYPE_INFO,
42 _("Initiating shutdown as requested by client.\n"));
43 GNUNET_SERVICE_client_persist (client);
44 GNUNET_SCHEDULER_shutdown ();
45 /* ARM won't exponentially increase restart delay if we
46 * terminate normally. This changes the return code.
53 * Callback called when a client connects to the service.
55 * @param cls closure for the service
56 * @param c the new client that connected to the service
57 * @param mq the message queue used to send messages to the client
61 client_connect_cb (void *cls,
62 struct GNUNET_SERVICE_Client *c,
63 struct GNUNET_MQ_Handle *mq)
70 * Callback called when a client disconnected from the service
72 * @param cls closure for the service
73 * @param c the client that disconnected
74 * @param internal_cls should be equal to @a c
77 client_disconnect_cb (void *cls,
78 struct GNUNET_SERVICE_Client *c,
81 GNUNET_assert (c == internal_cls);
87 const struct GNUNET_CONFIGURATION_Handle *cfg,
88 struct GNUNET_SERVICE_Handle *service)
95 * Define "main" method using service macro.
99 GNUNET_SERVICE_OPTION_NONE,
102 &client_disconnect_cb,
104 GNUNET_MQ_hd_fixed_size (stop,
105 GNUNET_MESSAGE_TYPE_ARM_STOP,
106 struct GNUNET_MessageHeader,
108 GNUNET_MQ_handler_end ());
112 * MINIMIZE heap size (way below 128k) since this process doesn't need much.
114 void __attribute__ ((destructor))
115 GNUNET_mockup_done ()