* Functionality
** Not implemented
- reading config file
-- server fail over
- resending packets
+- custom allocation scheme used in all places
+- callbacks invoked properly
+- server fail over
- matching responses
-- TLS, DTLS
+- TLS
- TLS PSK
- autoconf/automake/libtool
+- DTLS
** Not tested
- short read
- short write
-CFLAGS = -Wall -g -I ../include
+SPECIAL = # -DUSE_REQUEST_OBJECT
+
+CFLAGS = -Wall -g -I ../include $(SPECIAL)
HFILES = ../include/radsec/radsec.h ../include/radsec/radsec-impl.h
#include <event2/event.h>
#include <freeradius/libradius.h>
#include <radsec/radsec.h>
+#if defined(USE_REQUEST_OBJECT)
+#include <radsec/request.h>
+#endif
#define SECRET "sikrit"
#define USER_NAME "bob"
return rs_conn_err_pop (conn);
if (rs_conn_add_server (conn, &server, RS_CONN_TYPE_UDP, srvname, srvport))
return rs_conn_err_pop (conn);
- rs_server_set_timeout (server, 10);
+ rs_server_set_timeout (server, 1);
rs_server_set_tries (server, 3);
rs_server_set_secret (server, SECRET);
if (rs_packet_create_acc_request (conn, &req, USER_NAME, USER_PW))
return rs_conn_err_pop (conn);
+#if !defined(USE_REQUEST_OBJECT)
if (rs_packet_send (req, NULL))
return rs_conn_err_pop (conn);
req = NULL;
-
if (rs_conn_receive_packet (conn, &resp))
return rs_conn_err_pop (conn);
+#else
+ {
+ struct rs_request *request;
+
+ if (rs_request_new (conn, &request))
+ return rs_conn_err_pop (conn);
+ if (rs_req_send (request, req, &resp))
+ return rs_conn_err_pop (conn);
+ rs_request_destroy (request);
+ }
+#endif /* !defined(USE_REQUEST_OBJECT) */
+
fr_pkt = rs_packet_frpkt (resp);
fr_vp = fr_pkt->vps; /* FIXME: Is there an accessor? */
vp_printlist(stdout, fr_vp);
--- /dev/null
+/* See the file COPYING for licensing information. */
+
+struct rs_request
+{
+ struct rs_connection *conn;
+ struct event *timer;
+ struct rs_packet *req;
+ struct rs_packet *resp;
+ struct rs_conn_callbacks saved_cb;
+};
--- /dev/null
+/* See the file COPYING for licensing information. */
+
+struct rs_request;
+
+int rs_req_create(struct rs_connection *conn, struct rs_request **req_out);
+void rs_req_destroy(struct rs_request *request);
+int rs_req_send(struct rs_request *request, struct rs_packet *req, struct rs_packet **resp);
void
rs_packet_destroy(struct rs_packet *pkt)
{
- rad_free (&pkt->rpkt);
- rs_free (pkt->conn->ctx, pkt);
+ if (pkt)
+ {
+ rad_free (&pkt->rpkt);
+ rs_free (pkt->conn->ctx, pkt);
+ }
}
--- /dev/null
+/* See the file COPYING for licensing information. */
+
+#include <time.h>
+#include <event2/event.h>
+#include <radsec/radsec.h>
+#include <radsec/radsec-impl.h>
+#include <radsec/request.h>
+#include <radsec/request-impl.h>
+
+int
+rs_req_create (struct rs_connection *conn, struct rs_request **req_out)
+{
+ struct rs_request *req = rs_malloc (conn->ctx, sizeof(*req));
+ if (!req)
+ return rs_conn_err_push_fl (conn, RSE_NOMEM, __FILE__, __LINE__, NULL);
+ memset (req, 0, sizeof(*req));
+ req->conn = conn;
+ *req_out = req;
+ return RSE_OK;
+}
+
+void
+rs_req_destroy(struct rs_request *request)
+{
+ rs_packet_destroy (request->req);
+ rs_packet_destroy (request->resp);
+ rs_free (request->conn->ctx, request);
+}
+
+#if 0
+static void
+_timer_cb(evutil_socket_t fd, short what, void *arg)
+
+{
+}
+#endif
+
+int
+rs_req_send(struct rs_request *request, struct rs_packet *req,
+ struct rs_packet **resp)
+{
+ /* install our own callback, backing up any user provided one in
+ req->saved_cb*/
+
+ return -1;
+}