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.
17 * @file template/gnunet-service-template.c
18 * @brief program that does template
19 * @author Christian Grothoff
22 #include "gnunet_util_lib.h"
26 * Task run during shutdown.
31 cleanup_task (void *cls)
33 /* FIXME: do clean up here */
38 * Callback called when a client connects to the service.
40 * @param cls closure for the service
41 * @param c the new client that connected to the service
42 * @param mq the message queue used to send messages to the client
46 client_connect_cb (void *cls,
47 struct GNUNET_SERVICE_Client *c,
48 struct GNUNET_MQ_Handle *mq)
55 * Callback called when a client disconnected from the service
57 * @param cls closure for the service
58 * @param c the client that disconnected
59 * @param internal_cls should be equal to @a c
62 client_disconnect_cb (void *cls,
63 struct GNUNET_SERVICE_Client *c,
66 GNUNET_assert (c == internal_cls);
71 * Process template requests.
74 * @param cfg configuration to use
75 * @param service the initialized service
79 const struct GNUNET_CONFIGURATION_Handle *cfg,
80 struct GNUNET_SERVICE_Handle *service)
82 /* FIXME: do setup here */
83 GNUNET_SCHEDULER_add_shutdown (&cleanup_task,
89 * Define "main" method using service macro.
93 GNUNET_SERVICE_OPTION_NONE,
96 &client_disconnect_cb,
98 GNUNET_MQ_handler_end ());
101 /* end of gnunet-service-template.c */