]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blame - lfs/stage2
Merge remote-tracking branch 'alfh/bugfix_openbox_center' into next
[people/teissler/ipfire-2.x.git] / lfs / stage2
CommitLineData
cd1a2927 1###############################################################################
cd1a2927 2# #
70df8302
MT
3# IPFire.org - A linux based firewall #
4# Copyright (C) 2007 Michael Tremer & Christian Schmidt #
5# #
6# This program is free software: you can redistribute it and/or modify #
cd1a2927 7# it under the terms of the GNU General Public License as published by #
70df8302 8# the Free Software Foundation, either version 3 of the License, or #
cd1a2927
MT
9# (at your option) any later version. #
10# #
70df8302 11# This program is distributed in the hope that it will be useful, #
cd1a2927
MT
12# but WITHOUT ANY WARRANTY; without even the implied warranty of #
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14# GNU General Public License for more details. #
15# #
16# You should have received a copy of the GNU General Public License #
70df8302 17# along with this program. If not, see <http://www.gnu.org/licenses/>. #
cd1a2927 18# #
cd1a2927
MT
19###############################################################################
20
21###############################################################################
22# Definitions
23###############################################################################
24
25include Config
26
15679d9f
MT
27VER = ipfire
28
cd1a2927
MT
29THISAPP = stage2
30TARGET = $(DIR_INFO)/$(THISAPP)
31
32###############################################################################
33# Top-level Rules
34###############################################################################
35
36install : $(TARGET)
37
38check :
39
40download :
41
42md5 :
43
44###############################################################################
45# Installation Details
46###############################################################################
47
48$(TARGET) :
49 @$(PREBUILD)
50
51 # Create directories
b8e2d108 52 -mkdir -pv /{bin,boot,etc/opt,etc/modprobe.d,home,lib,mnt,opt,run}
59de0b00 53 -mkdir -pv /{media/{floppy,cdrom,usbkey},sbin,srv,var}
9b0ff0a0
MT
54 -install -dv -m 0750 /root
55 -install -dv -m 1777 /tmp /var/tmp
56 -mkdir -pv /usr/{,local/}{bin,include,lib,sbin,src}
57 -mkdir -pv /usr/{,local/}share/{doc,info,locale,man}
58 -mkdir -v /usr/{,local/}share/{misc,terminfo,zoneinfo}
59 -mkdir -pv /usr/{,local/}share/man/man{1..8}
90d372c4
MT
60 #-for dir in /usr /usr/local; do \
61 # ln -sv share/{man,doc,info} $$dir; \
62 #done
b8e2d108
AF
63
64 # Symlink /var/run -> /run.
65 ln -svf ../run /var/run
cd1a2927
MT
66
67 # Symlinks
68 # for this reason, stage2 rebuild will broke the iso:perl, grubbatch
4a337852 69 -ln -sv /tools/bin/{bash,cat,echo,pwd,stty} /bin
9b0ff0a0
MT
70 -ln -sv /tools/bin/perl /usr/bin
71 -ln -sv /tools/lib/libgcc_s.so{,.1} /usr/lib
4a337852
MT
72 -ln -sv /tools/lib/libstdc++.so{,.6} /usr/lib
73 sed 's/tools/usr/' /tools/lib/libstdc++.la > /usr/lib/libstdc++.la
9b0ff0a0 74 -ln -sv bash /bin/sh
cd1a2927
MT
75
76 # Config files
fb617ff5 77 cp -rvf $(DIR_SRC)/config/etc/* /etc;
9b0ff0a0 78 touch /etc/mtab
0b59f25c
MT
79 echo "$(NAME) v$(VERSION) - $(SLOGAN)" > /etc/issue
80 echo "===============================" >> /etc/issue
81 echo "\n running on \s \r \m" >> /etc/issue
82
71e32384
MT
83 # Bash startup files
84 install --directory --mode=0755 --owner=root --group=root /etc/profile.d
85 for i in $(DIR_SRC)/config/profile.d/*; do \
86 [ -f $$i ] && cp $$i /etc/profile.d; \
87 done
05402246 88 chmod 755 /etc/bashrc
b21b0df6
MT
89
90 # Install root's bash files.
91 for i in $(DIR_SRC)/config/bash/dot_*; do \
92 [ -f $$i ] && cp $$i /root/$$(basename $${i/dot_/\.}); \
93 done
cd1a2927
MT
94
95 # Scripts
96 for i in `find $(DIR_SRC)/src/scripts -maxdepth 1 -type f`; do \
97 sed "s+CONFIG_ROOT+$(CONFIG_ROOT)+g" $$i > /usr/local/bin/`basename $$i`; \
98 chmod 755 /usr/local/bin/`basename $$i`; \
99 done
100
07cdb8f6
SS
101 # Move script to correct place.
102 mv -vf /usr/local/bin/ovpn-ccd-convert /usr/sbin/
103
73372ed4
MT
104 # Install firewall scripts.
105 mkdir -pv /usr/lib/firewall
106 install -m 755 $(DIR_SRC)/config/firewall/rules.pl \
107 /usr/lib/firewall/rules.pl
108 install -m 644 $(DIR_SRC)/config/firewall/firewall-lib.pl \
109 /usr/lib/firewall/firewall-lib.pl
110
cd1a2927
MT
111 # Nobody user
112 -mkdir -p /home/nobody
113 chown -R nobody:nobody /home/nobody
114
9b0ff0a0 115 # Create /var dirs and files
b8e2d108 116 -mkdir -v /var/{lock,log,mail,spool,empty}
9b0ff0a0 117 -mkdir -pv /var/{opt,cache,lib/{misc,locate},local}
069ae085
MT
118 -mkdir -pv /var/log/{counter,calamaris}
119 chown nobody.nobody /var/log/calamaris
b8e2d108
AF
120 touch /var/log/{btmp,lastlog,wtmp,net-traffic.log}
121 chgrp -v utmp /var/log/lastlog
122 chmod -v 664 /var/log/lastlog
b474c1ca 123
90d372c4
MT
124 # Permissions
125 chmod 0711 /var/empty
99f3c72f
MT
126
127 # A small hack to include /root to the iso but not all of it's files.
128 touch /root/ipfire
90d372c4 129
7274a673
JPT
130 # License agreement
131 -mkdir -pv /usr/share/doc/licenses/
132 cp -vf $(DIR_SRC)/doc/COPYING /usr/share/doc/licenses/GPLv3
133
d02853e7
MT
134 # System release
135 echo "$(SYSTEM_RELEASE)" > /etc/system-release
136
065c9931
MT
137 # Pakfire
138 -mkdir -pv /opt/pakfire/db/core
139 echo "$(PAKFIRE_CORE)" > /opt/pakfire/db/core/mine
140
cd1a2927 141 @$(POSTBUILD)