summaryrefslogtreecommitdiffstats
path: root/etc/rc
blob: 7a8db2bb43b0812ee41c48338d963768830963f0 (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
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
#!/bin/sh

# /etc/rc - master bootup script, invokes php setup
# part of pfSense by Scott Ullrich
# Copyright (C) 2004 Scott Ullrich, All rights reserved.
# originally based on m0n0wall (http://neon1.net/m0n0wall)
# Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>.
# All rights reserved.

stty status '^T'

trap : 2
trap : 3

HOME=/
PATH=/sbin:/bin:/usr/sbin:/usr/bin
export HOME PATH

version=`cat /etc/version`

echo
echo "Welcome to pfSense ${version} ..."
echo

/sbin/mount -a || fsck -y && mount -a
SWAPDEVICE=`cat /etc/fstab | grep swap | cut -f1`
/sbin/dumpon -v $SWAPDEVICE 2>/dev/null
/sbin/swapon -a 2>/dev/null
/bin/mkdir -p /usr/savecore 2>/dev/null
/sbin/savecore /usr/savecore $SWAPDEVICE

/usr/local/bin/php -f /etc/rc.conf_mount_rw

# Repair symlinks if they are broken
if [ ! -L /etc/hosts ]; then
	rm -rf /etc/hosts
	ln -s /var/etc/hosts /etc/hosts    
fi
if [ ! -L /etc/resolv.conf ]; then
    rm -rf /etc/resolv.conf
    ln -s /var/etc/resolv.conf /etc/resolv.conf    
fi

/etc/rc.d/initrandom start >/dev/null
/etc/rc.d/random start >/dev/null

set -T
trap "echo 'Reboot interrupted'; exit 1" 3

# Create uploadbar tmp directory
mkdir /tmp/uploadbar
chmod 777 /tmp/uploadbar

# make some directories in /var
mkdir /var/run /var/log /var/etc /var/db/ipf 2>/dev/null
chmod 0755 /var/db/ipf
rm -rf /var/log/*
rm -rf /var/run/*
rm -rf /tmp/*

# generate circular logfiles
clog -i -s 262144 /var/log/system.log
clog -i -s 262144 /var/log/filter.log
clog -i -s 32768 /var/log/dhcpd.log
clog -i -s 32768 /var/log/vpn.log
clog -i -s 32768 /var/log/portalauth.log
chmod 0600 /var/log/system.log /var/log/filter.log /var/log/dhcpd.log /var/log/vpn.log /var/log/portalauth.log

adjkerntz -i

DEVFS=`mount | grep devfs | wc -l | cut -d" " -f8`
if [ "$DEVFS" = "0" ]; then
    mount_devfs devfs /dev
fi

echo Syncing master.passwd...
/usr/sbin/pwd_mkdb -d /etc/ /etc/master.passwd

# Create an initial utmp file
cd /var/run && cp /dev/null utmp && chmod 644 utmp

# Build devices database
#dev_mkdb

# Run ldconfig
/sbin/ldconfig -elf /usr/lib /usr/local/lib /lib

# let the PHP-based configuration subsystem set up the system now
/etc/rc.bootup

/usr/local/bin/php -f /etc/rc.conf_mount_rw

echo -n Starting Secure Shell Services...
/etc/sshd

echo -n "Starting USB..."
/usr/sbin/usbd 2>>/tmp/bootup_messages
echo Done.

/usr/sbin/cron 2>>/tmp/bootup_messages

/etc/rc.packages

echo "Executing rc.d items..."
for FILE in /usr/local/etc/rc.d/*.sh; do
    echo -n " Starting ${FILE}..."
    sh $FILE >>/tmp/bootup_messages 2>&1
    echo "Done."
done

if -e [ /tmp/filter_boot_dirty ]; then
    # one more pass to give package plugins a chance to adjust
    echo -n "Final firewall setup in progress..."
    /etc/rc.filter_configure
    echo "Done."
fi

/usr/local/bin/php -f /etc/rc.conf_mount_ro

echo "Bootup complete"

exit 0

OpenPOWER on IntegriCloud