summaryrefslogtreecommitdiff
path: root/src/instcheck.c
blob: e47da8760abb3d1583a209075b4ec59d4024a78b (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
70
71
72
73
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include "logmsg.h"
#include "exit.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);
}