2 Unix SMB/CIFS implementation.
3 Utility functions for Samba
4 Copyright (C) Andrew Tridgell 1992-1999
5 Copyright (C) Jelmer Vernooij 2005
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>.
21 #ifndef _SAMBA_UTIL_NET_H_
22 #define _SAMBA_UTIL_NET_H_
24 #include "system/network.h"
26 struct samba_sockaddr
{
30 struct sockaddr_in in
;
32 struct sockaddr_in6 in6
;
34 struct sockaddr_un un
;
35 struct sockaddr_storage ss
;
39 /* The following definitions come from lib/util/util_net.c */
41 void zero_sockaddr(struct sockaddr_storage
*pss
);
43 bool interpret_string_addr_internal(struct addrinfo
**ppres
,
44 const char *str
, int flags
);
46 bool interpret_string_addr(struct sockaddr_storage
*pss
,
50 /*******************************************************************
51 Map a text hostname or IP address (IPv4 or IPv6) into a
52 struct sockaddr_storage. Version that prefers IPv4.
53 ******************************************************************/
55 bool interpret_string_addr_prefer_ipv4(struct sockaddr_storage
*pss
,
59 void set_sockaddr_port(struct sockaddr
*psa
, uint16_t port
);
62 Check if an IP is the 0.0.0.0.
64 _PUBLIC_
bool is_zero_ip_v4(struct in_addr ip
);
66 void in_addr_to_sockaddr_storage(struct sockaddr_storage
*ss
,
68 #if defined(HAVE_IPV6)
70 * Convert an IPv6 struct in_addr to a struct sockaddr_storage.
72 void in6_addr_to_sockaddr_storage(struct sockaddr_storage
*ss
,
76 Are two IPs on the same subnet?
78 _PUBLIC_
bool same_net_v4(struct in_addr ip1
,struct in_addr ip2
,struct in_addr mask
);
81 Return true if a string could be a pure IP address.
83 _PUBLIC_
bool is_ipaddress(const char *str
);
85 bool is_broadcast_addr(const struct sockaddr
*pss
);
86 bool is_loopback_ip_v4(struct in_addr ip
);
87 bool is_loopback_addr(const struct sockaddr
*pss
);
88 bool is_zero_addr(const struct sockaddr_storage
*pss
);
89 void zero_ip_v4(struct in_addr
*ip
);
90 bool is_linklocal_addr(const struct sockaddr_storage
*pss
);
92 Interpret an internet address or name into an IP address in 4 byte form.
94 _PUBLIC_
uint32_t interpret_addr(const char *str
);
97 A convenient addition to interpret_addr().
99 _PUBLIC_
struct in_addr
interpret_addr2(const char *str
);
101 _PUBLIC_
bool is_ipaddress_v4(const char *str
);
102 _PUBLIC_
bool is_ipv6_literal(const char *str
);
103 _PUBLIC_
bool is_ipaddress_v6(const char *str
);
105 bool is_address_any(const struct sockaddr
*psa
);
106 bool same_net(const struct sockaddr
*ip1
,
107 const struct sockaddr
*ip2
,
108 const struct sockaddr
*mask
);
109 bool sockaddr_equal(const struct sockaddr
*ip1
,
110 const struct sockaddr
*ip2
);
112 bool is_address_any(const struct sockaddr
*psa
);
113 uint16_t get_sockaddr_port(const struct sockaddr_storage
*pss
);
114 char *print_sockaddr_len(char *dest
,
116 const struct sockaddr
*psa
,
118 char *print_sockaddr(char *dest
,
120 const struct sockaddr_storage
*psa
);
121 char *print_canonical_sockaddr(TALLOC_CTX
*ctx
,
122 const struct sockaddr_storage
*pss
);
124 void set_socket_options(int fd
, const char *options
);
126 bool sockaddr_storage_to_samba_sockaddr(
127 struct samba_sockaddr
*sa
, const struct sockaddr_storage
*ss
);
128 bool samba_sockaddr_set_port(struct samba_sockaddr
*sa
, uint16_t port
);
129 bool samba_sockaddr_get_port(const struct samba_sockaddr
*sa
, uint16_t *port
);
132 * check for POLLERR or POLL*HUP
134 int samba_socket_poll_error(int fd
);
136 * getsockopt(fd, SOL_SOCKET, SO_ERROR, &error, &len)
138 int samba_socket_sock_error(int fd
);
140 * check for POLL*HUP and fallback to
141 * getsockopt(fd, SOL_SOCKET, SO_ERROR, &error, &len)
143 int samba_socket_poll_or_sock_error(int fd
);
145 #endif /* _SAMBA_UTIL_NET_H_ */