2
* Copyright (c) 1997, 1998, 1999, 2000, 2001, 2002, 2003
3
* Inferno Nettverk A/S, Norway. All rights reserved.
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
8
* 1. The above copyright notice, this list of conditions and the following
9
* disclaimer must appear in all copies of the software, derivative works
10
* or modified versions, and any portions thereof, aswell as in all
11
* supporting documentation.
12
* 2. All advertising materials mentioning features or use of this software
13
* must display the following acknowledgement:
14
* This product includes software developed by
15
* Inferno Nettverk A/S, Norway.
16
* 3. The name of the author may not be used to endorse or promote products
17
* derived from this software without specific prior written permission.
19
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
* Inferno Nettverk A/S requests users of this software to return to
32
* Software Distribution Coordinator or sdc@inet.no
33
* Inferno Nettverk A/S
39
* any improvements or extensions that they make and grant Inferno Nettverk A/S
40
* the rights to redistribute these changes.
46
static const char rcsid[] =
47
"$Id: Rgetpeername.c,v 1.32 2003/07/01 13:21:23 michaels Exp $";
50
Rgetpeername(s, name, namelen)
52
struct sockaddr *name;
55
const char *function = "Rgetpeername()";
56
struct socksfd_t *socksfd;
57
struct sockaddr *addr;
61
slog(LOG_DEBUG, "%s", function);
63
if (!socks_addrisok((unsigned int)s)) {
64
socks_rmaddr((unsigned int)s);
65
return getpeername(s, name, namelen);
68
socksfd = socks_getaddr((unsigned int)s);
69
SASSERTX(socksfd != NULL);
71
switch (socksfd->state.command) {
73
addr = &socksfd->forus.accepted;
77
if (socksfd->state.err != 0) {
81
addr = &socksfd->forus.connected;
84
case SOCKS_UDPASSOCIATE:
85
if (!socksfd->state.udpconnect) {
89
addr = &socksfd->forus.connected;
93
SERRX(socksfd->state.command);
97
*namelen = MIN(*namelen, sizeof(*addr));
98
memcpy(name, addr, (size_t)*namelen);