155682Smarkm/* 2120945Snectar * Copyright (c) 1995 - 2001, 2003 Kungliga Tekniska H�gskolan 355682Smarkm * (Royal Institute of Technology, Stockholm, Sweden). 455682Smarkm * All rights reserved. 555682Smarkm * 655682Smarkm * Redistribution and use in source and binary forms, with or without 755682Smarkm * modification, are permitted provided that the following conditions 855682Smarkm * are met: 955682Smarkm * 1055682Smarkm * 1. Redistributions of source code must retain the above copyright 1155682Smarkm * notice, this list of conditions and the following disclaimer. 1255682Smarkm * 1355682Smarkm * 2. Redistributions in binary form must reproduce the above copyright 1455682Smarkm * notice, this list of conditions and the following disclaimer in the 1555682Smarkm * documentation and/or other materials provided with the distribution. 1655682Smarkm * 1755682Smarkm * 3. Neither the name of the Institute nor the names of its contributors 1855682Smarkm * may be used to endorse or promote products derived from this software 1955682Smarkm * without specific prior written permission. 2055682Smarkm * 2155682Smarkm * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 2255682Smarkm * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2355682Smarkm * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2455682Smarkm * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 2555682Smarkm * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2655682Smarkm * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2755682Smarkm * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2855682Smarkm * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2955682Smarkm * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 3055682Smarkm * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3155682Smarkm * SUCH DAMAGE. 3255682Smarkm */ 3355682Smarkm 34178825Sdfr/* $Id: kafs.h 20652 2007-05-10 19:30:18Z lha $ */ 3555682Smarkm 3655682Smarkm#ifndef __KAFS_H 3755682Smarkm#define __KAFS_H 3855682Smarkm 3955682Smarkm/* XXX must include krb5.h or krb.h */ 4055682Smarkm 4155682Smarkm/* sys/ioctl.h must be included manually before kafs.h */ 4255682Smarkm 4355682Smarkm/* 4455682Smarkm */ 4555682Smarkm#define AFSCALL_PIOCTL 20 4655682Smarkm#define AFSCALL_SETPAG 21 4755682Smarkm 4855682Smarkm#ifndef _VICEIOCTL 4955682Smarkm#define _VICEIOCTL(id) ((unsigned int ) _IOW('V', id, struct ViceIoctl)) 50178825Sdfr#define _AFSCIOCTL(id) ((unsigned int ) _IOW('C', id, struct ViceIoctl)) 5155682Smarkm#endif /* _VICEIOCTL */ 5255682Smarkm 5355682Smarkm#define VIOCSETAL _VICEIOCTL(1) 5455682Smarkm#define VIOCGETAL _VICEIOCTL(2) 5555682Smarkm#define VIOCSETTOK _VICEIOCTL(3) 5655682Smarkm#define VIOCGETVOLSTAT _VICEIOCTL(4) 5755682Smarkm#define VIOCSETVOLSTAT _VICEIOCTL(5) 5855682Smarkm#define VIOCFLUSH _VICEIOCTL(6) 5955682Smarkm#define VIOCGETTOK _VICEIOCTL(8) 6055682Smarkm#define VIOCUNLOG _VICEIOCTL(9) 6155682Smarkm#define VIOCCKSERV _VICEIOCTL(10) 6255682Smarkm#define VIOCCKBACK _VICEIOCTL(11) 6355682Smarkm#define VIOCCKCONN _VICEIOCTL(12) 6455682Smarkm#define VIOCWHEREIS _VICEIOCTL(14) 6555682Smarkm#define VIOCACCESS _VICEIOCTL(20) 6655682Smarkm#define VIOCUNPAG _VICEIOCTL(21) 6755682Smarkm#define VIOCGETFID _VICEIOCTL(22) 6855682Smarkm#define VIOCSETCACHESIZE _VICEIOCTL(24) 6955682Smarkm#define VIOCFLUSHCB _VICEIOCTL(25) 7055682Smarkm#define VIOCNEWCELL _VICEIOCTL(26) 7155682Smarkm#define VIOCGETCELL _VICEIOCTL(27) 7255682Smarkm#define VIOC_AFS_DELETE_MT_PT _VICEIOCTL(28) 7355682Smarkm#define VIOC_AFS_STAT_MT_PT _VICEIOCTL(29) 7455682Smarkm#define VIOC_FILE_CELL_NAME _VICEIOCTL(30) 7555682Smarkm#define VIOC_GET_WS_CELL _VICEIOCTL(31) 7655682Smarkm#define VIOC_AFS_MARINER_HOST _VICEIOCTL(32) 7755682Smarkm#define VIOC_GET_PRIMARY_CELL _VICEIOCTL(33) 7855682Smarkm#define VIOC_VENUSLOG _VICEIOCTL(34) 7955682Smarkm#define VIOC_GETCELLSTATUS _VICEIOCTL(35) 8055682Smarkm#define VIOC_SETCELLSTATUS _VICEIOCTL(36) 8155682Smarkm#define VIOC_FLUSHVOLUME _VICEIOCTL(37) 8255682Smarkm#define VIOC_AFS_SYSNAME _VICEIOCTL(38) 8355682Smarkm#define VIOC_EXPORTAFS _VICEIOCTL(39) 8455682Smarkm#define VIOCGETCACHEPARAMS _VICEIOCTL(40) 8555682Smarkm#define VIOC_GCPAGS _VICEIOCTL(48) 8655682Smarkm 87178825Sdfr#define VIOCGETTOK2 _AFSCIOCTL(7) 88178825Sdfr#define VIOCSETTOK2 _AFSCIOCTL(8) 89178825Sdfr 9055682Smarkmstruct ViceIoctl { 9155682Smarkm caddr_t in, out; 9255682Smarkm short in_size; 9355682Smarkm short out_size; 9455682Smarkm}; 9555682Smarkm 9655682Smarkmstruct ClearToken { 9755682Smarkm int32_t AuthHandle; 9855682Smarkm char HandShakeKey[8]; 9955682Smarkm int32_t ViceId; 10055682Smarkm int32_t BeginTimestamp; 10155682Smarkm int32_t EndTimestamp; 10255682Smarkm}; 10355682Smarkm 10455682Smarkm/* Use k_hasafs() to probe if the machine supports AFS syscalls. 10555682Smarkm The other functions will generate a SIGSYS if AFS is not supported */ 10655682Smarkm 107178825Sdfrint k_hasafs (void); 108178825Sdfrint k_hasafs_recheck (void); 10955682Smarkm 110178825Sdfrint krb_afslog (const char *cell, const char *realm); 111178825Sdfrint krb_afslog_uid (const char *cell, const char *realm, uid_t uid); 112178825Sdfrint krb_afslog_home (const char *cell, const char *realm, 113178825Sdfr const char *homedir); 114178825Sdfrint krb_afslog_uid_home (const char *cell, const char *realm, uid_t uid, 115178825Sdfr const char *homedir); 11655682Smarkm 117178825Sdfrint krb_realm_of_cell (const char *cell, char **realm); 11855682Smarkm 11955682Smarkm/* compat */ 12055682Smarkm#define k_afsklog krb_afslog 12155682Smarkm#define k_afsklog_uid krb_afslog_uid 12255682Smarkm 123178825Sdfrint k_pioctl (char *a_path, 12455682Smarkm int o_opcode, 12555682Smarkm struct ViceIoctl *a_paramsP, 126178825Sdfr int a_followSymlinks); 127178825Sdfrint k_unlog (void); 128178825Sdfrint k_setpag (void); 129178825Sdfrint k_afs_cell_of_file (const char *path, char *cell, int len); 13055682Smarkm 13155682Smarkm 13255682Smarkm 13355682Smarkm/* XXX */ 13455682Smarkm#ifdef KFAILURE 13555682Smarkm#define KRB_H_INCLUDED 13655682Smarkm#endif 13755682Smarkm 13855682Smarkm#ifdef KRB5_RECVAUTH_IGNORE_VERSION 13955682Smarkm#define KRB5_H_INCLUDED 14055682Smarkm#endif 14155682Smarkm 142178825Sdfrvoid kafs_set_verbose (void (*kafs_verbose)(void *, const char *), void *); 143178825Sdfrint kafs_settoken_rxkad (const char *, struct ClearToken *, 144178825Sdfr void *ticket, size_t ticket_len); 14555682Smarkm#ifdef KRB_H_INCLUDED 146178825Sdfrint kafs_settoken (const char*, uid_t, CREDENTIALS*); 14755682Smarkm#endif 148120945Snectar#ifdef KRB5_H_INCLUDED 149178825Sdfrint kafs_settoken5 (krb5_context, const char*, uid_t, krb5_creds*); 150120945Snectar#endif 15155682Smarkm 152120945Snectar 15355682Smarkm#ifdef KRB5_H_INCLUDED 154178825Sdfrkrb5_error_code krb5_afslog_uid (krb5_context context, 15555682Smarkm krb5_ccache id, 15655682Smarkm const char *cell, 15755682Smarkm krb5_const_realm realm, 158178825Sdfr uid_t uid); 159178825Sdfrkrb5_error_code krb5_afslog (krb5_context context, 16055682Smarkm krb5_ccache id, 16155682Smarkm const char *cell, 162178825Sdfr krb5_const_realm realm); 163178825Sdfrkrb5_error_code krb5_afslog_uid_home (krb5_context context, 16455682Smarkm krb5_ccache id, 16555682Smarkm const char *cell, 16655682Smarkm krb5_const_realm realm, 16755682Smarkm uid_t uid, 168178825Sdfr const char *homedir); 16955682Smarkm 170178825Sdfrkrb5_error_code krb5_afslog_home (krb5_context context, 17155682Smarkm krb5_ccache id, 17255682Smarkm const char *cell, 17355682Smarkm krb5_const_realm realm, 174178825Sdfr const char *homedir); 17555682Smarkm 176178825Sdfrkrb5_error_code krb5_realm_of_cell (const char *cell, char **realm); 17755682Smarkm 17855682Smarkm#endif 17955682Smarkm 18055682Smarkm 18155682Smarkm#define _PATH_VICE "/usr/vice/etc/" 18255682Smarkm#define _PATH_THISCELL _PATH_VICE "ThisCell" 18355682Smarkm#define _PATH_CELLSERVDB _PATH_VICE "CellServDB" 18455682Smarkm#define _PATH_THESECELLS _PATH_VICE "TheseCells" 18555682Smarkm 18655682Smarkm#define _PATH_ARLA_VICE "/usr/arla/etc/" 18755682Smarkm#define _PATH_ARLA_THISCELL _PATH_ARLA_VICE "ThisCell" 18855682Smarkm#define _PATH_ARLA_CELLSERVDB _PATH_ARLA_VICE "CellServDB" 18955682Smarkm#define _PATH_ARLA_THESECELLS _PATH_ARLA_VICE "TheseCells" 19055682Smarkm 19190926Snectar#define _PATH_OPENAFS_DEBIAN_VICE "/etc/openafs/" 19290926Snectar#define _PATH_OPENAFS_DEBIAN_THISCELL _PATH_OPENAFS_DEBIAN_VICE "ThisCell" 19390926Snectar#define _PATH_OPENAFS_DEBIAN_CELLSERVDB _PATH_OPENAFS_DEBIAN_VICE "CellServDB" 19490926Snectar#define _PATH_OPENAFS_DEBIAN_THESECELLS _PATH_OPENAFS_DEBIAN_VICE "TheseCells" 19590926Snectar 196178825Sdfr#define _PATH_OPENAFS_MACOSX_VICE "/var/db/openafs/etc/" 197178825Sdfr#define _PATH_OPENAFS_MACOSX_THISCELL _PATH_OPENAFS_MACOSX_VICE "ThisCell" 198178825Sdfr#define _PATH_OPENAFS_MACOSX_CELLSERVDB _PATH_OPENAFS_MACOSX_VICE "CellServDB" 199178825Sdfr#define _PATH_OPENAFS_MACOSX_THESECELLS _PATH_OPENAFS_MACOSX_VICE "TheseCells" 200178825Sdfr 20190926Snectar#define _PATH_ARLA_DEBIAN_VICE "/etc/arla/" 20290926Snectar#define _PATH_ARLA_DEBIAN_THISCELL _PATH_ARLA_DEBIAN_VICE "ThisCell" 20390926Snectar#define _PATH_ARLA_DEBIAN_CELLSERVDB _PATH_ARLA_DEBIAN_VICE "CellServDB" 20490926Snectar#define _PATH_ARLA_DEBIAN_THESECELLS _PATH_ARLA_DEBIAN_VICE "TheseCells" 20590926Snectar 206178825Sdfr#define _PATH_ARLA_OPENBSD_VICE "/etc/afs/" 207178825Sdfr#define _PATH_ARLA_OPENBSD_THISCELL _PATH_ARLA_OPENBSD_VICE "ThisCell" 208178825Sdfr#define _PATH_ARLA_OPENBSD_CELLSERVDB _PATH_ARLA_OPENBSD_VICE "CellServDB" 209178825Sdfr#define _PATH_ARLA_OPENBSD_THESECELLS _PATH_ARLA_OPENBSD_VICE "TheseCells" 210178825Sdfr 21155682Smarkmextern int _kafs_debug; 21255682Smarkm 21355682Smarkm#endif /* __KAFS_H */ 214