1 /*- 2 * Copyright (c) 2009, Sun Microsystems, Inc. 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are met: 7 * - Redistributions of source code must retain the above copyright notice, 8 * this list of conditions and the following disclaimer. 9 * - Redistributions in binary form must reproduce the above copyright notice, 10 * this list of conditions and the following disclaimer in the documentation 11 * and/or other materials provided with the distribution. 12 * - Neither the name of Sun Microsystems, Inc. nor the names of its 13 * contributors may be used to endorse or promote products derived 14 * from this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 * POSSIBILITY OF SUCH DAMAGE. 27 * 28 * $FreeBSD: src/lib/libc/rpc/netname.c,v 1.8 2004/10/16 06:11:35 obrien Exp $ 29 * $DragonFly: src/lib/libc/rpc/netname.c,v 1.3 2005/11/13 12:27:04 swildner Exp $ 30 * 31 * @(#)netname.c 1.8 91/03/11 Copyr 1986 Sun Micro 32 */ 33 34 /* 35 * netname utility routines 36 * convert from unix names to network names and vice-versa 37 * This module is operating system dependent! 38 * What we define here will work with any unix system that has adopted 39 * the sun NIS domain architecture. 40 */ 41 42 #include "namespace.h" 43 #include <sys/param.h> 44 #include <rpc/rpc.h> 45 #include <rpc/rpc_com.h> 46 #ifdef YP 47 #include <rpcsvc/yp_prot.h> 48 #include <rpcsvc/ypclnt.h> 49 #endif 50 #include <ctype.h> 51 #include <limits.h> 52 #include <stdio.h> 53 #include <stdlib.h> 54 #include <string.h> 55 #include <unistd.h> 56 #include "un-namespace.h" 57 58 #ifndef MAXHOSTNAMELEN 59 #define MAXHOSTNAMELEN 256 60 #endif 61 #ifndef NGROUPS 62 #define NGROUPS 16 63 #endif 64 65 #define TYPE_BIT(type) (sizeof (type) * CHAR_BIT) 66 67 #define TYPE_SIGNED(type) (((type) -1) < 0) 68 69 /* 70 ** 302 / 1000 is log10(2.0) rounded up. 71 ** Subtract one for the sign bit if the type is signed; 72 ** add one for integer division truncation; 73 ** add one more for a minus sign if the type is signed. 74 */ 75 #define INT_STRLEN_MAXIMUM(type) \ 76 ((TYPE_BIT(type) - TYPE_SIGNED(type)) * 302 / 1000 + 1 + TYPE_SIGNED(type)) 77 78 static char *OPSYS = "unix"; 79 80 /* 81 * Figure out my fully qualified network name 82 */ 83 int 84 getnetname(char *name) 85 { 86 uid_t uid; 87 88 uid = geteuid(); 89 if (uid == 0) { 90 return (host2netname(name, NULL, NULL)); 91 } else { 92 return (user2netname(name, uid, NULL)); 93 } 94 } 95 96 97 /* 98 * Convert unix cred to network-name 99 */ 100 int 101 user2netname(char *netname, const uid_t uid, const char *domain) 102 { 103 char *dfltdom; 104 105 if (domain == NULL) { 106 if (__rpc_get_default_domain(&dfltdom) != 0) { 107 return (0); 108 } 109 domain = dfltdom; 110 } 111 if (strlen(domain) + 1 + INT_STRLEN_MAXIMUM(u_long) + 1 + strlen(OPSYS) > MAXNETNAMELEN) { 112 return (0); 113 } 114 sprintf(netname, "%s.%ld@%s", OPSYS, (u_long)uid, domain); 115 return (1); 116 } 117 118 119 /* 120 * Convert host to network-name 121 */ 122 int 123 host2netname(char *netname, const char *host, const char *domain) 124 { 125 char *dfltdom; 126 char hostname[MAXHOSTNAMELEN+1]; 127 128 if (domain == NULL) { 129 if (__rpc_get_default_domain(&dfltdom) != 0) { 130 return (0); 131 } 132 domain = dfltdom; 133 } 134 if (host == NULL) { 135 gethostname(hostname, sizeof(hostname)); 136 host = hostname; 137 } 138 if (strlen(domain) + 1 + strlen(host) + 1 + strlen(OPSYS) > MAXNETNAMELEN) { 139 return (0); 140 } 141 sprintf(netname, "%s.%s@%s", OPSYS, host, domain); 142 return (1); 143 } 144