xref: /netbsd-src/crypto/external/bsd/heimdal/dist/lib/kafs/kafs.h (revision d3273b5b76f5afaafe308cead5511dbb8df8c5e9)
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