source: trunk/include/sh_files.h@ 559

Last change on this file since 559 was 514, checked in by katerina, 8 years ago

Fix for ticket #407 (option to set auditd flags).

File size: 7.1 KB
Line 
1/* SAMHAIN file system integrity testing */
2/* Copyright (C) 1999, 2000 Rainer Wichmann */
3/* */
4/* This program is free software; you can redistribute it */
5/* and/or modify */
6/* it under the terms of the GNU General Public License as */
7/* published by */
8/* the Free Software Foundation; either version 2 of the License, or */
9/* (at your option) any later version. */
10/* */
11/* This program is distributed in the hope that it will be useful, */
12/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
13/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
14/* GNU General Public License for more details. */
15/* */
16/* You should have received a copy of the GNU General Public License */
17/* along with this program; if not, write to the Free Software */
18/* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
19
20#ifndef SH_FILES_H
21#define SH_FILES_H
22
23void sh_audit_mark (const char * file);
24void sh_audit_commit ();
25void sh_audit_delete_all ();
26int sh_audit_set_flags(const char * str);
27char * sh_audit_fetch (char * file, time_t mtime, time_t ctime, time_t atime, char * result, size_t rsize);
28
29struct sh_dirent {
30 char * sh_d_name;
31 struct sh_dirent * next;
32};
33
34/* Fix the check flags
35 */
36void sh_files_fixup_mask (int class, unsigned long * check_flags);
37
38/* Dequote a filename in the config file
39 */
40char * sh_files_parse_input(const char * str_s, size_t * len);
41
42/* Check whether a file is in the config
43 */
44char * sh_files_findfile(const char * path);
45
46/* Find the most specific directory in the config
47 */
48char * sh_files_find_mostspecific_dir(const char * path);
49
50/* free a directory listing
51 */
52void kill_sh_dirlist (struct sh_dirent * dirlist);
53
54#ifdef NEED_ADD_DIRENT
55/* add an entry to a directory listing
56 */
57struct sh_dirent * addto_sh_dirlist (struct dirent * thisEntry,
58 struct sh_dirent * dirlist);
59#endif
60
61/* register exceptions to hardlink check
62 */
63int sh_files_hle_reg (const char * str);
64
65/* Check for new files/dirs matching configured glob patterns.
66 */
67void sh_files_check_globPatterns();
68
69/* Check for new files (only) matching configured glob patterns.
70 */
71void sh_files_check_globFilePatterns();
72
73/* check the setup
74 */
75int sh_files_test_setup (void);
76
77/* check if allignore
78 */
79int sh_files_is_allignore (char * str);
80
81/* activate hardlink check
82 */
83int sh_files_check_hardlinks (const char * opt);
84
85/* check rsrc fork (Mac OS X)
86 */
87int sh_files_use_rsrc(const char * str);
88
89/* set recursion depth
90 */
91int sh_files_setrec (void);
92
93/* report only once
94 */
95int sh_files_reportonce(const char * c);
96
97/* report full details
98 */
99int sh_files_fulldetail(const char * c);
100
101/* reset the 'checked' flag
102 */
103void sh_dirs_reset(void);
104
105/* reset the 'checked' flag
106 */
107void sh_files_reset(void);
108
109/* set maximum recursion level
110 */
111int sh_files_setrecursion (const char * flag_s);
112
113/* select a directory stack 2=Two, else One (standard)
114 */
115int set_dirList (int which);
116
117/* push a directory on the stack USER0
118 */
119int sh_files_pushdir_user0 (const char * dirName);
120
121/* push a directory on the stack USER1
122 */
123int sh_files_pushdir_user1 (const char * dirName);
124
125/* push a directory on the stack USER2
126 */
127int sh_files_pushdir_user2 (const char * dirName);
128
129/* push a directory on the stack USER3
130 */
131int sh_files_pushdir_user3 (const char * dirName);
132
133/* push a directory on the stack USER4
134 */
135int sh_files_pushdir_user4 (const char * dirName);
136
137/* push a directory on the stack PRELINK
138 */
139int sh_files_pushdir_prelink (const char * dirName);
140
141/* push a directory on the stack ATTR
142 */
143int sh_files_pushdir_attr (const char * dirName);
144
145/* push a directory on the stack READONLY
146 */
147int sh_files_pushdir_ro (const char * dirName);
148
149/* push a directory on the stack LOGFILE
150 */
151int sh_files_pushdir_log (const char * dirName);
152
153/* push a directory on the stack GROWING LOGFILE
154 */
155int sh_files_pushdir_glog (const char * dirName);
156
157/* push a directory on the stack IGNORE NONE
158 */
159int sh_files_pushdir_noig (const char * dirName);
160
161/* push a directory on the stack IGNORE ALL
162 */
163int sh_files_pushdir_allig (const char * dirName);
164
165
166/* push a file on the stack USER0
167 */
168int sh_files_pushfile_user0 (const char * dirName);
169
170/* push a file on the stack USER1
171 */
172int sh_files_pushfile_user1 (const char * dirName);
173
174/* push a file on the stack USER2
175 */
176int sh_files_pushfile_user2 (const char * dirName);
177
178/* push a file on the stack USER3
179 */
180int sh_files_pushfile_user3 (const char * dirName);
181
182/* push a file on the stack USER4
183 */
184int sh_files_pushfile_user4 (const char * dirName);
185
186/* push a file on the stack PRELINK
187 */
188int sh_files_pushfile_prelink (const char * dirName);
189
190/* push a file on the stack ATTR
191 */
192int sh_files_pushfile_attr (const char * dirName);
193
194/* push a file on the stack READONLY
195 */
196int sh_files_pushfile_ro (const char * dirName);
197
198/* push a file on the stack LOGFILE
199 */
200int sh_files_pushfile_log (const char * dirName);
201
202/* push a file on the stack GROWING LOGFILE
203 */
204int sh_files_pushfile_glog (const char * dirName);
205
206/* push a file on the stack IGNORE NONE
207 */
208int sh_files_pushfile_noig (const char * dirName);
209
210/* push a file on the stack IGNORE ALL
211 */
212int sh_files_pushfile_allig (const char * dirName);
213
214
215/* check directories on the stack
216 */
217unsigned long sh_dirs_chk (int which);
218
219/* check files on the stack
220 */
221unsigned long sh_files_chk (void);
222
223int sh_files_delglobstack (void);
224
225int sh_files_deldirstack (void);
226
227int sh_files_delfilestack (void);
228
229/* redefine policies
230 */
231int sh_files_redef_user0(const char * str);
232int sh_files_redef_user1(const char * str);
233int sh_files_redef_user2(const char * str);
234int sh_files_redef_user3(const char * str);
235int sh_files_redef_user4(const char * str);
236int sh_files_redef_prelink(const char * str);
237int sh_files_redef_readonly(const char * str);
238int sh_files_redef_loggrow(const char * str);
239int sh_files_redef_logfiles(const char * str);
240int sh_files_redef_attributes(const char * str);
241int sh_files_redef_noignore(const char * str);
242int sh_files_redef_allignore(const char * str);
243
244ShFileType sh_files_filecheck (int class, unsigned long check_flags,
245 const char * dirName,
246 const char * infileName,
247 int * reported,
248 int rsrcflag);
249
250int sh_files_checkdir (int iclass, unsigned long check_flags,
251 int idepth, char * iname,
252 char * relativeName);
253
254int sh_files_search_file(char * name, int * class,
255 unsigned long *check_flags, int * reported);
256int sh_files_search_dir(char * name, int * class,
257 unsigned long *check_flags, int *reported,
258 int * rdepth);
259void sh_files_set_file_reported(const char * name);
260void sh_files_clear_file_reported(const char * name);
261
262#endif
263
264
265
266
Note: See TracBrowser for help on using the repository browser.