| 1 | /*	$NetBSD: kafs_locl.h,v 1.2 2017/01/28 21:31:49 christos Exp $	*/ | 
| 2 |  | 
| 3 | /* | 
| 4 |  * Copyright (c) 1995, 1996, 1997, 1998, 1999 Kungliga Tekniska Högskolan | 
| 5 |  * (Royal Institute of Technology, Stockholm, Sweden). | 
| 6 |  * All rights reserved. | 
| 7 |  * | 
| 8 |  * Redistribution and use in source and binary forms, with or without | 
| 9 |  * modification, are permitted provided that the following conditions | 
| 10 |  * are met: | 
| 11 |  * | 
| 12 |  * 1. Redistributions of source code must retain the above copyright | 
| 13 |  *    notice, this list of conditions and the following disclaimer. | 
| 14 |  * | 
| 15 |  * 2. Redistributions in binary form must reproduce the above copyright | 
| 16 |  *    notice, this list of conditions and the following disclaimer in the | 
| 17 |  *    documentation and/or other materials provided with the distribution. | 
| 18 |  * | 
| 19 |  * 3. Neither the name of the Institute nor the names of its contributors | 
| 20 |  *    may be used to endorse or promote products derived from this software | 
| 21 |  *    without specific prior written permission. | 
| 22 |  * | 
| 23 |  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND | 
| 24 |  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
| 25 |  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 
| 26 |  * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE | 
| 27 |  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | 
| 28 |  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | 
| 29 |  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 
| 30 |  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | 
| 31 |  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | 
| 32 |  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | 
| 33 |  * SUCH DAMAGE. | 
| 34 |  */ | 
| 35 |  | 
| 36 | /* Id */ | 
| 37 |  | 
| 38 | #ifndef __KAFS_LOCL_H__ | 
| 39 | #define __KAFS_LOCL_H__ | 
| 40 |  | 
| 41 | #ifdef HAVE_CONFIG_H | 
| 42 | #include <config.h> | 
| 43 | #endif | 
| 44 |  | 
| 45 | #include <stdio.h> | 
| 46 | #include <stdlib.h> | 
| 47 | #include <string.h> | 
| 48 | #include <signal.h> | 
| 49 | #include <setjmp.h> | 
| 50 | #include <errno.h> | 
| 51 |  | 
| 52 | #ifdef HAVE_SYS_TYPES_H | 
| 53 | #include <sys/types.h> | 
| 54 | #endif | 
| 55 | #ifdef HAVE_UNISTD_H | 
| 56 | #include <unistd.h> | 
| 57 | #endif | 
| 58 | #if defined(HAVE_SYS_IOCTL_H) && SunOS != 40 | 
| 59 | #include <sys/ioctl.h> | 
| 60 | #endif | 
| 61 | #ifdef HAVE_SYS_FILIO_H | 
| 62 | #include <sys/filio.h> | 
| 63 | #endif | 
| 64 | #ifdef HAVE_SYS_SYSCTL_H | 
| 65 | #include <sys/sysctl.h> | 
| 66 | #endif | 
| 67 |  | 
| 68 | #ifdef HAVE_SYS_SYSCALL_H | 
| 69 | #include <sys/syscall.h> | 
| 70 | #endif | 
| 71 | #ifdef HAVE_SYS_SOCKET_H | 
| 72 | #include <sys/socket.h> | 
| 73 | #endif | 
| 74 | #ifdef HAVE_NETINET_IN_H | 
| 75 | #include <netinet/in.h> | 
| 76 | #endif | 
| 77 | #ifdef HAVE_NETINET_IN6_H | 
| 78 | #include <netinet/in6.h> | 
| 79 | #endif | 
| 80 | #ifdef HAVE_NETINET6_IN6_H | 
| 81 | #include <netinet6/in6.h> | 
| 82 | #endif | 
| 83 |  | 
| 84 | #ifdef HAVE_NETDB_H | 
| 85 | #include <netdb.h> | 
| 86 | #endif | 
| 87 |  | 
| 88 | #ifdef HAVE_ARPA_NAMESER_H | 
| 89 | #include <arpa/nameser.h> | 
| 90 | #endif | 
| 91 | #ifdef HAVE_RESOLV_H | 
| 92 | #include <resolv.h> | 
| 93 | #endif | 
| 94 | #include <krb5/roken.h> | 
| 95 |  | 
| 96 | #ifdef KRB5 | 
| 97 | #include <krb5/krb5.h> | 
| 98 | #endif | 
| 99 | #ifdef KRB5 | 
| 100 | #include "crypto-headers.h" | 
| 101 | #include <krb5/krb5-v4compat.h> | 
| 102 | typedef struct credentials CREDENTIALS; | 
| 103 | #endif /* KRB5 */ | 
| 104 | #ifndef NO_AFS | 
| 105 | #include <krb5/kafs.h> | 
| 106 | #endif | 
| 107 |  | 
| 108 | #include <krb5/resolve.h> | 
| 109 |  | 
| 110 | #include "afssysdefs.h" | 
| 111 |  | 
| 112 | struct kafs_data; | 
| 113 | struct kafs_token; | 
| 114 | typedef int (*afslog_uid_func_t)(struct kafs_data *, | 
| 115 | 				 const char *, | 
| 116 | 				 const char *, | 
| 117 | 				 uid_t, | 
| 118 | 				 const char *); | 
| 119 |  | 
| 120 | typedef int (*get_cred_func_t)(struct kafs_data*, const char*, const char*, | 
| 121 | 			       const char*, uid_t, struct kafs_token *); | 
| 122 |  | 
| 123 | typedef char* (*get_realm_func_t)(struct kafs_data*, const char*); | 
| 124 |  | 
| 125 | struct kafs_data { | 
| 126 |     const char *name; | 
| 127 |     afslog_uid_func_t afslog_uid; | 
| 128 |     get_cred_func_t get_cred; | 
| 129 |     get_realm_func_t get_realm; | 
| 130 |     const char *(*get_error)(struct kafs_data *, int); | 
| 131 |     void (*free_error)(struct kafs_data *, const char *); | 
| 132 |     void *data; | 
| 133 | }; | 
| 134 |  | 
| 135 | struct kafs_token { | 
| 136 |     struct ClearToken ct; | 
| 137 |     void *ticket; | 
| 138 |     size_t ticket_len; | 
| 139 | }; | 
| 140 |  | 
| 141 | void _kafs_foldup(char *, const char *); | 
| 142 |  | 
| 143 | int _kafs_afslog_all_local_cells(struct kafs_data*, uid_t, const char*); | 
| 144 |  | 
| 145 | int _kafs_get_cred(struct kafs_data*, const char*, const char*, const char *, | 
| 146 | 		   uid_t, struct kafs_token *); | 
| 147 |  | 
| 148 | int | 
| 149 | _kafs_realm_of_cell(struct kafs_data *, const char *, char **); | 
| 150 |  | 
| 151 | int | 
| 152 | _kafs_v4_to_kt(CREDENTIALS *, uid_t, struct kafs_token *); | 
| 153 |  | 
| 154 | void | 
| 155 | _kafs_fixup_viceid(struct ClearToken *, uid_t); | 
| 156 |  | 
| 157 | int | 
| 158 | _kafs_derive_des_key(krb5_enctype, void *, size_t, char[8]); | 
| 159 |  | 
| 160 | #ifdef _AIX | 
| 161 | int aix_pioctl(char*, int, struct ViceIoctl*, int); | 
| 162 | int aix_setpag(void); | 
| 163 | #endif | 
| 164 |  | 
| 165 | #endif /* __KAFS_LOCL_H__ */ | 
| 166 |  |