#include <sys/types.h>
#include <sys/socket.h>
#include <sys/stat.h>
+#include <sys/un.h>
#include <netinet/in.h>
#include <unistd.h>
#include <fcntl.h>
struct sockaddr sa;
struct sockaddr_in in4;
struct sockaddr_in6 in6;
+ struct sockaddr_un un;
+ /** Return the family of the socket (e.g. AF_INET). */
+ int family() const;
/** Return the size of the structure for syscall passing */
- int sa_size() const;
+ socklen_t sa_size() const;
/** Return port number or -1 if invalid */
int port() const;
/** Return IP only */
/** Construct a CIDR mask from the string. Will normalize (127.0.0.1/8 => 127.0.0.0/8). */
cidr_mask(const std::string& mask);
/** Construct a CIDR mask of a given length from the given address */
- cidr_mask(const irc::sockets::sockaddrs& addr, int len);
+ cidr_mask(const irc::sockets::sockaddrs& addr, unsigned char len);
/** Equality of bits, type, and length */
bool operator==(const cidr_mask& other) const;
/** Ordering defined for maps */
* @return true if the conversion was successful, false if not.
*/
CoreExport bool aptosa(const std::string& addr, int port, irc::sockets::sockaddrs& sa);
+
+ /** Convert a UNIX socket path to a binary sockaddr.
+ * @param path The path to the UNIX socket.
+ * @param sa The structure to place the result in. Will be zeroed prior to conversion.
+ * @return True if the conversion was successful; otherwise, false.
+ */
+ CoreExport bool untosa(const std::string& path, irc::sockets::sockaddrs& sa);
}
}
+/** A list of failed port bindings, used for informational purposes on startup */
+typedef std::vector<std::pair<irc::sockets::sockaddrs, int> > FailedPortList;
+
#include "socketengine.h"
/** This class handles incoming connections on client ports.
* It will create a new User for every valid connection