login_cap.h revision 180815
125658Sdavidn/*-
225658Sdavidn * Copyright (c) 1996 by
325658Sdavidn * Sean Eric Fagan <sef@kithrup.com>
425658Sdavidn * David Nugent <davidn@blaze.net.au>
525658Sdavidn * All rights reserved.
625658Sdavidn *
725658Sdavidn * Redistribution and use in source and binary forms, with or without
825658Sdavidn * modification, is permitted provided that the following conditions
925658Sdavidn * are met:
1025658Sdavidn * 1. Redistributions of source code must retain the above copyright
1125658Sdavidn *    notice immediately at the beginning of the file, without modification,
1225658Sdavidn *    this list of conditions, and the following disclaimer.
1325658Sdavidn * 2. Redistributions in binary form must reproduce the above copyright
1425658Sdavidn *    notice, this list of conditions and the following disclaimer in the
1525658Sdavidn *    documentation and/or other materials provided with the distribution.
1625658Sdavidn * 3. This work was done expressly for inclusion into FreeBSD.  Other use
1725658Sdavidn *    is permitted provided this notation is included.
1825658Sdavidn * 4. Absolutely no warranty of function or purpose is made by the authors.
1925658Sdavidn * 5. Modifications may be freely made to this file providing the above
2025658Sdavidn *    conditions are met.
2125658Sdavidn *
2225658Sdavidn * Low-level routines relating to the user capabilities database
2325658Sdavidn *
2425658Sdavidn *	Was login_cap.h,v 1.9 1997/05/07 20:00:01 eivind Exp
2550476Speter * $FreeBSD: head/lib/libutil/login_cap.h 180815 2008-07-25 19:58:14Z brooks $
2625658Sdavidn */
2725658Sdavidn
2825658Sdavidn#ifndef _LOGIN_CAP_H_
2925658Sdavidn#define _LOGIN_CAP_H_
3025658Sdavidn
3125658Sdavidn#define LOGIN_DEFCLASS		"default"
3225670Sdavidn#define LOGIN_DEFROOTCLASS	"root"
3325670Sdavidn#define LOGIN_MECLASS		"me"
3425658Sdavidn#define LOGIN_DEFSTYLE		"passwd"
3525658Sdavidn#define LOGIN_DEFSERVICE	"login"
36101658Srwatson#define LOGIN_DEFUMASK		022
3725658Sdavidn#define LOGIN_DEFPRI		0
3825658Sdavidn#define _PATH_LOGIN_CONF	"/etc/login.conf"
3925658Sdavidn#define _FILE_LOGIN_CONF	".login_conf"
4025658Sdavidn#define _PATH_AUTHPROG		"/usr/libexec/login_"
4125658Sdavidn
4225670Sdavidn#define LOGIN_SETGROUP		0x0001		/* set group */
4325670Sdavidn#define LOGIN_SETLOGIN		0x0002		/* set login (via setlogin) */
4425670Sdavidn#define LOGIN_SETPATH		0x0004		/* set path */
4525670Sdavidn#define LOGIN_SETPRIORITY	0x0008		/* set priority */
4625670Sdavidn#define LOGIN_SETRESOURCES	0x0010		/* set resources (cputime, etc.) */
4725670Sdavidn#define LOGIN_SETUMASK		0x0020		/* set umask, obviously */
4825670Sdavidn#define LOGIN_SETUSER		0x0040		/* set user (via setuid) */
4925670Sdavidn#define LOGIN_SETENV		0x0080		/* set user environment */
50101959Srwatson#define LOGIN_SETMAC		0x0100		/* set user default MAC label */
51180815Sbrooks#define LOGIN_SETCPUMASK	0x0200		/* set user cpumask */
52180815Sbrooks#define LOGIN_SETALL		0x03ff		/* set everything */
5325658Sdavidn
5425670Sdavidn#define BI_AUTH		"authorize"		/* accepted authentication */
5525670Sdavidn#define BI_REJECT	"reject"		/* rejected authentication */
5625670Sdavidn#define BI_CHALLENG	"reject challenge"	/* reject with a challenge */
5725670Sdavidn#define BI_SILENT	"reject silent"		/* reject silently */
5825670Sdavidn#define BI_REMOVE	"remove"		/* remove file on error */
5925670Sdavidn#define BI_ROOTOKAY	"authorize root"	/* root authenticated */
6025670Sdavidn#define BI_SECURE	"authorize secure"	/* okay on non-secure line */
6125670Sdavidn#define BI_SETENV	"setenv"		/* set environment variable */
6225670Sdavidn#define BI_VALUE	"value"			/* set local variable */
6325658Sdavidn
6425670Sdavidn#define AUTH_OKAY		0x01		/* user authenticated */
6525670Sdavidn#define AUTH_ROOTOKAY		0x02		/* root login okay */
6625670Sdavidn#define AUTH_SECURE		0x04		/* secure login */
6725670Sdavidn#define AUTH_SILENT		0x08		/* silent rejection */
6825670Sdavidn#define AUTH_CHALLENGE		0x10		/* a chellenge was given */
6925658Sdavidn
70101658Srwatson#define AUTH_ALLOW		(AUTH_OKAY | AUTH_ROOTOKAY | AUTH_SECURE)
7125670Sdavidn
7225658Sdavidntypedef struct login_cap {
7325670Sdavidn    char    *lc_class;
7425670Sdavidn    char    *lc_cap;
7525670Sdavidn    char    *lc_style;
7625658Sdavidn} login_cap_t;
7725658Sdavidn
7825658Sdavidntypedef struct login_time {
7925670Sdavidn    u_short     lt_start;	/* Start time */
8025670Sdavidn    u_short     lt_end;		/* End time */
8125670Sdavidn#define LTM_NONE  0x00
8225670Sdavidn#define LTM_SUN   0x01
8325670Sdavidn#define LTM_MON   0x02
8425670Sdavidn#define LTM_TUE   0x04
8525670Sdavidn#define LTM_WED   0x08
8625670Sdavidn#define LTM_THU   0x10
8725670Sdavidn#define LTM_FRI   0x20
8825670Sdavidn#define LTM_SAT   0x40
8925670Sdavidn#define LTM_ANY   0x7F
9025670Sdavidn#define LTM_WK    0x3E
9125670Sdavidn#define LTM_WD    0x41
9225670Sdavidn    u_char	 lt_dow;	/* Days of week */
9325658Sdavidn} login_time_t;
9425670Sdavidn
9525658Sdavidn#define LC_MAXTIMES 64
9625658Sdavidn
9725658Sdavidn#include <sys/cdefs.h>
9825658Sdavidn__BEGIN_DECLS
9925658Sdavidnstruct passwd;
10025658Sdavidn
10192917Sobrienvoid login_close(login_cap_t *);
10292917Sobrienlogin_cap_t *login_getclassbyname(const char *, const struct passwd *);
10392917Sobrienlogin_cap_t *login_getclass(const char *);
10492917Sobrienlogin_cap_t *login_getpwclass(const struct passwd *);
10592917Sobrienlogin_cap_t *login_getuserclass(const struct passwd *);
10625658Sdavidn
10794202Sruconst char *login_getcapstr(login_cap_t*, const char *, const char *, const char *);
108121193Smarkmconst char **login_getcaplist(login_cap_t *, const char *, const char *);
10994202Sruconst char *login_getstyle(login_cap_t *, const char *, const char *);
11092917Sobrienrlim_t login_getcaptime(login_cap_t *, const char *, rlim_t, rlim_t);
11192917Sobrienrlim_t login_getcapnum(login_cap_t *, const char *, rlim_t, rlim_t);
11292917Sobrienrlim_t login_getcapsize(login_cap_t *, const char *, rlim_t, rlim_t);
11394202Sruconst char *login_getpath(login_cap_t *, const char *, const char *);
11492917Sobrienint login_getcapbool(login_cap_t *, const char *, int);
11592917Sobrienconst char *login_setcryptfmt(login_cap_t *, const char *, const char *);
11625658Sdavidn
11792917Sobrienint setclasscontext(const char*, unsigned int);
11892917Sobrienint setusercontext(login_cap_t*, const struct passwd*, uid_t, unsigned int);
11992917Sobrienvoid setclassresources(login_cap_t *);
12092917Sobrienvoid setclassenvironment(login_cap_t *, const struct passwd *, int);
12125658Sdavidn
12225670Sdavidn/* Most of these functions are deprecated */
12392917Sobrienint auth_approve(login_cap_t*, const char*, const char*);
12492917Sobrienint auth_check(const char *, const char *, const char *, const char *, int *);
12592917Sobrienvoid auth_env(void);
12692917Sobrienchar *auth_mkvalue(const char *n);
12792917Sobrienint auth_response(const char *, const char *, const char *, const char *, int *, const char *, const char *);
12892917Sobrienvoid auth_rmfiles(void);
12992917Sobrienint auth_scan(int);
13092917Sobrienint auth_script(const char*, ...);
13192917Sobrienint auth_script_data(const char *, int, const char *, ...);
13292917Sobrienchar *auth_valud(const char *);
13392917Sobrienint auth_setopt(const char *, const char *);
13492917Sobrienvoid auth_clropts(void);
13525670Sdavidn
13692917Sobrienvoid auth_checknologin(login_cap_t*);
13792917Sobrienint auth_cat(const char*);
13825658Sdavidn
13992917Sobrienint auth_ttyok(login_cap_t*, const char *);
14092917Sobrienint auth_hostok(login_cap_t*, const char *, char const *);
14192917Sobrienint auth_timeok(login_cap_t*, time_t);
14225658Sdavidn
14325658Sdavidnstruct tm;
14425658Sdavidn
14592917Sobrienlogin_time_t parse_lt(const char *);
14692917Sobrienint in_ltm(const login_time_t *, struct tm *, time_t *);
14792917Sobrienint in_ltms(const login_time_t *, struct tm *, time_t *);
14825658Sdavidn
14925670Sdavidn/* helper functions */
15025658Sdavidn
151121193Smarkmint login_strinlist(const char **, char const *, int);
152121193Smarkmint login_str2inlist(const char **, const char *, const char *, int);
15392917Sobrienlogin_time_t * login_timelist(login_cap_t *, char const *, int *, login_time_t **);
15492917Sobrienint login_ttyok(login_cap_t *, const char *, const char *, const char *);
15592917Sobrienint login_hostok(login_cap_t *, const char *, const char *, const char *, const char *);
15625658Sdavidn
15725658Sdavidn__END_DECLS
15825658Sdavidn
15925658Sdavidn#endif /* _LOGIN_CAP_H_ */
160