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