2 This file is part of GNUnet.
3 (C) 2009, 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 core/core_api_peer_request.c
23 * @brief implementation of the peer_request functions
24 * @author Christian Grothoff
27 #include "gnunet_core_service.h"
32 * Handle for a request to the core to connect to
33 * a particular peer. Can be used to cancel the request
34 * (before the 'cont'inuation is called).
36 struct GNUNET_CORE_PeerRequestHandle
40 * Our connection to the service.
42 struct GNUNET_CLIENT_Connection *client;
47 struct GNUNET_SCHEDULER_Handle *sched;
50 * Function to call once done.
52 GNUNET_SCHEDULER_Task cont;
62 struct GNUNET_TIME_Absolute timeout;
65 * Identity of the peer to connect to.
67 struct GNUNET_PeerIdentity peer;
70 * Message type to use.
77 * Transmit the request to the core service.
79 * @param cls our 'struct GNUNET_CORE_PeerRequestHandle'
80 * @param size number of bytes available in buf
81 * @param buf where the callee should write the message
82 * @return number of bytes written to buf
85 send_request (void *cls,
89 struct GNUNET_CORE_PeerRequestHandle * prh = cls;
90 struct ConnectMessage msg;
94 GNUNET_SCHEDULER_add_continuation (prh->sched,
97 GNUNET_SCHEDULER_REASON_TIMEOUT);
98 GNUNET_CLIENT_disconnect (prh->client, GNUNET_NO);
102 GNUNET_assert (size >= sizeof (struct ConnectMessage));
103 msg.header.type = htons (prh->type);
104 msg.header.size = htons (sizeof (struct ConnectMessage));
105 msg.reserved = htonl (0);
106 msg.timeout = GNUNET_TIME_relative_hton (GNUNET_TIME_absolute_get_remaining (prh->timeout));
107 msg.peer = prh->peer;
108 memcpy (buf, &msg, sizeof (msg));
109 GNUNET_SCHEDULER_add_continuation (prh->sched,
112 GNUNET_SCHEDULER_REASON_PREREQ_DONE);
113 GNUNET_CLIENT_disconnect (prh->client, GNUNET_YES);
120 * Request that the core should try to connect to a particular peer.
121 * Once the request has been transmitted to the core, the continuation
122 * function will be called. Note that this does NOT mean that a
123 * connection was successfully established -- it only means that the
124 * core will now try. Successful establishment of the connection
125 * will be signalled to the 'connects' callback argument of
126 * 'GNUNET_CORE_connect' only. If the core service does not respond
127 * to our connection attempt within the given time frame, 'cont' will
128 * be called with the TIMEOUT reason code.
130 * @param sched scheduler to use
131 * @param cfg configuration to use
132 * @param timeout how long to try to talk to core
133 * @param peer who should we connect to
134 * @param cont function to call once the request has been completed (or timed out)
135 * @param cont_cls closure for cont
136 * @return NULL on error (cont will not be called), otherwise handle for cancellation
138 struct GNUNET_CORE_PeerRequestHandle *
139 GNUNET_CORE_peer_request_connect (struct GNUNET_SCHEDULER_Handle *sched,
140 const struct GNUNET_CONFIGURATION_Handle *cfg,
141 struct GNUNET_TIME_Relative timeout,
142 const struct GNUNET_PeerIdentity * peer,
143 GNUNET_SCHEDULER_Task cont,
146 struct GNUNET_CORE_PeerRequestHandle *ret;
147 struct GNUNET_CLIENT_Connection *client;
149 client = GNUNET_CLIENT_connect (sched, "core", cfg);
152 ret = GNUNET_malloc (sizeof (struct GNUNET_CORE_PeerRequestHandle));
153 ret->client = client;
156 ret->cont_cls = cont_cls;
158 ret->type = GNUNET_MESSAGE_TYPE_CORE_REQUEST_CONNECT;
159 ret->timeout = GNUNET_TIME_relative_to_absolute (timeout);
160 GNUNET_CLIENT_notify_transmit_ready (client,
161 sizeof (struct ConnectMessage),
171 * Cancel a pending request to connect to a particular peer. Must not
172 * be called after the 'cont' function was invoked.
174 * @param req request handle that was returned for the original request
177 GNUNET_CORE_peer_request_connect_cancel (struct GNUNET_CORE_PeerRequestHandle *req)
179 GNUNET_CLIENT_disconnect (req->client, GNUNET_NO);
184 /* end of core_api_peer_request.c */