1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
#include "exit.h"
#include "logmsg.h"
#include "hier.h"
extern void hier();
#define WHO "instcheck"
void perm(char *prefix1, char *prefix2, char *prefix3, char *file, int type, int uid, int gid, int mode)
{
struct stat st;
if (stat(file, &st) == -1) {
if (errno == ENOENT)
logmsg(WHO, 0, WARN, B("file does nost exist:", prefix1, prefix2, prefix3, file));
else
logmsg(WHO, errno, WARN, B("unable to stat: ../", file));
return;
}
if ((uid != -1) && (st.st_uid != uid))
logmsg(WHO, 0, WARN, B("file has wrong owner: ", prefix1, prefix2, prefix3, file));
if ((gid != -1) && (st.st_gid != gid))
logmsg(WHO, 0, WARN, B("file has wrong group: ", prefix1, prefix2, prefix3, file));
if ((st.st_mode & 07777) != mode)
logmsg(WHO, 0, WARN, B("file has wrong permissions: ", prefix1, prefix2, prefix3, file));
if ((st.st_mode & S_IFMT) != type)
logmsg(WHO, 0, WARN, B("file has wrong type: ", prefix1, prefix2, prefix3, file));
}
void h(char *home, int uid, int gid, int mode)
{
perm("", "", "", home, S_IFDIR, uid, gid, mode);
}
void d(char *home, char *subdir, int uid, int gid, int mode)
{
if (chdir(home) == -1) logmsg(WHO, 111, FATAL, B("unable to switch to: ", home));
perm("", home, "/", subdir, S_IFDIR, uid, gid, mode);
}
void p(char *home, char *fifo, int uid, int gid, int mode)
{
if (chdir(home) == -1) logmsg(WHO, 111, FATAL, B("unable to switch to: ", home));
perm("", home, "/", fifo, S_IFIFO, uid, gid, mode);
}
void c(char *home, char *subdir, char *file, int uid, int gid, int mode)
{
if (chdir(home) == -1) logmsg(WHO, 111, FATAL, B("unable to switch to: ", home));
if (chdir(subdir) == -1) logmsg(WHO, 111, FATAL, B("unable to switch to: ", home, "/", subdir));
perm(".../", subdir, "/", file, S_IFREG, uid, gid, mode);
}
void z(char *home, char *file, int len, int uid, int gid, int mode)
{
if (chdir(home) == -1) logmsg(WHO, 111, FATAL, B("unable to switch to: ", home));
perm("", home, "/", file, S_IFREG, uid, gid, mode);
}
int main()
{
hier();
_exit(0);
}
|