summaryrefslogtreecommitdiff
path: root/src/instcheck.c
blob: c42eebf45d9725730dbcd4be511716648d08e8c5 (plain)
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
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>

#include "exit.h"
#include "logmsg.h"

#include "hier.h"

#define WHO "instcheck"

static 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(const char *home, int uid, int gid, int mode)
{
  perm("", "", "", home, S_IFDIR, uid, gid, mode);
}

void d(const 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(const 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(const 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(const 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);
}