/*
- * Copyright (C) 2005-2006 Andre Noll <maan@systemlinux.org>
+ * Copyright (C) 2005-2007 Andre Noll <maan@systemlinux.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
#include "error.h"
-/** \cond holds information about one encrypted connection */
+/** holds information about one encrypted connection */
struct crypt_data {
+ /** function used to decrypt received data */
crypt_function *recv;
+ /** function used to encrypt data to be sent */
crypt_function *send;
+ /** context-dependent data, passed to \a recv() and \a send() */
void *private_data;
};
-static unsigned cda_size = 0;
+/** array holding per fd crypt data per */
static struct crypt_data *crypt_data_array;
-/** \endcond */
+/** current size of the crypt data array */
+static unsigned cda_size = 0;
/**
* Receive at most \a size bytes from filedescriptor fd. If encryption is
* available, decrypt the received buffer.
*
- * \return the number of bytes received on success. On receive errors, -E_RECV
+ * \return The number of bytes received on success. On receive errors, -E_RECV
* is returned. On crypt errors, the corresponding crypt error number is
* returned.
*
* Read and decrypt at most \a size - 1 bytes from file descriptor \a fd and
* write a NULL byte at the end of the received data.
*
-*/
+ * \return: The return value of the underlying call to \a recv_bin_buffer().
+ *
+ * \sa recv_bin_buffer()
+ */
int recv_buffer(int fd, char *buf, ssize_t size)
{
int n;
* \param their_addr the address to connect
*
* \return \p -E_CONNECT on errors, 1 on success
+ *
* \sa connect(2)
*/
int para_connect(int fd, struct sockaddr_in *their_addr)
* \param addr structure which is filled in with the address of the peer socket
* \param size should contain the size of the structure pointed to by \a addr
*
+ * Accept incoming connections on \a addr. Retry if interrupted.
+ *
+ * \return The new file descriptor on success, \a -E_ACCEPT on errors.
+ *
* \sa accept(2).
*/
int para_accept(int fd, void *addr, socklen_t size)
{
int new_fd;
- do
+ do
new_fd = accept(fd, (struct sockaddr *) addr, &size);
while (new_fd < 0 && errno == EINTR);
return new_fd < 0? -E_ACCEPT : new_fd;
*
* This functions creates a local socket for sequenced, reliable,
* two-way, connection-based byte streams.
+ *
+ * \return The file descriptor, on success, negative on errors.
+ *
* \sa socket(2)
* \sa bind(2)
* \sa chmod(2)
*
* \return On success, this call returns the number of characters sent. On
* error, \p -E_SENDMSG ist returned.
+ *
* \sa okir's Black Hats Manual
* \sa sendmsg(2)
*/
/**
* create a socket, bind it and listen
+ *
* \param port the tcp port to listen on
*
* \return The file descriptor of the created socket, negative
* to receive at most \a bufsize bytes from file descriptor \a fd.
* If at least \p strlen(\a pattern) bytes were received, the beginning of
* the received buffer is compared with \a pattern, ignoring case.
+ *
* \sa recv_buffer()
* \sa strncasecmp(3)
*/