xref: /onnv-gate/usr/src/lib/nsswitch/mdns/common/gethostent6.c (revision 4904:cd464a980538)
1*4904Srs200217 /*
2*4904Srs200217  * CDDL HEADER START
3*4904Srs200217  *
4*4904Srs200217  * The contents of this file are subject to the terms of the
5*4904Srs200217  * Common Development and Distribution License (the "License").
6*4904Srs200217  * You may not use this file except in compliance with the License.
7*4904Srs200217  *
8*4904Srs200217  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*4904Srs200217  * or http://www.opensolaris.org/os/licensing.
10*4904Srs200217  * See the License for the specific language governing permissions
11*4904Srs200217  * and limitations under the License.
12*4904Srs200217  *
13*4904Srs200217  * When distributing Covered Code, include this CDDL HEADER in each
14*4904Srs200217  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*4904Srs200217  * If applicable, add the following below this CDDL HEADER, with the
16*4904Srs200217  * fields enclosed by brackets "[]" replaced with your own identifying
17*4904Srs200217  * information: Portions Copyright [yyyy] [name of copyright owner]
18*4904Srs200217  *
19*4904Srs200217  * CDDL HEADER END
20*4904Srs200217  */
21*4904Srs200217 
22*4904Srs200217 /*
23*4904Srs200217  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
24*4904Srs200217  * Use is subject to license terms.
25*4904Srs200217  */
26*4904Srs200217 
27*4904Srs200217 #pragma ident	"%Z%%M%	%I%	%E% SMI"
28*4904Srs200217 
29*4904Srs200217 #include "mdns_common.h"
30*4904Srs200217 
31*4904Srs200217 /*
32*4904Srs200217  * gethostby* functions for the ipnodes database. The ipnodes
33*4904Srs200217  * database stores both IPv4 and IPv6 address information.
34*4904Srs200217  * mDNS query functions to perform the host lookup are
35*4904Srs200217  * in mdns/common/mdns_common.c file.
36*4904Srs200217  * _nss_mdns_ipnodes_constr is called to initialize
37*4904Srs200217  * the nsswitch backend data structures.
38*4904Srs200217  */
39*4904Srs200217 
40*4904Srs200217 static nss_status_t
getbyname(be,a)41*4904Srs200217 getbyname(be, a)
42*4904Srs200217 	mdns_backend_ptr_t	be;
43*4904Srs200217 	void			*a;
44*4904Srs200217 {
45*4904Srs200217 	nss_XbyY_args_t 	*argp = (nss_XbyY_args_t *)a;
46*4904Srs200217 	int			af = argp->key.ipnode.af_family;
47*4904Srs200217 	char			*hname = (char *)argp->key.ipnode.name;
48*4904Srs200217 	struct mdns_querydata   qdata;
49*4904Srs200217 
50*4904Srs200217 	(void) memset(&qdata, 0, sizeof (struct mdns_querydata));
51*4904Srs200217 	qdata.argp = argp;
52*4904Srs200217 
53*4904Srs200217 	_nss_mdns_updatecfg(be);
54*4904Srs200217 	return (_nss_mdns_querybyname(be, hname, af, &qdata));
55*4904Srs200217 }
56*4904Srs200217 
57*4904Srs200217 static nss_status_t
getbyaddr(be,a)58*4904Srs200217 getbyaddr(be, a)
59*4904Srs200217 	mdns_backend_ptr_t	be;
60*4904Srs200217 	void			*a;
61*4904Srs200217 {
62*4904Srs200217 	int i;
63*4904Srs200217 	char ch;
64*4904Srs200217 	char *chptr;
65*4904Srs200217 	uint8_t *p;
66*4904Srs200217 	struct in6_addr *addr;
67*4904Srs200217 	struct mdns_querydata qdata;
68*4904Srs200217 	char addrqryname[ sizeof ("f.f.f.f.f.f.f.f.f.f.f.f.f.f.f.f") + \
69*4904Srs200217 		sizeof (".f.f.f.f.f.f.f.f.f.f.f.f.f.f.f.f.ip6.arpa.")];
70*4904Srs200217 	nss_XbyY_args_t *argp = (nss_XbyY_args_t *)a;
71*4904Srs200217 
72*4904Srs200217 	(void) memset(&qdata, 0, sizeof (struct mdns_querydata));
73*4904Srs200217 	qdata.argp = argp;
74*4904Srs200217 	argp->h_errno = 0;
75*4904Srs200217 
76*4904Srs200217 	if ((argp->key.hostaddr.type != AF_INET6) ||
77*4904Srs200217 	    (argp->key.hostaddr.len != sizeof (*addr)))
78*4904Srs200217 		return (NSS_NOTFOUND);
79*4904Srs200217 
80*4904Srs200217 	/* LINTED E_BAD_PTR_CAST_ALIGN */
81*4904Srs200217 	addr = (struct in6_addr *)(argp->key.hostaddr.addr);
82*4904Srs200217 
83*4904Srs200217 	if (IN6_IS_ADDR_V4MAPPED(addr)) {
84*4904Srs200217 		struct in_addr ipv4addr;
85*4904Srs200217 
86*4904Srs200217 		IN6_V4MAPPED_TO_INADDR(addr, &ipv4addr);
87*4904Srs200217 		if (inet_ntop(AF_INET, (void *) &ipv4addr.s_addr,
88*4904Srs200217 		(void *)qdata.paddrbuf, sizeof (qdata.paddrbuf)) == NULL)
89*4904Srs200217 				return (NSS_NOTFOUND);
90*4904Srs200217 		qdata.af = AF_INET;
91*4904Srs200217 		p = (uint8_t *)&ipv4addr.s_addr;
92*4904Srs200217 		(void) snprintf(addrqryname, sizeof (addrqryname),
93*4904Srs200217 			"%u.%u.%u.%u.in-addr.arpa.", p[3], p[2], p[1], p[0]);
94*4904Srs200217 	} else {
95*4904Srs200217 		if (inet_ntop(AF_INET6, (void *)addr,
96*4904Srs200217 			(void *)qdata.paddrbuf,
97*4904Srs200217 			sizeof (qdata.paddrbuf)) == NULL)
98*4904Srs200217 			return (NSS_NOTFOUND);
99*4904Srs200217 		qdata.af = AF_INET6;
100*4904Srs200217 		chptr = addrqryname;
101*4904Srs200217 		for (i = 0; i < 16; i++)
102*4904Srs200217 		{
103*4904Srs200217 			ch = ((char *)addr)[15-i];
104*4904Srs200217 			chptr += snprintf(chptr, sizeof (addrqryname)-i*4,
105*4904Srs200217 					"%X.%X.", ch&0x0f, (ch>>4)&0x0f);
106*4904Srs200217 		}
107*4904Srs200217 		(void) strlcpy(chptr, "ip6.arpa.", sizeof (addrqryname)-64);
108*4904Srs200217 	}
109*4904Srs200217 
110*4904Srs200217 	_nss_mdns_updatecfg(be);
111*4904Srs200217 	return (_nss_mdns_querybyaddr(be, addrqryname, qdata.af, &qdata));
112*4904Srs200217 }
113*4904Srs200217 
114*4904Srs200217 /*ARGSUSED*/
115*4904Srs200217 static nss_status_t
_nss_mdns_getent(be,args)116*4904Srs200217 _nss_mdns_getent(be, args)
117*4904Srs200217 	mdns_backend_ptr_t	be;
118*4904Srs200217 	void			*args;
119*4904Srs200217 {
120*4904Srs200217 	return (NSS_UNAVAIL);
121*4904Srs200217 }
122*4904Srs200217 
123*4904Srs200217 /*ARGSUSED*/
124*4904Srs200217 static nss_status_t
_nss_mdns_setent(be,dummy)125*4904Srs200217 _nss_mdns_setent(be, dummy)
126*4904Srs200217 	mdns_backend_ptr_t	be;
127*4904Srs200217 	void			*dummy;
128*4904Srs200217 {
129*4904Srs200217 	return (NSS_UNAVAIL);
130*4904Srs200217 }
131*4904Srs200217 
132*4904Srs200217 /*ARGSUSED*/
133*4904Srs200217 static nss_status_t
_nss_mdns_endent(be,dummy)134*4904Srs200217 _nss_mdns_endent(be, dummy)
135*4904Srs200217 	mdns_backend_ptr_t	be;
136*4904Srs200217 	void			*dummy;
137*4904Srs200217 {
138*4904Srs200217 	return (NSS_UNAVAIL);
139*4904Srs200217 }
140*4904Srs200217 
141*4904Srs200217 /*ARGSUSED*/
142*4904Srs200217 static nss_status_t
_nss_mdns_ipnodes_destr(be,dummy)143*4904Srs200217 _nss_mdns_ipnodes_destr(be, dummy)
144*4904Srs200217 	mdns_backend_ptr_t	be;
145*4904Srs200217 	void			*dummy;
146*4904Srs200217 {
147*4904Srs200217 	_nss_mdns_destr(be);
148*4904Srs200217 	return (NSS_SUCCESS);
149*4904Srs200217 }
150*4904Srs200217 
151*4904Srs200217 static mdns_backend_op_t ipnodes_ops[] = {
152*4904Srs200217 	_nss_mdns_ipnodes_destr,
153*4904Srs200217 	_nss_mdns_endent,
154*4904Srs200217 	_nss_mdns_setent,
155*4904Srs200217 	_nss_mdns_getent,
156*4904Srs200217 	getbyname,
157*4904Srs200217 	getbyaddr,
158*4904Srs200217 };
159*4904Srs200217 
160*4904Srs200217 /*ARGSUSED*/
161*4904Srs200217 nss_backend_t *
_nss_mdns_ipnodes_constr(dummy1,dummy2,dummy3)162*4904Srs200217 _nss_mdns_ipnodes_constr(dummy1, dummy2, dummy3)
163*4904Srs200217 	const char	*dummy1, *dummy2, *dummy3;
164*4904Srs200217 {
165*4904Srs200217 	return (_nss_mdns_constr(ipnodes_ops,
166*4904Srs200217 		sizeof (ipnodes_ops) / sizeof (ipnodes_ops[0])));
167*4904Srs200217 }
168*4904Srs200217 
169*4904Srs200217 /*ARGSUSED*/
170*4904Srs200217 nss_status_t
_nss_get_mdns_ipnodes_name(mdns_backend_ptr_t * be,void ** bufp,size_t * sizep)171*4904Srs200217 _nss_get_mdns_ipnodes_name(mdns_backend_ptr_t *be, void **bufp, size_t *sizep)
172*4904Srs200217 {
173*4904Srs200217 	return (_nss_mdns_gethost_withttl(*bufp, *sizep, 1));
174*4904Srs200217 }
175