miniupnp/miniupnpd/upnputils.h

69 lines
1.6 KiB
C
Raw Normal View History

/* $Id: upnputils.h,v 1.9 2018/03/13 10:25:20 nanard Exp $ */
2011-09-28 19:13:20 +00:00
/* MiniUPnP project
* http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/
* (c) 2011-2018 Thomas Bernard
2011-09-28 19:13:20 +00:00
* This software is subject to the conditions detailed
* in the LICENCE file provided within the distribution */
#ifndef UPNPUTILS_H_INCLUDED
#define UPNPUTILS_H_INCLUDED
2011-09-28 19:13:20 +00:00
/**
* convert a struct sockaddr to a human readable string.
* [ipv6]:port or ipv4:port
* return the number of characters used (as snprintf)
*/
int
sockaddr_to_string(const struct sockaddr * addr, char * str, size_t size);
/**
* set the file description as non blocking
* return 0 in case of failure, 1 in case of success
*/
int
set_non_blocking(int fd);
/**
* get the LAN which the peer belongs to
*/
struct lan_addr_s *
get_lan_for_peer(const struct sockaddr * peer);
/**
* get the time for upnp (release expiration, etc.)
* Similar to a monotonic time(NULL)
*/
time_t upnp_time(void);
/**
* return either the machine or the daemon uptime
*/
time_t upnp_get_uptime(void);
2014-04-01 09:44:39 +00:00
/**
* define portability macros
*/
#if defined(__sun)
2016-11-11 14:42:22 +00:00
static __inline size_t _sa_len(const struct sockaddr *addr)
2014-04-01 09:44:39 +00:00
{
if (addr->sa_family == AF_INET)
return (sizeof(struct sockaddr_in));
else if (addr->sa_family == AF_INET6)
return (sizeof(struct sockaddr_in6));
else
return (sizeof(struct sockaddr));
}
# define SA_LEN(sa) (_sa_len(sa))
#else
#if !defined(SA_LEN)
# define SA_LEN(sa) ((sa)->sa_len)
#endif
#endif
#ifndef MAX
# define MAX(a,b) (((a)>(b))?(a):(b))
#endif
2011-09-28 19:13:20 +00:00
#endif