aboutsummaryrefslogtreecommitdiff
path: root/files/file_system_reporter.sh
blob: e88d70dc0fb5e5146ff20305c12dd47f704bdd22 (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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#!/bin/bash
#
# file_system_reporter.sh - hash the files on the boot device and compare
#
# This hashes files in $BOOTDEVICE_FILESYSTEM recursively and hashes the entire
# $BOOTDEVICE as well This must be run as root or as a user that has access to
# the specific device.
#

BOOTDEVICE="/dev/sda1";
BOOTDEVICE_FILESYSTEM="/boot/";
STATE_DIR="/var/lib/smartmonster";
PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE="$STATE_DIR/previous_bootdevice_files_state";
CURRENT_BOOTDEVICE_FILESYSTEM_FILE="$STATE_DIR/current_bootdevice_files_state";
PREVIOUS_BOOTDEVICE_RAW_FILE="$STATE_DIR/previous_bootdevice_raw_state";
CURRENT_BOOTDEVICE_RAW_FILE="$STATE_DIR/current_bootdevice_raw_state";
TAMPER=0;
HASHER="`which sha256deep`";
HASHER_ARGS="-r";

if [ "$USER" != "root" ];
then
  echo "You must be root!";
  exit 1;
fi

# XXX: Hello TOCTOU!
if [ ! -d "$STATE_DIR" ];
then
  echo "You have no $STATE_DIR; creating it!";
  mkdir -p $STATE_DIR;

  if [ $? != 0 ];
  then
    echo "Unable to create $STATE_DIR!";
    exit 1;
  fi

fi

# Hash all files and store the state in $STATE_DIR
echo "Hashing files in $BOOTDEVICE_FILESYSTEM";
if [ ! -f "$PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE" ];
then
  echo "You have no $PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE!";
  echo "Assuming first run and populating with hashes!";
  $HASHER $HASHER_ARGS $BOOTDEVICE_FILESYSTEM > $PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE;
  cp -f $PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE $CURRENT_BOOTDEVICE_FILESYSTEM_FILE;
else
  $HASHER $HASHER_ARGS $BOOTDEVICE_FILESYSTEM > $CURRENT_BOOTDEVICE_FILESYSTEM_FILE;
fi

# Diff and recurse
HASHER_ARGS="-r -x";
# Now attempt to detect a miss-match of hashes in the $BOOTDEVICE_FILE path
$HASHER $HASHER_ARGS $PREVIOUS_BOOTDEVICE_FILESYSTEM_FILE $BOOTDEVICE_FILESYSTEM;
HASHER_RESULT=$?;
if [ "$HASHER_RESULT" -ge 2 ];
then
  echo "Files on $BOOTDEVICE_FILESYSTEM appear to be mismatched - tampering detected?";
  TAMPER=1;
fi

# Hash $BOOTDEVICE and store the state in $STATE_DIR
echo "Hashing $BOOTDEVICE";
if [ ! -f "$PREVIOUS_BOOTDEVICE_RAW_FILE" ];
then
  echo "You have no $PREVIOUS_BOOTDEVICE_RAW_FILE!";
  echo "Assuming first run and populating with hashes!";
  $HASHER $BOOTDEVICE > $PREVIOUS_BOOTDEVICE_RAW_FILE;
else
  $HASHER $BOOTDEVICE > $CURRENT_BOOTDEVICE_RAW_FILE;
fi

# Diff
HASHER_ARGS="-x";
# Now attempt to detect a miss-match with the $BOOTDEVICE itself
$HASHER $HASHER_ARGS $PREVIOUS_BOOTDEVICE_RAW_FILE $BOOTDEVICE;
HASHER_RESULT=$?;
if [ "$HASHER_RESULT" -ge 3 ];
then
  echo "Files on $BOOTDEVICE_FILESYSTEM appear to be mismatched - tampering detected?";
  TAMPER=1;
fi

if [ "$TAMPER" -eq 1 ];
then
  echo "Possible tampering detected - please inspect with caution!";
  exit 1;
else
  exit 0;
fi