2 This file is part of GNUnet.
3 (C) 2010 Christian Grothoff (and other contributing authors)
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 2, 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., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA.
22 * @file transport/gnunet-service-transport_blacklist.h
23 * @brief internal API for blacklisting functionality
24 * @author Christian Grothoff
26 #ifndef GNUNET_SERVICE_TRANSPORT_BLACKLIST_H
27 #define GNUNET_SERVICE_TRANSPORT_BLACKLIST_H
29 #include "gnunet_protocols.h"
30 #include "gnunet_service_lib.h"
31 #include "transport.h"
34 * Handle a request to blacklist a peer.
36 * @param cls closure (always NULL)
37 * @param client identification of the client
38 * @param message the actual message
41 GNUNET_TRANSPORT_handle_blacklist (void *cls,
42 struct GNUNET_SERVER_Client *client,
43 const struct GNUNET_MessageHeader *message);
47 * Handle a request for notification of blacklist changes.
49 * @param cls closure (always NULL)
50 * @param client identification of the client
51 * @param message the actual message
54 GNUNET_TRANSPORT_handle_blacklist_notify (void *cls,
55 struct GNUNET_SERVER_Client *client,
56 const struct GNUNET_MessageHeader *message);
60 * Is the given peer currently blacklisted?
62 * @param id identity of the peer
63 * @return GNUNET_YES if the peer is blacklisted, GNUNET_NO if not
66 GNUNET_TRANSPORT_blacklist_check (const struct GNUNET_PeerIdentity *id);
70 * Initialize the blacklisting subsystem.
72 * @param server server we handle requests from (transport service server)
73 * @param s scheduler to use
76 GNUNET_TRANSPORT_blacklist_init (struct GNUNET_SERVER_Handle *server,
77 struct GNUNET_SCHEDULER_Handle *s);
81 /* end of gnunet-service-transport_blacklist.h */