1*d3273b5bSchristos /* $NetBSD: kafs.h,v 1.2 2017/01/28 21:31:49 christos Exp $ */ 2ca1c9b0cSelric 3ca1c9b0cSelric /* 4ca1c9b0cSelric * Copyright (c) 1995 - 2001, 2003 Kungliga Tekniska Högskolan 5ca1c9b0cSelric * (Royal Institute of Technology, Stockholm, Sweden). 6ca1c9b0cSelric * All rights reserved. 7ca1c9b0cSelric * 8ca1c9b0cSelric * Redistribution and use in source and binary forms, with or without 9ca1c9b0cSelric * modification, are permitted provided that the following conditions 10ca1c9b0cSelric * are met: 11ca1c9b0cSelric * 12ca1c9b0cSelric * 1. Redistributions of source code must retain the above copyright 13ca1c9b0cSelric * notice, this list of conditions and the following disclaimer. 14ca1c9b0cSelric * 15ca1c9b0cSelric * 2. Redistributions in binary form must reproduce the above copyright 16ca1c9b0cSelric * notice, this list of conditions and the following disclaimer in the 17ca1c9b0cSelric * documentation and/or other materials provided with the distribution. 18ca1c9b0cSelric * 19ca1c9b0cSelric * 3. Neither the name of the Institute nor the names of its contributors 20ca1c9b0cSelric * may be used to endorse or promote products derived from this software 21ca1c9b0cSelric * without specific prior written permission. 22ca1c9b0cSelric * 23ca1c9b0cSelric * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 24ca1c9b0cSelric * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25ca1c9b0cSelric * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26ca1c9b0cSelric * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 27ca1c9b0cSelric * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28ca1c9b0cSelric * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29ca1c9b0cSelric * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30ca1c9b0cSelric * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31ca1c9b0cSelric * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32ca1c9b0cSelric * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33ca1c9b0cSelric * SUCH DAMAGE. 34ca1c9b0cSelric */ 35ca1c9b0cSelric 36b40995a4Selric /* Id */ 37ca1c9b0cSelric 38ca1c9b0cSelric #ifndef __KAFS_H 39ca1c9b0cSelric #define __KAFS_H 40ca1c9b0cSelric 41ca1c9b0cSelric /* XXX must include krb5.h or krb.h */ 42ca1c9b0cSelric 43ca1c9b0cSelric /* sys/ioctl.h must be included manually before kafs.h */ 44ca1c9b0cSelric 45ca1c9b0cSelric /* 46ca1c9b0cSelric */ 47ca1c9b0cSelric #define AFSCALL_PIOCTL 20 48ca1c9b0cSelric #define AFSCALL_SETPAG 21 49ca1c9b0cSelric 50ca1c9b0cSelric #ifndef _VICEIOCTL 51b9d004c6Schristos #ifdef __GNU__ 52b9d004c6Schristos #define _IOT_ViceIoctl _IOT(_IOTS(caddr_t), 2, _IOTS(short), 2, 0, 0) 53b9d004c6Schristos #endif 54ca1c9b0cSelric #define _VICEIOCTL(id) ((unsigned int ) _IOW('V', id, struct ViceIoctl)) 55ca1c9b0cSelric #define _AFSCIOCTL(id) ((unsigned int ) _IOW('C', id, struct ViceIoctl)) 56ca1c9b0cSelric #endif /* _VICEIOCTL */ 57ca1c9b0cSelric 58ca1c9b0cSelric #define VIOCSETAL _VICEIOCTL(1) 59ca1c9b0cSelric #define VIOCGETAL _VICEIOCTL(2) 60ca1c9b0cSelric #define VIOCSETTOK _VICEIOCTL(3) 61ca1c9b0cSelric #define VIOCGETVOLSTAT _VICEIOCTL(4) 62ca1c9b0cSelric #define VIOCSETVOLSTAT _VICEIOCTL(5) 63ca1c9b0cSelric #define VIOCFLUSH _VICEIOCTL(6) 64ca1c9b0cSelric #define VIOCGETTOK _VICEIOCTL(8) 65ca1c9b0cSelric #define VIOCUNLOG _VICEIOCTL(9) 66ca1c9b0cSelric #define VIOCCKSERV _VICEIOCTL(10) 67ca1c9b0cSelric #define VIOCCKBACK _VICEIOCTL(11) 68ca1c9b0cSelric #define VIOCCKCONN _VICEIOCTL(12) 69ca1c9b0cSelric #define VIOCWHEREIS _VICEIOCTL(14) 70ca1c9b0cSelric #define VIOCACCESS _VICEIOCTL(20) 71ca1c9b0cSelric #define VIOCUNPAG _VICEIOCTL(21) 72ca1c9b0cSelric #define VIOCGETFID _VICEIOCTL(22) 73ca1c9b0cSelric #define VIOCSETCACHESIZE _VICEIOCTL(24) 74ca1c9b0cSelric #define VIOCFLUSHCB _VICEIOCTL(25) 75ca1c9b0cSelric #define VIOCNEWCELL _VICEIOCTL(26) 76ca1c9b0cSelric #define VIOCGETCELL _VICEIOCTL(27) 77ca1c9b0cSelric #define VIOC_AFS_DELETE_MT_PT _VICEIOCTL(28) 78ca1c9b0cSelric #define VIOC_AFS_STAT_MT_PT _VICEIOCTL(29) 79ca1c9b0cSelric #define VIOC_FILE_CELL_NAME _VICEIOCTL(30) 80ca1c9b0cSelric #define VIOC_GET_WS_CELL _VICEIOCTL(31) 81ca1c9b0cSelric #define VIOC_AFS_MARINER_HOST _VICEIOCTL(32) 82ca1c9b0cSelric #define VIOC_GET_PRIMARY_CELL _VICEIOCTL(33) 83ca1c9b0cSelric #define VIOC_VENUSLOG _VICEIOCTL(34) 84ca1c9b0cSelric #define VIOC_GETCELLSTATUS _VICEIOCTL(35) 85ca1c9b0cSelric #define VIOC_SETCELLSTATUS _VICEIOCTL(36) 86ca1c9b0cSelric #define VIOC_FLUSHVOLUME _VICEIOCTL(37) 87ca1c9b0cSelric #define VIOC_AFS_SYSNAME _VICEIOCTL(38) 88ca1c9b0cSelric #define VIOC_EXPORTAFS _VICEIOCTL(39) 89ca1c9b0cSelric #define VIOCGETCACHEPARAMS _VICEIOCTL(40) 90ca1c9b0cSelric #define VIOC_GCPAGS _VICEIOCTL(48) 91ca1c9b0cSelric 92ca1c9b0cSelric #define VIOCGETTOK2 _AFSCIOCTL(7) 93ca1c9b0cSelric #define VIOCSETTOK2 _AFSCIOCTL(8) 94ca1c9b0cSelric 95ca1c9b0cSelric struct ViceIoctl { 96ca1c9b0cSelric caddr_t in, out; 974f77a458Spettai unsigned short in_size; 984f77a458Spettai unsigned short out_size; 99ca1c9b0cSelric }; 100ca1c9b0cSelric 101ca1c9b0cSelric struct ClearToken { 102ca1c9b0cSelric int32_t AuthHandle; 103ca1c9b0cSelric char HandShakeKey[8]; 104ca1c9b0cSelric int32_t ViceId; 105ca1c9b0cSelric int32_t BeginTimestamp; 106ca1c9b0cSelric int32_t EndTimestamp; 107ca1c9b0cSelric }; 108ca1c9b0cSelric 109ca1c9b0cSelric /* Use k_hasafs() to probe if the machine supports AFS syscalls. 110ca1c9b0cSelric The other functions will generate a SIGSYS if AFS is not supported */ 111ca1c9b0cSelric 112ca1c9b0cSelric int k_hasafs (void); 113ca1c9b0cSelric int k_hasafs_recheck (void); 114ca1c9b0cSelric 115ca1c9b0cSelric int krb_afslog (const char *cell, const char *realm); 116ca1c9b0cSelric int krb_afslog_uid (const char *cell, const char *realm, uid_t uid); 117ca1c9b0cSelric int krb_afslog_home (const char *cell, const char *realm, 118ca1c9b0cSelric const char *homedir); 119ca1c9b0cSelric int krb_afslog_uid_home (const char *cell, const char *realm, uid_t uid, 120ca1c9b0cSelric const char *homedir); 121ca1c9b0cSelric 122ca1c9b0cSelric int krb_realm_of_cell (const char *cell, char **realm); 123ca1c9b0cSelric 124ca1c9b0cSelric /* compat */ 125ca1c9b0cSelric #define k_afsklog krb_afslog 126ca1c9b0cSelric #define k_afsklog_uid krb_afslog_uid 127ca1c9b0cSelric 128ca1c9b0cSelric int k_pioctl (char *a_path, 129ca1c9b0cSelric int o_opcode, 130ca1c9b0cSelric struct ViceIoctl *a_paramsP, 131ca1c9b0cSelric int a_followSymlinks); 132ca1c9b0cSelric int k_unlog (void); 133ca1c9b0cSelric int k_setpag (void); 134ca1c9b0cSelric int k_afs_cell_of_file (const char *path, char *cell, int len); 135ca1c9b0cSelric 136ca1c9b0cSelric 137ca1c9b0cSelric 138ca1c9b0cSelric /* XXX */ 139ca1c9b0cSelric #ifdef KFAILURE 140ca1c9b0cSelric #define KRB_H_INCLUDED 141ca1c9b0cSelric #endif 142ca1c9b0cSelric 143ca1c9b0cSelric #ifdef KRB5_RECVAUTH_IGNORE_VERSION 144ca1c9b0cSelric #define KRB5_H_INCLUDED 145ca1c9b0cSelric #endif 146ca1c9b0cSelric 147ca1c9b0cSelric void kafs_set_verbose (void (*kafs_verbose)(void *, const char *), void *); 148ca1c9b0cSelric int kafs_settoken_rxkad (const char *, struct ClearToken *, 149ca1c9b0cSelric void *ticket, size_t ticket_len); 150ca1c9b0cSelric #ifdef KRB_H_INCLUDED 151ca1c9b0cSelric int kafs_settoken (const char*, uid_t, CREDENTIALS*); 152ca1c9b0cSelric #endif 153ca1c9b0cSelric #ifdef KRB5_H_INCLUDED 154ca1c9b0cSelric int kafs_settoken5 (krb5_context, const char*, uid_t, krb5_creds*); 155ca1c9b0cSelric #endif 156ca1c9b0cSelric 157ca1c9b0cSelric 158ca1c9b0cSelric #ifdef KRB5_H_INCLUDED 159ca1c9b0cSelric krb5_error_code krb5_afslog_uid (krb5_context context, 160ca1c9b0cSelric krb5_ccache id, 161ca1c9b0cSelric const char *cell, 162ca1c9b0cSelric krb5_const_realm realm, 163ca1c9b0cSelric uid_t uid); 164ca1c9b0cSelric krb5_error_code krb5_afslog (krb5_context context, 165ca1c9b0cSelric krb5_ccache id, 166ca1c9b0cSelric const char *cell, 167ca1c9b0cSelric krb5_const_realm realm); 168ca1c9b0cSelric krb5_error_code krb5_afslog_uid_home (krb5_context context, 169ca1c9b0cSelric krb5_ccache id, 170ca1c9b0cSelric const char *cell, 171ca1c9b0cSelric krb5_const_realm realm, 172ca1c9b0cSelric uid_t uid, 173ca1c9b0cSelric const char *homedir); 174ca1c9b0cSelric 175ca1c9b0cSelric krb5_error_code krb5_afslog_home (krb5_context context, 176ca1c9b0cSelric krb5_ccache id, 177ca1c9b0cSelric const char *cell, 178ca1c9b0cSelric krb5_const_realm realm, 179ca1c9b0cSelric const char *homedir); 180ca1c9b0cSelric 181ca1c9b0cSelric krb5_error_code krb5_realm_of_cell (const char *cell, char **realm); 182ca1c9b0cSelric 183ca1c9b0cSelric #endif 184ca1c9b0cSelric 185ca1c9b0cSelric 186ca1c9b0cSelric #define _PATH_VICE "/usr/vice/etc/" 187ca1c9b0cSelric #define _PATH_THISCELL _PATH_VICE "ThisCell" 188ca1c9b0cSelric #define _PATH_CELLSERVDB _PATH_VICE "CellServDB" 189ca1c9b0cSelric #define _PATH_THESECELLS _PATH_VICE "TheseCells" 190ca1c9b0cSelric 191ca1c9b0cSelric #define _PATH_ARLA_VICE "/usr/arla/etc/" 192ca1c9b0cSelric #define _PATH_ARLA_THISCELL _PATH_ARLA_VICE "ThisCell" 193ca1c9b0cSelric #define _PATH_ARLA_CELLSERVDB _PATH_ARLA_VICE "CellServDB" 194ca1c9b0cSelric #define _PATH_ARLA_THESECELLS _PATH_ARLA_VICE "TheseCells" 195ca1c9b0cSelric 196ca1c9b0cSelric #define _PATH_OPENAFS_DEBIAN_VICE "/etc/openafs/" 197ca1c9b0cSelric #define _PATH_OPENAFS_DEBIAN_THISCELL _PATH_OPENAFS_DEBIAN_VICE "ThisCell" 198ca1c9b0cSelric #define _PATH_OPENAFS_DEBIAN_CELLSERVDB _PATH_OPENAFS_DEBIAN_VICE "CellServDB" 199ca1c9b0cSelric #define _PATH_OPENAFS_DEBIAN_THESECELLS _PATH_OPENAFS_DEBIAN_VICE "TheseCells" 200ca1c9b0cSelric 201ca1c9b0cSelric #define _PATH_OPENAFS_MACOSX_VICE "/var/db/openafs/etc/" 202ca1c9b0cSelric #define _PATH_OPENAFS_MACOSX_THISCELL _PATH_OPENAFS_MACOSX_VICE "ThisCell" 203ca1c9b0cSelric #define _PATH_OPENAFS_MACOSX_CELLSERVDB _PATH_OPENAFS_MACOSX_VICE "CellServDB" 204ca1c9b0cSelric #define _PATH_OPENAFS_MACOSX_THESECELLS _PATH_OPENAFS_MACOSX_VICE "TheseCells" 205ca1c9b0cSelric 206ca1c9b0cSelric #define _PATH_ARLA_DEBIAN_VICE "/etc/arla/" 207ca1c9b0cSelric #define _PATH_ARLA_DEBIAN_THISCELL _PATH_ARLA_DEBIAN_VICE "ThisCell" 208ca1c9b0cSelric #define _PATH_ARLA_DEBIAN_CELLSERVDB _PATH_ARLA_DEBIAN_VICE "CellServDB" 209ca1c9b0cSelric #define _PATH_ARLA_DEBIAN_THESECELLS _PATH_ARLA_DEBIAN_VICE "TheseCells" 210ca1c9b0cSelric 211ca1c9b0cSelric #define _PATH_ARLA_OPENBSD_VICE "/etc/afs/" 212ca1c9b0cSelric #define _PATH_ARLA_OPENBSD_THISCELL _PATH_ARLA_OPENBSD_VICE "ThisCell" 213ca1c9b0cSelric #define _PATH_ARLA_OPENBSD_CELLSERVDB _PATH_ARLA_OPENBSD_VICE "CellServDB" 214ca1c9b0cSelric #define _PATH_ARLA_OPENBSD_THESECELLS _PATH_ARLA_OPENBSD_VICE "TheseCells" 215ca1c9b0cSelric 216ca1c9b0cSelric extern int _kafs_debug; 217ca1c9b0cSelric 218ca1c9b0cSelric #endif /* __KAFS_H */ 219