xref: /freebsd/lib/libutil/realhostname_sa.3 (revision 0cac72f42c2f9dfe7953cb3dd7c2e93d1d0c61cf)
10cac72f4SYoshinobu Inoue.\" Copyright (C) 1995, 1996, 1997, 1998, 1999, and 2000 WIDE Project.
20cac72f4SYoshinobu Inoue.\" All rights reserved.
30cac72f4SYoshinobu Inoue.\"
40cac72f4SYoshinobu Inoue.\" Redistribution and use in source and binary forms, with or without
50cac72f4SYoshinobu Inoue.\" modification, are permitted provided that the following conditions
60cac72f4SYoshinobu Inoue.\" are met:
70cac72f4SYoshinobu Inoue.\" 1. Redistributions of source code must retain the above copyright
80cac72f4SYoshinobu Inoue.\"    notice, this list of conditions and the following disclaimer.
90cac72f4SYoshinobu Inoue.\" 2. Redistributions in binary form must reproduce the above copyright
100cac72f4SYoshinobu Inoue.\"    notice, this list of conditions and the following disclaimer in the
110cac72f4SYoshinobu Inoue.\"    documentation and/or other materials provided with the distribution.
120cac72f4SYoshinobu Inoue.\" 3. Neither the name of the project nor the names of its contributors
130cac72f4SYoshinobu Inoue.\"    may be used to endorse or promote products derived from this software
140cac72f4SYoshinobu Inoue.\"    without specific prior written permission.
150cac72f4SYoshinobu Inoue.\"
160cac72f4SYoshinobu Inoue.\" THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
170cac72f4SYoshinobu Inoue.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
180cac72f4SYoshinobu Inoue.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
190cac72f4SYoshinobu Inoue.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
200cac72f4SYoshinobu Inoue.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
210cac72f4SYoshinobu Inoue.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
220cac72f4SYoshinobu Inoue.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
230cac72f4SYoshinobu Inoue.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
240cac72f4SYoshinobu Inoue.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
250cac72f4SYoshinobu Inoue.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
260cac72f4SYoshinobu Inoue.\" SUCH DAMAGE.
270cac72f4SYoshinobu Inoue.\"
280cac72f4SYoshinobu Inoue.\" Copyright (c) 1999 Brian Somers <brian@Awfulhak.org>
290cac72f4SYoshinobu Inoue.\" All rights reserved.
300cac72f4SYoshinobu Inoue.\"
310cac72f4SYoshinobu Inoue.\" Redistribution and use in source and binary forms, with or without
320cac72f4SYoshinobu Inoue.\" modification, are permitted provided that the following conditions
330cac72f4SYoshinobu Inoue.\" are met:
340cac72f4SYoshinobu Inoue.\" 1. Redistributions of source code must retain the above copyright
350cac72f4SYoshinobu Inoue.\"    notice, this list of conditions and the following disclaimer.
360cac72f4SYoshinobu Inoue.\" 2. Redistributions in binary form must reproduce the above copyright
370cac72f4SYoshinobu Inoue.\"    notice, this list of conditions and the following disclaimer in the
380cac72f4SYoshinobu Inoue.\"    documentation and/or other materials provided with the distribution.
390cac72f4SYoshinobu Inoue.\"
400cac72f4SYoshinobu Inoue.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
410cac72f4SYoshinobu Inoue.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
420cac72f4SYoshinobu Inoue.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
430cac72f4SYoshinobu Inoue.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
440cac72f4SYoshinobu Inoue.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
450cac72f4SYoshinobu Inoue.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
460cac72f4SYoshinobu Inoue.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
470cac72f4SYoshinobu Inoue.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
480cac72f4SYoshinobu Inoue.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
490cac72f4SYoshinobu Inoue.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
500cac72f4SYoshinobu Inoue.\" SUCH DAMAGE.
510cac72f4SYoshinobu Inoue.\"
520cac72f4SYoshinobu Inoue.\" $FreeBSD$
530cac72f4SYoshinobu Inoue.\"
540cac72f4SYoshinobu Inoue.Dd January 11, 2000
550cac72f4SYoshinobu Inoue.Os
560cac72f4SYoshinobu Inoue.Dt REALHOSTNAME_SA 3
570cac72f4SYoshinobu Inoue.Sh NAME
580cac72f4SYoshinobu Inoue.Nm realhostname_sa
590cac72f4SYoshinobu Inoue.Nd "convert an struct sockaddr to the real host name"
600cac72f4SYoshinobu Inoue.Sh SYNOPSIS
610cac72f4SYoshinobu Inoue.Fd #include <sys/types.h>
620cac72f4SYoshinobu Inoue.Fd #include <netinet/in.h>
630cac72f4SYoshinobu Inoue.Fd #include <libutil.h>
640cac72f4SYoshinobu Inoue.Ft int
650cac72f4SYoshinobu Inoue.Fn realhostname_sa "char *host" "size_t hsize" "struct sockaddr *addr" \
660cac72f4SYoshinobu Inoue"int addrlen"
670cac72f4SYoshinobu Inoue.Pp
680cac72f4SYoshinobu InoueLink with
690cac72f4SYoshinobu Inoue.Va -lutil
700cac72f4SYoshinobu Inoueon the
710cac72f4SYoshinobu Inoue.Xr cc 1
720cac72f4SYoshinobu Inouecommand line.
730cac72f4SYoshinobu Inoue.Sh DESCRIPTION
740cac72f4SYoshinobu InoueThe function
750cac72f4SYoshinobu Inoue.Fn realhostname_sa
760cac72f4SYoshinobu Inoueconverts
770cac72f4SYoshinobu Inoue.Ar addr
780cac72f4SYoshinobu Inoueto the corresponding host name.  This is done by resolving
790cac72f4SYoshinobu Inoue.Ar addr
800cac72f4SYoshinobu Inoueto a host name and then ensuring that the host name resolves
810cac72f4SYoshinobu Inoueback to
820cac72f4SYoshinobu Inoue.Ar addr .
830cac72f4SYoshinobu Inoue.Pp
840cac72f4SYoshinobu Inoue.Ar host
850cac72f4SYoshinobu Inouemust point to a buffer of at least
860cac72f4SYoshinobu Inoue.Ar hsize
870cac72f4SYoshinobu Inouebytes, and will always be written to by this function.
880cac72f4SYoshinobu Inoue.Pp
890cac72f4SYoshinobu InoueIf the name resolution doesn't work both ways or if the host name is longer
900cac72f4SYoshinobu Inouethan
910cac72f4SYoshinobu Inoue.Ar hsize
920cac72f4SYoshinobu Inouebytes,
930cac72f4SYoshinobu Inoue.Xr getnameinfo 3
940cac72f4SYoshinobu Inouewith NI_NUMERICHOST specified, is used to convert
950cac72f4SYoshinobu Inoue.Ar addr
960cac72f4SYoshinobu Inoueto an ASCII form.
970cac72f4SYoshinobu Inoue.Pp
980cac72f4SYoshinobu InoueIf the string written to
990cac72f4SYoshinobu Inoue.Ar host
1000cac72f4SYoshinobu Inoueis
1010cac72f4SYoshinobu Inoue.Ar hsize
1020cac72f4SYoshinobu Inouebytes long,
1030cac72f4SYoshinobu Inoue.Ar host
1040cac72f4SYoshinobu Inouewill not be NUL terminated.
1050cac72f4SYoshinobu Inoue.Sh RETURN VALUES
1060cac72f4SYoshinobu Inoue.Fn realhostname_sa
1070cac72f4SYoshinobu Inouewill return one of the following constants which are defined in
1080cac72f4SYoshinobu Inoue.Pa libutil.h :
1090cac72f4SYoshinobu Inoue.Pp
1100cac72f4SYoshinobu Inoue.Bl -tag -width XXX -offset XXX
1110cac72f4SYoshinobu Inoue.It Li HOSTNAME_FOUND
1120cac72f4SYoshinobu InoueA valid host name was found.
1130cac72f4SYoshinobu Inoue.It Li HOSTNAME_INCORRECTNAME
1140cac72f4SYoshinobu InoueA host name was found, but it did not resolve back to the passed
1150cac72f4SYoshinobu Inoue.Ar ip .
1160cac72f4SYoshinobu Inoue.Ar host
1170cac72f4SYoshinobu Inouenow contains the numeric value of
1180cac72f4SYoshinobu Inoue.Ar ip .
1190cac72f4SYoshinobu Inoue.It Li HOSTNAME_INVALIDADDR
1200cac72f4SYoshinobu Inoue.Ar ip
1210cac72f4SYoshinobu Inouecould not be resolved.
1220cac72f4SYoshinobu Inoue.Ar host
1230cac72f4SYoshinobu Inouenow contains the numeric value of
1240cac72f4SYoshinobu Inoue.Ar ip .
1250cac72f4SYoshinobu Inoue.It Li HOSTNAME_INVALIDNAME
1260cac72f4SYoshinobu InoueA host name was found, but it could not be resolved back to any ip number.
1270cac72f4SYoshinobu Inoue.Ar host
1280cac72f4SYoshinobu Inouenow contains the numeric value of
1290cac72f4SYoshinobu Inoue.Ar ip .
1300cac72f4SYoshinobu Inoue.El
1310cac72f4SYoshinobu Inoue.Sh SEE ALSO
1320cac72f4SYoshinobu Inoue.Xr getaddrinfo 3 ,
1330cac72f4SYoshinobu Inoue.Xr getnameinfo 3 ,
1340cac72f4SYoshinobu Inoue.Xr realhostname 3
1350cac72f4SYoshinobu Inoue
136