[BACK]Return to acl.h CVS log [TXT][DIR] Up to [Development] / xfs-cmds / acl / include

File: [Development] / xfs-cmds / acl / include / acl.h (download)

Revision 1.6, Wed Jun 6 04:55:01 2001 UTC (16 years, 4 months ago) by tes
Branch: MAIN
Changes since 1.5: +1 -0 lines

Add ACL_OTHER (defined same as ACL_OTHER_OBJ).

/*
 * Copyright (c) 2001 Silicon Graphics, Inc.  All Rights Reserved.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it would be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 *
 * Further, this software is distributed without any warranty that it is
 * free of the rightful claim of any third person regarding infringement
 * or the like.  Any license provided herein, whether implied or
 * otherwise, applies only to this software file.  Patent licenses, if
 * any, provided herein do not apply to combinations of this program with
 * other software, or any other product whatsoever.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write the Free Software Foundation, Inc., 59
 * Temple Place - Suite 330, Boston MA 02111-1307, USA.
 *
 * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
 * Mountain View, CA  94043, or:
 *
 * http://www.sgi.com
 *
 * For further information regarding this notice, see:
 *
 * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
 */

#ifndef __ACL_H__
#define __ACL_H__

#ifdef __cplusplus
extern "C" {
#endif

/*
 * Data types for Access Control Lists (ACLs)
 */
#define SGI_ACL_FILE	"SGI_ACL_FILE"
#define SGI_ACL_DEFAULT	"SGI_ACL_DEFAULT"

#define SGI_ACL_FILE_SIZE	12
#define SGI_ACL_DEFAULT_SIZE	15

/*
 * An IRIX defined macro not in P1003.1e
 * With ACL_COMPAT_IRIXGET set
 * it used to signify an empty ACL.
 * It is also used to delete an ACL.
 */
#define ACL_NOT_PRESENT	-1

/*
 * Number of "base" ACL entries
 * (USER_OBJ, GROUP_OBJ, MASK, & OTHER_OBJ)
 */
#define NACLBASE	4
#define ACL_MAX_ENTRIES 25	/* Arbitrarily chosen number */

/*
 * Data types required by POSIX P1003.1eD15
 */
typedef ushort	acl_perm_t;
typedef int	acl_type_t;
typedef int	acl_tag_t;

/*
 * On-disk representation of an ACL.
 */
struct acl_entry {
	acl_tag_t 	ae_tag;
	uid_t		ae_id;
	acl_perm_t	ae_perm;	
};
typedef struct acl_entry * acl_entry_t;

struct acl {
	int			acl_cnt;	/* Number of entries */
	struct acl_entry	acl_entry[ACL_MAX_ENTRIES];
};

/*
 * Values for acl_get_entry
 */
#define ACL_FIRST_ENTRY		0x00
#define ACL_NEXT_ENTRY		0x01

/*
 * Values for acl_tag_t
 */
#define ACL_UNDEFINED_TAG	0x00			/* undefined tag */
#define ACL_USER_OBJ		0x01			/* owner */
#define ACL_USER		0x02			/* additional users */
#define ACL_GROUP_OBJ		0x04			/* group */
#define ACL_GROUP		0x08			/* additional groups */
#define ACL_MASK		0x10			/* mask entry */
#define ACL_OTHER_OBJ		0x20			/* other entry */
#define ACL_OTHER		0x20			/* POSIX other entry */
/*
 * Values for acl_type_t
 */
#define ACL_TYPE_ACCESS		0
#define ACL_TYPE_DEFAULT	1
/*
 * Values for acl_perm_t
 */
#define ACL_PERM_NONE	00
#define ACL_READ	04
#define ACL_WRITE	02
#define ACL_EXECUTE	01

/*
 * Values for qualifiers
 */
#define ACL_UNDEFINED_ID	((unsigned int)-1)

/*
 * Values for acl compatibility
 */
#define ACL_COMPAT_DEFAULT	0x00
#define ACL_COMPAT_IRIXGET	0x01

typedef struct acl * acl_t;
typedef acl_perm_t * acl_permset_t;
typedef unsigned int acl_compat_t;

/*
 * User-space POSIX data types and functions.
 */
#ifndef __KERNEL__

extern void acl_set_compat(acl_compat_t);
extern int acl_add_perm(acl_permset_t, acl_perm_t);
extern int acl_clear_perms(acl_permset_t);
extern ssize_t acl_copy_ext(void *, acl_t, ssize_t);
extern acl_t acl_copy_int(const void *);
extern int acl_create_entry(acl_t *, acl_entry_t *);
extern int acl_delete_def_file(const char *);
extern int acl_delete_entry(acl_t, acl_entry_t);
extern int acl_delete_perm(acl_permset_t, acl_perm_t);
extern acl_t acl_dup(acl_t);
extern void acl_entry_sort(acl_t);
extern int acl_free(void *);
extern acl_t acl_from_text(const char *);
extern int acl_get_entry(acl_t, int, acl_entry_t *);
extern acl_t acl_get_fd(int);
extern acl_t acl_get_file(const char *, acl_type_t);
extern int acl_get_perm(acl_permset_t, acl_perm_t);
extern int acl_get_permset(acl_entry_t, acl_permset_t *);
extern void *acl_get_qualifier(acl_entry_t);
extern int acl_get_tag_type(acl_entry_t, acl_tag_t *);
extern acl_t acl_init(int);
extern int acl_set_fd(int, acl_t);
extern int acl_set_file(const char *, acl_type_t, acl_t);
extern int acl_set_permset(acl_entry_t, acl_permset_t);
extern int acl_set_qualifier(acl_entry_t,const void *);
extern int acl_set_tag_type(acl_entry_t, acl_tag_t);
extern ssize_t acl_size(acl_t);
extern char *acl_to_short_text(acl_t, ssize_t *);
extern char *acl_to_text(acl_t, ssize_t *);
extern int acl_valid(acl_t);

/* system calls */
extern int acl_get(const char *, int, struct acl *, struct acl *);
extern int acl_set(const char *, int, struct acl *, struct acl *);

#endif /* __KERNEL__ */

#ifdef __cplusplus
}
#endif

#endif /* __ACL_H__ */