auditr.h revision 1780:baba427bca27
1/*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21/*
22 * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
23 * Use is subject to license terms.
24 */
25
26#ifndef _AUDITR_H
27#define	_AUDITR_H
28
29#pragma ident	"%Z%%M%	%I%	%E% SMI"
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
35#include <sys/types.h>
36#include <stdio.h>
37#include <sys/types.h>
38
39#include <grp.h>
40#include <pwd.h>
41#include <signal.h>
42#include <string.h>
43#include <values.h>
44
45#include <dirent.h>
46#include <sys/errno.h>
47#include <sys/file.h>
48#include <sys/param.h>
49#include <sys/stat.h>
50#include <sys/socket.h>
51#include <sys/wait.h>
52#include <sys/time.h>
53#include <tzfile.h>
54#include <sys/resource.h>
55#include <netdb.h>
56#include <unistd.h>
57#include <libgen.h>
58#include <stdlib.h>
59#include <libscf_priv.h>
60
61#include <bsm/audit.h>
62#include <bsm/audit_record.h>
63#include <bsm/libbsm.h>
64
65#include <tsol/label.h>
66#include <sys/tsol/label_macro.h>
67
68#include "auditrt.h"
69
70/*
71 * Flags for on/off code.
72 * The release setting would be 0 0 0 1.
73 */
74#define	AUDIT_PROC_TRACE	0	/* process trace code */
75#define	AUDIT_FILE		0	/* file trace code (use -V also) */
76#define	AUDIT_REC		0	/* record trace code (very verbose) */
77#define	AUDIT_RENAME		1	/* rename output file w/time stamps */
78
79#define	TRUE	1
80#define	FALSE	0
81
82#define	FM_ALLDIR	1	/* f_mode in o.c - all dirs in this dir */
83#define	FM_ALLFILE	0	/* f_mode in o.c - all audit files in dir */
84
85#define	MAXFILELEN	(MAXPATHLEN+MAXNAMLEN+1)
86
87/*
88 * Initial size of a record buffer.
89 * Never smaller than (2 * sizeof (short)).
90 * If a buffer is too small for the record being read then the
91 * current buffer is freed and a large-enough one is allocated.
92 */
93#define	AUDITBUFSIZE	512	/* size of default record buffer */
94
95/*
96 * Controls size of audit_pcbs[] array.
97 * INITSIZE is the initial allocation for the array.
98 * INC is the growth jump when the array becomes too small.
99 */
100#define	PCB_INITSIZE	100
101#define	PCB_INC		50
102
103
104/*
105 * Memory allocation functions.
106 * audit calloc that checks for NULL return
107 */
108extern void	*a_calloc(int, size_t);
109
110/*
111 * Statistical reporting for error conditions.
112 */
113extern void	audit_stats(void);
114extern int	errno;
115
116#ifdef	__cplusplus
117}
118#endif
119
120#endif /* _AUDITR_H */
121