-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathinstall.sh
134 lines (118 loc) · 3.35 KB
/
install.sh
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
#!/bin/bash
#Tell the installer the root of the files to download
REPO="https://raw.githubusercontent.com/p0lr/PAN-AF/master/"
#check to make sure Python is installed
python --version
#install the python requests module
sudo apt-get install python-requests -y
#install sqlite3
sudo apt-get install sqlite3 -y
#install python-pip
sudo apt-get install python-pip -y
#install xmldiff
sudo pip install xmldiff
#create the directory for the primary dug code to live
cd /var
sudo mkdir dug
sudo chown www-data dug
sudo chgrp www-data dug
cd /var/dug
#create the devices database
sudo touch create.sql
sudo chmod 777 create.sql
sudo echo 'CREATE TABLE DevicesDynamic (DeviceName "TEXT", DeviceMac "TEXT", Groups "Text");' > create.sql
sudo sqlite3 devices.sql < create.sql
sudo rm create.sql
#install the code that updates the firewall
sudo wget -q ${REPO}dug.py
#create the log file
sudo touch dug.log
#Set owner, group, and permissions of files in /var/dug
sudo chown www-data *.*
sudo chgrp www-data *.*
sudo chmod 755 *.*
#update cron to execute the script every minute
cd /etc/cron.d
sudo wget -q ${REPO}dugcron
#install apache2 and configure it to allow cgi
sudo apt-get install apache2 -y
sudo a2enmod cgid
sudo service apache2 restart
#copy cgi scripts into the cgi directory
cd /usr/lib/cgi-bin
sudo wget -q ${REPO}index.cgi
sudo wget -q ${REPO}keygen.cgi
sudo wget -q ${REPO}vlan.cgi
sudo wget -q ${REPO}usermap.cgi
sudo wget -q ${REPO}groupmap.cgi
sudo wget -q ${REPO}clearusers.cgi
sudo wget -q ${REPO}arp.cgi
sudo wget -q ${REPO}dhcp.cgi
sudo wget -q ${REPO}dhcputil.cgi
sudo wget -q ${REPO}policy.cgi
sudo wget -q ${REPO}duglog.cgi
sudo wget -q ${REPO}syslog.cgi
sudo wget -q ${REPO}messageslog.cgi
sudo wget -q ${REPO}accesslog.cgi
sudo wget -q ${REPO}errorlog.cgi
sudo wget -q ${REPO}manback.cgi
sudo wget -q ${REPO}software.cgi
sudo wget -q ${REPO}changes.cgi
sudo wget -q ${REPO}menu.html
sudo chown www-data *.*
sudo chgrp www-data *.*
sudo chmod 755 *.*
#log permissions and rotation configuration
sudo chmod 644 /var/log/syslog
sudo chmod 644 /var/log/messages
cd /etc
sudo rm rsyslog.conf
sudo wget -q ${REPO}rsyslog.conf
sudo chown root rsyslog.conf
sudo chgrp root rsyslog.conf
sudo chmod 755 rsyslog.conf
sudo rm logrotate.conf
sudo wget -q ${REPO}logrotate.conf
sudo chown root logrotate.conf
sudo chgrp root logrotate.conf
sudo chmod 755 logrotate.conf
sudo chmod 755 /var/log/apache2
sudo chmod 644 /var/log/apache2/access.log
sudo chmod 644 /var/log/apache2/error.log
cd /etc/logrotate.d
sudo rm apache2
sudo wget -q ${REPO}apache2
sudo chown root apache2
sudo chgrp root apache2
sudo chmod 644 apache2
#copy default web pages
cd /var/www/html
sudo rm index.html
sudo wget -q ${REPO}index.html
sudo wget -q ${REPO}logo.svg
sudo wget -q ${REPO}style.css
sudo wget -q ${REPO}favicon.ico
sudo touch macs.txt
sudo touch rsa.csv
sudo chown www-data *.*
sudo chgrp www-data *.*
sudo chmod 755 *.*
cd /var
sudo mkdir autoback
sudo chown www-data autoback
sudo chgrp www-data autoback
cd /var/autoback
sudo wget -q ${REPO}autoback.py
sudo chown www-data *.*
sudo chgrp www-data *.*
sudo chmod 755 *.*
#harden the Raspberry Pi
sudo systemctl disable avahi-daemon
sudo systemctl stop avahi-daemon
sudo systemctl disable triggerhappy
sudo systemctl stop triggerhappy
#harden Apache
cd /etc/apache2/conf-available
sudo rm -y security.conf
sudo wget -q ${REPO}security.conf
sudo systemctl restart apache2